AzuraCast/src/Controller/Api/Stations/Reports/PerformanceAction.php

102 lines
2.8 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Controller\Api\Stations\Reports;
use App\Http\Response;
use App\Http\ServerRequest;
use App\Paginator;
use App\Sync\Task\RunAutomatedAssignmentTask;
use App\Utilities\File;
use League\Csv\Writer;
use Psr\Http\Message\ResponseInterface;
class PerformanceAction
{
public function __invoke(
ServerRequest $request,
Response $response,
RunAutomatedAssignmentTask $automationTask
): ResponseInterface {
$station = $request->getStation();
$automationConfig = (array)$station->getAutomationSettings();
$thresholdDays = (int)($automationConfig['threshold_days']
?? RunAutomatedAssignmentTask::DEFAULT_THRESHOLD_DAYS);
$reportData = $automationTask->generateReport($station, $thresholdDays);
// Do not show songs that are not in playlists.
$reportData = array_filter(
$reportData,
static function ($media) {
return !(empty($media['playlists']));
}
);
$params = $request->getQueryParams();
$format = $params['format'] ?? 'json';
if ($format === 'csv') {
return $this->exportReportAsCsv(
$response,
$reportData,
$station->getShortName() . '_media_' . date('Ymd') . '.csv'
);
}
$paginator = Paginator::fromArray($reportData, $request);
return $paginator->write($response);
}
/**
* @param Response $response
* @param mixed[] $reportData
* @param string $filename
*/
protected function exportReportAsCsv(
Response $response,
array $reportData,
string $filename
): ResponseInterface {
$tempFile = File::generateTempPath($filename);
$csv = Writer::createFromPath($tempFile, 'w+');
$csv->insertOne(
[
'Song Title',
'Song Artist',
'Filename',
'Length',
'Current Playlist',
'Delta Joins',
'Delta Losses',
'Delta Total',
'Play Count',
'Play Percentage',
'Weighted Ratio',
]
);
foreach ($reportData as $row) {
$csv->insertOne([
$row['title'],
$row['artist'],
$row['path'],
$row['length'],
implode('/', $row['playlists']),
$row['delta_positive'],
$row['delta_negative'],
$row['delta_total'],
$row['num_plays'],
$row['percent_plays'] . '%',
$row['ratio'],
]);
}
return $response->withFileDownload($tempFile, $filename, 'text/csv');
}
}