mDescription = 'Purge old IP Address data from AbuseFilter logs'; $this->setBatchSize( 200 ); $this->requireExtension( 'Abuse Filter' ); } public function execute() { global $wgAbuseFilterLogIPMaxAge; $this->output( "Purging old IP Address data from abuse_filter_log...\n" ); $dbw = wfGetDB( DB_MASTER ); $cutoffUnix = time() - $wgAbuseFilterLogIPMaxAge; $count = 0; do { $ids = $dbw->selectFieldValues( 'abuse_filter_log', 'afl_id', [ 'afl_ip <> ""', "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" ); wfWaitForSlaves(); } } while ( count( $ids ) >= $this->getBatchSize() ); $this->output( "$count rows.\n" ); $this->output( "Done.\n" ); } } $maintClass = "PurgeOldLogIPData"; require_once RUN_MAINTENANCE_IF_MAIN;