mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-02 19:52:44 +01:00
9c798e5cca
Summary: Fixes T9494. This: - Removes all the random GC.x.y.z config. - Puts it all in one place that's locked and which you use `bin/garbage set-policy ...` to adjust. - Makes every TTL-based GC configurable. - Simplifies the code in the actual GCs. Test Plan: - Ran `bin/garbage collect` to collect some garbage, until it stopped collecting. - Ran `bin/garbage set-policy ...` to shorten policy. Saw change in web UI. Ran `bin/garbage collect` again and saw it collect more garbage. - Set policy to indefinite and saw it not collect garabge. - Set policy to default and saw it reflected in web UI / `collect`. - Ran `bin/phd debug trigger` and saw all GCs fire with reasonable looking queries. - Read new docs. {F857928} Reviewers: chad Reviewed By: chad Maniphest Tasks: T9494 Differential Revision: https://secure.phabricator.com/D14219
30 lines
684 B
PHP
30 lines
684 B
PHP
<?php
|
|
|
|
final class ConduitLogGarbageCollector
|
|
extends PhabricatorGarbageCollector {
|
|
|
|
const COLLECTORCONST = 'conduit.logs';
|
|
|
|
public function getCollectorName() {
|
|
return pht('Conduit Logs');
|
|
}
|
|
|
|
public function getDefaultRetentionPolicy() {
|
|
return phutil_units('180 days in seconds');
|
|
}
|
|
|
|
protected function collectGarbage() {
|
|
$table = new PhabricatorConduitMethodCallLog();
|
|
$conn_w = $table->establishConnection('w');
|
|
|
|
queryfx(
|
|
$conn_w,
|
|
'DELETE FROM %T WHERE dateCreated < %d
|
|
ORDER BY dateCreated ASC LIMIT 100',
|
|
$table->getTableName(),
|
|
$this->getGarbageEpoch());
|
|
|
|
return ($conn_w->getAffectedRows() == 100);
|
|
}
|
|
|
|
}
|