1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
declare(strict_types=1);
namespace Piwik\Plugins\ArchivingMetrics;
use Piwik\Common;
use Piwik\Config;
use Piwik\Date;
use Piwik\Db;
class Tasks extends \Piwik\Plugin\Tasks
{
public const DEFAULT_RETENTION_DAYS = 180;
public function schedule()
{
$this->weekly('purgeOldMetrics');
$this->monthly('purgeMetricsForDeletedSites');
}
/**
* To test execute the following command:
* `./console core:run-scheduled-tasks --force "Piwik\Plugins\ArchivingMetrics\Tasks.purgeOldMetrics"`
*/
public function purgeOldMetrics()
{
$retentionDays = $this->getRetentionDays();
if ($retentionDays <= 0) {
return;
}
$cutoff = Date::now()->subDay($retentionDays)->getDatetime();
$table = Common::prefixTable('archiving_metrics');
Db::query("DELETE FROM {$table} WHERE ts_started < ?", [$cutoff]);
}
public function purgeMetricsForDeletedSites()
{
$siteTable = Common::prefixTable('site');
$table = Common::prefixTable('archiving_metrics');
Db::query("DELETE a FROM {$table} a LEFT JOIN {$siteTable} s ON a.idsite = s.idsite WHERE s.idsite IS NULL");
}
private function getRetentionDays(): int
{
$config = Config::getInstance();
$retentionDays = $config->ArchivingMetrics['retention_days'] ?? self::DEFAULT_RETENTION_DAYS;
return max(0, (int) $retentionDays);
}
}
|