blob: bc528f1fb71694757458f7ebb67088c4643b22b2 (
plain)
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
|
<?php
/**
* Piwik - free/libre analytics platform
*
* @link https://matomo.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*
*/
namespace Piwik\Updates;
use Piwik\DataAccess\ArchiveTableCreator;
use Piwik\Date;
use Piwik\Plugins\CoreAdminHome\Tasks\ArchivesToPurgeDistributedList;
use Piwik\Updater;
use Piwik\Updates as PiwikUpdates;
class Updates_3_13_5_rc1 extends PiwikUpdates
{
public function doUpdate(Updater $updater)
{
$this->addArchivesToPurge();
}
private function addArchivesToPurge()
{
$archivesToPurge = new ArchivesToPurgeDistributedList();
$startOfProblem = Date::factory('2020-01-01 00:00:00');
$archiveTables = ArchiveTableCreator::getTablesArchivesInstalled(ArchiveTableCreator::NUMERIC_TABLE);
foreach ($archiveTables as $table) {
$date = ArchiveTableCreator::getDateFromTableName($table);
list($year, $month) = explode('_', $date);
// only add if the table is for jan 2020 or above since tables w/ that date will be most affected
try {
$dateObj = Date::factory("$year-$month-01 00:00:00");
} catch (\Exception $ex) {
continue; // date is too old for some reason
}
if ($dateObj->isEarlier($startOfProblem)) {
continue;
}
$archivesToPurge->add("{$year}_{$month}");
}
}
}
|