AzuraCast/src/Webhook/Connector/TuneIn.php

49 lines
1.6 KiB
PHP

<?php
namespace App\Webhook\Connector;
use App\Entity;
use App\Event\SendWebhooks;
use GuzzleHttp\Exception\TransferException;
use Monolog\Logger;
class TuneIn extends AbstractConnector
{
public function shouldDispatch(SendWebhooks $event, array $triggers): bool
{
return $event->hasTrigger('song_changed');
}
public function dispatch(SendWebhooks $event, array $config): void
{
if (empty($config['partner_id']) || empty($config['partner_key']) || empty($config['station_id'])) {
$this->logger->error('Webhook '.$this->_getName().' is missing necessary configuration. Skipping...');
return;
}
$this->logger->debug('Dispatching TuneIn AIR API call...');
try {
$np = $event->getNowPlaying();
$response = $this->http_client->get('http://air.radiotime.com/Playing.ashx', [
'query' => [
'partnerId' => $config['partner_id'],
'partnerKey' => $config['partner_key'],
'id' => $config['station_id'],
'title' => $np->now_playing->song->title,
'artist' => $np->now_playing->song->artist,
'album' => $np->now_playing->song->artist,
],
]);
$this->logger->debug(
sprintf('TuneIn returned code %d', $response->getStatusCode()),
['response_body' => $response->getBody()->getContents()]
);
} catch(TransferException $e) {
$this->logger->error(sprintf('Error from TuneIn (%d): %s', $e->getCode(), $e->getMessage()));
}
}
}