AzuraCast/src/Radio/Backend/Liquidsoap/Command/AbstractCommand.php

83 lines
2.1 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Radio\Backend\Liquidsoap\Command;
use App\Entity;
use App\Radio\Enums\BackendAdapters;
use Monolog\Logger;
use ReflectionClass;
use Throwable;
abstract class AbstractCommand
{
public function __construct(
protected Logger $logger
) {
}
public function run(
Entity\Station $station,
bool $asAutoDj = false,
?array $payload = []
): string {
$this->logger->pushProcessor(
function ($record) use ($station) {
$record['extra']['station'] = [
'id' => $station->getId(),
'name' => $station->getName(),
];
return $record;
}
);
$className = (new ReflectionClass(static::class))->getShortName();
$this->logger->debug(
sprintf('Running Internal Command %s', $className),
[
'asAutoDj' => $asAutoDj,
'payload' => $payload,
]
);
try {
if (BackendAdapters::Liquidsoap !== $station->getBackendTypeEnum()) {
$this->logger->error('Station does not use Liquidsoap backend.');
return 'false';
}
$result = $this->doRun($station, $asAutoDj, $payload ?? []);
if (true === $result) {
return 'true';
} elseif (false === $result) {
return 'false';
} else {
return (string)$result;
}
} catch (Throwable $e) {
$this->logger->error(
sprintf(
'Error with Internal Command %s: %s',
$className,
$e->getMessage()
),
[
'exception' => $e,
]
);
return 'false';
} finally {
$this->logger->popProcessor();
}
}
abstract protected function doRun(
Entity\Station $station,
bool $asAutoDj = false,
array $payload = []
): mixed;
}