mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/AbuseFilter.git
synced 2024-11-24 14:13:54 +00:00
9092ffab30
* Match $IP pattern verbatim from most other WMF extensions. * Lowercase "Address". * Change description to be more explicit. * Change printed lint to be shorter once it starts running. Change-Id: Iaa1b4683c5c856c752065797cf651ca7b1b46943
71 lines
1.6 KiB
PHP
71 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\AbuseFilter\Maintenance;
|
|
|
|
// @codeCoverageIgnoreStart
|
|
$IP = getenv( 'MW_INSTALL_PATH' );
|
|
if ( $IP === false ) {
|
|
$IP = __DIR__ . '/../../..';
|
|
}
|
|
require_once "$IP/maintenance/Maintenance.php";
|
|
// @codeCoverageIgnoreEnd
|
|
|
|
use Maintenance;
|
|
use MediaWiki\MediaWikiServices;
|
|
use MWTimestamp;
|
|
|
|
class PurgeOldLogIPData extends Maintenance {
|
|
public function __construct() {
|
|
parent::__construct();
|
|
$this->addDescription( 'Purge old IP address data from the abuse_filter_log table' );
|
|
$this->setBatchSize( 200 );
|
|
|
|
$this->requireExtension( 'Abuse Filter' );
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function execute() {
|
|
$this->output( "Purging old data from abuse_filter_log...\n" );
|
|
$dbw = wfGetDB( DB_PRIMARY );
|
|
$factory = MediaWikiServices::getInstance()->getDBLoadBalancerFactory();
|
|
$cutoffUnix = (int)MWTimestamp::now( TS_UNIX ) - $this->getConfig()->get( 'AbuseFilterLogIPMaxAge' );
|
|
|
|
$count = 0;
|
|
do {
|
|
$ids = $dbw->selectFieldValues(
|
|
'abuse_filter_log',
|
|
'afl_id',
|
|
[
|
|
'afl_ip <> ' . $dbw->addQuotes( '' ),
|
|
"afl_timestamp < " . $dbw->addQuotes( $dbw->timestamp( $cutoffUnix ) )
|
|
],
|
|
__METHOD__,
|
|
[ 'LIMIT' => $this->getBatchSize() ]
|
|
);
|
|
|
|
if ( $ids ) {
|
|
$dbw->update(
|
|
'abuse_filter_log',
|
|
[ 'afl_ip' => '' ],
|
|
[ 'afl_id' => $ids ],
|
|
__METHOD__
|
|
);
|
|
$count += $dbw->affectedRows();
|
|
$this->output( "$count\n" );
|
|
|
|
$factory->waitForReplication();
|
|
}
|
|
} while ( count( $ids ) >= $this->getBatchSize() );
|
|
|
|
$this->output( "$count rows.\n" );
|
|
|
|
$this->output( "Done.\n" );
|
|
}
|
|
|
|
}
|
|
|
|
$maintClass = PurgeOldLogIPData::class;
|
|
require_once RUN_MAINTENANCE_IF_MAIN;
|