diff options
author | diosmosis <benaka@piwik.pro> | 2015-03-29 22:38:15 +0300 |
---|---|---|
committer | diosmosis <benaka@piwik.pro> | 2015-04-01 04:37:28 +0300 |
commit | b70727fb720098a63272870025879e7e395512dd (patch) | |
tree | 1e6a57ce496ea7182fbb897f95b391118ca9933a /plugins/CoreAdminHome/Tasks.php | |
parent | f595087622b06707a67d761e07cf0147f0ace6b5 (diff) |
Refs #7181, add logging to ArchivePurger service + archive purging scheduled tasks + Scheduler, modify CronArchive to run scheduled tasks within same process as core:archive so logs are visible in core:archive output.
Diffstat (limited to 'plugins/CoreAdminHome/Tasks.php')
-rw-r--r-- | plugins/CoreAdminHome/Tasks.php | 41 |
1 files changed, 24 insertions, 17 deletions
diff --git a/plugins/CoreAdminHome/Tasks.php b/plugins/CoreAdminHome/Tasks.php index 700c7d69c2..7a3ff406b5 100644 --- a/plugins/CoreAdminHome/Tasks.php +++ b/plugins/CoreAdminHome/Tasks.php @@ -14,9 +14,8 @@ use Piwik\Container\StaticContainer; use Piwik\DataAccess\ArchiveTableCreator; use Piwik\Date; use Piwik\Db; -use Piwik\Log; use Piwik\Plugins\CoreAdminHome\Tasks\ArchivesToPurgeDistributedList; -use Piwik\SettingsServer; +use Psr\Log\LoggerInterface; class Tasks extends \Piwik\Plugin\Tasks { @@ -25,9 +24,15 @@ class Tasks extends \Piwik\Plugin\Tasks */ private $archivePurger; - public function __construct(ArchivePurger $archivePurger = null) + /** + * @var LoggerInterface + */ + private $logger; + + public function __construct(ArchivePurger $archivePurger, LoggerInterface $logger) { - $this->archivePurger = $archivePurger ?: new ArchivePurger(); + $this->archivePurger = $archivePurger; + $this->logger = $logger; } public function schedule() @@ -44,16 +49,14 @@ class Tasks extends \Piwik\Plugin\Tasks public function purgeOutdatedArchives() { - $logger = StaticContainer::get('Psr\Log\LoggerInterface'); - if ($this->willPurgingCausePotentialProblemInUI()) { - $logger->info("Purging temporary archives: skipped (browser triggered archiving not enabled & not running after core:archive)"); + $this->logger->info("Purging temporary archives: skipped (browser triggered archiving not enabled & not running after core:archive)"); return false; } $archiveTables = ArchiveTableCreator::getTablesArchivesInstalled(); - $logger->info("Purging archives in {tableCount} archive tables.", array('tableCount' => count($archiveTables))); + $this->logger->info("Purging archives in {tableCount} archive tables.", array('tableCount' => count($archiveTables))); // keep track of dates we purge for, since getTablesArchivesInstalled() will return numeric & blob // tables (so dates will appear two times, and we should only purge once per date) @@ -64,15 +67,19 @@ class Tasks extends \Piwik\Plugin\Tasks list($year, $month) = explode('_', $date); // Somehow we may have archive tables created with older dates, prevent exception from being thrown - if ($year > 1990 - && empty($datesPurged[$date]) - ) { - $dateObj = Date::factory("$year-$month-15"); - - $this->archivePurger->purgeOutdatedArchives($dateObj); - $this->archivePurger->purgeArchivesWithPeriodRange($dateObj); - - $datesPurged[$date] = true; + if ($year > 1990) { + if (empty($datesPurged[$date])) { + $dateObj = Date::factory("$year-$month-15"); + + $this->archivePurger->purgeOutdatedArchives($dateObj); + $this->archivePurger->purgeArchivesWithPeriodRange($dateObj); + + $datesPurged[$date] = true; + } else { + $this->logger->debug("Date {date} already purged.", array('date' => $date)); + } + } else { + $this->logger->info("Skipping purging of archive tables *_{year}_{month}, year <= 1990.", array('year' => $year, 'month' => $month)); } } } |