mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2026-03-06 23:47:22 -05:00
* Complete PHPStan Level 6 Fix https://github.com/FreshRSS/FreshRSS/issues/4112 And initiate PHPStan Level 7 * PHPStan Level 6 for tests * Use phpstan/phpstan-phpunit * Update to PHPStan version 1.10 * Fix mixed bug * Fix mixed return bug * Fix paginator bug * Fix FreshRSS_UserConfiguration * A couple more Minz_Configuration bug fixes * A few trivial PHPStan Level 7 fixes * A few more simple PHPStan Level 7 * More files passing PHPStan Level 7 Add interface to replace removed class from https://github.com/FreshRSS/FreshRSS/pull/5251 * A few more PHPStan Level 7 preparations * A few last details
56 lines
1.0 KiB
PHP
56 lines
1.0 KiB
PHP
<?php
|
|
|
|
class FreshRSS_StatsDAOSQLite extends FreshRSS_StatsDAO {
|
|
|
|
protected function sqlFloor(string $s): string {
|
|
return "CAST(($s) AS INT)";
|
|
}
|
|
|
|
/**
|
|
* @return array<int,int>
|
|
*/
|
|
protected function calculateEntryRepartitionPerFeedPerPeriod(string $period, ?int $feed = null): array {
|
|
if ($feed) {
|
|
$restrict = "WHERE e.id_feed = {$feed}";
|
|
} else {
|
|
$restrict = '';
|
|
}
|
|
$sql = <<<SQL
|
|
SELECT strftime('{$period}', e.date, 'unixepoch') AS period
|
|
, COUNT(1) AS count
|
|
FROM `_entry` AS e
|
|
{$restrict}
|
|
GROUP BY period
|
|
ORDER BY period ASC
|
|
SQL;
|
|
|
|
$stm = $this->pdo->query($sql);
|
|
if ($stm === false) {
|
|
return [];
|
|
}
|
|
$res = $stm->fetchAll(PDO::FETCH_NAMED);
|
|
|
|
switch ($period) {
|
|
case '%H':
|
|
$periodMax = 24;
|
|
break;
|
|
case '%w':
|
|
$periodMax = 7;
|
|
break;
|
|
case '%m':
|
|
$periodMax = 12;
|
|
break;
|
|
default:
|
|
$periodMax = 30;
|
|
}
|
|
|
|
$repartition = array_fill(0, $periodMax, 0);
|
|
foreach ($res as $value) {
|
|
$repartition[(int) $value['period']] = (int) $value['count'];
|
|
}
|
|
|
|
return $repartition;
|
|
}
|
|
|
|
}
|