mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/AbuseFilter.git
synced 2024-11-27 15:30:42 +00:00
d0e85abda1
Also use expression builder to avoid raw sql Bug: T312420 Change-Id: I981f7d8107b7c4401056266c58db4457ad759f9c
80 lines
2 KiB
PHP
80 lines
2 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\AbuseFilter\Maintenance;
|
|
|
|
use Maintenance;
|
|
|
|
// @codeCoverageIgnoreStart
|
|
$IP = getenv( 'MW_INSTALL_PATH' );
|
|
if ( $IP === false ) {
|
|
$IP = __DIR__ . '/../../..';
|
|
}
|
|
require_once "$IP/maintenance/Maintenance.php";
|
|
// @codeCoverageIgnoreEnd
|
|
|
|
class SearchFilters extends Maintenance {
|
|
public function __construct() {
|
|
parent::__construct();
|
|
$this->addDescription( 'Find all filters matching a regular expression pattern' );
|
|
$this->addOption( 'pattern', 'Regular expression pattern', true, true );
|
|
|
|
$this->requireExtension( 'Abuse Filter' );
|
|
}
|
|
|
|
/**
|
|
* @see Maintenance:execute()
|
|
*/
|
|
public function execute() {
|
|
global $wgConf, $wgDBtype;
|
|
|
|
if ( $wgDBtype !== 'mysql' ) {
|
|
// Code using exit() cannot be tested (T272241)
|
|
// @codeCoverageIgnoreStart
|
|
$this->fatalError( 'This maintenance script only works with MySQL databases' );
|
|
// @codeCoverageIgnoreEnd
|
|
}
|
|
|
|
$this->output( "wiki\tfilter\n" );
|
|
if ( $this->getOption( 'pattern' ) === '' ) {
|
|
// Code using exit() cannot be tested (T272241)
|
|
// @codeCoverageIgnoreStart
|
|
$this->fatalError( 'Pattern cannot be empty' );
|
|
// @codeCoverageIgnoreEnd
|
|
}
|
|
|
|
if ( count( $wgConf->wikis ) > 0 ) {
|
|
foreach ( $wgConf->wikis as $dbname ) {
|
|
$this->getMatchingFilters( $dbname );
|
|
}
|
|
} else {
|
|
$this->getMatchingFilters();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param string|false $dbname Name of database, or false if the wiki is not part of a wikifarm
|
|
*/
|
|
private function getMatchingFilters( $dbname = false ) {
|
|
$dbr = $this->getDB( DB_REPLICA, [], $dbname );
|
|
$pattern = $dbr->addQuotes( $this->getOption( 'pattern' ) );
|
|
|
|
if ( $dbr->tableExists( 'abuse_filter' ) ) {
|
|
$rows = $dbr->newSelectQueryBuilder()
|
|
->select( [ 'dbname' => 'DATABASE()', 'af_id' ] )
|
|
->from( 'abuse_filter' )
|
|
->where( [
|
|
"af_pattern RLIKE $pattern"
|
|
] )
|
|
->caller( __METHOD__ )
|
|
->fetchResultSet();
|
|
|
|
foreach ( $rows as $row ) {
|
|
$this->output( $row->dbname . "\t" . $row->af_id . "\n" );
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$maintClass = SearchFilters::class;
|
|
require_once RUN_MAINTENANCE_IF_MAIN;
|