mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/AbuseFilter.git
synced 2025-01-07 10:14:19 +00:00
a722dfe1a4
The old parser now has the correct name "Evaluator", so the ParserFactory name was outdated. Additionally, the plan is to create a new RuleChecker class, acting as a facade for the different parsing-related stages (lexer, parser, evaluator, etc.), which is what most if not all callers should use. The RuleCheckerFactory still returns a FilterEvaluator for now. Also, "Parser" is a specific term defining *how* things happen internally, whereas "RuleChecker" describes *what* callers should expect from the new class. Change-Id: I25b47a162d933c1e385175aae715ca38872b1442
162 lines
5 KiB
PHP
162 lines
5 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\AbuseFilter;
|
|
|
|
use BagOStuff;
|
|
use IBufferingStatsdDataFactory;
|
|
use MediaWiki\Config\ServiceOptions;
|
|
use MediaWiki\Extension\AbuseFilter\ChangeTags\ChangeTagger;
|
|
use MediaWiki\Extension\AbuseFilter\Consequences\ConsequencesExecutorFactory;
|
|
use MediaWiki\Extension\AbuseFilter\Hooks\AbuseFilterHookRunner;
|
|
use MediaWiki\Extension\AbuseFilter\Parser\RuleCheckerFactory;
|
|
use MediaWiki\Extension\AbuseFilter\VariableGenerator\VariableGeneratorFactory;
|
|
use MediaWiki\Extension\AbuseFilter\Variables\VariableHolder;
|
|
use MediaWiki\Extension\AbuseFilter\Variables\VariablesManager;
|
|
use MediaWiki\Extension\AbuseFilter\Watcher\EmergencyWatcher;
|
|
use MediaWiki\Extension\AbuseFilter\Watcher\UpdateHitCountWatcher;
|
|
use NullStatsdDataFactory;
|
|
use Psr\Log\LoggerInterface;
|
|
use Title;
|
|
use User;
|
|
|
|
class FilterRunnerFactory {
|
|
public const SERVICE_NAME = 'AbuseFilterRunnerFactory';
|
|
|
|
/** @var AbuseFilterHookRunner */
|
|
private $hookRunner;
|
|
/** @var FilterProfiler */
|
|
private $filterProfiler;
|
|
/** @var ChangeTagger */
|
|
private $changeTagger;
|
|
/** @var FilterLookup */
|
|
private $filterLookup;
|
|
/** @var RuleCheckerFactory */
|
|
private $ruleCheckerFactory;
|
|
/** @var ConsequencesExecutorFactory */
|
|
private $consExecutorFactory;
|
|
/** @var AbuseLoggerFactory */
|
|
private $abuseLoggerFactory;
|
|
/** @var VariablesManager */
|
|
private $varManager;
|
|
/** @var VariableGeneratorFactory */
|
|
private $varGeneratorFactory;
|
|
/** @var EmergencyCache */
|
|
private $emergencyCache;
|
|
/** @var UpdateHitCountWatcher */
|
|
private $updateHitCountWatcher;
|
|
/** @var EmergencyWatcher */
|
|
private $emergencyWatcher;
|
|
/** @var BagOStuff */
|
|
private $localCache;
|
|
/** @var LoggerInterface */
|
|
private $logger;
|
|
/** @var LoggerInterface */
|
|
private $editStashLogger;
|
|
/** @var IBufferingStatsdDataFactory */
|
|
private $statsdDataFactory;
|
|
/** @var ServiceOptions */
|
|
private $options;
|
|
|
|
/**
|
|
* @param AbuseFilterHookRunner $hookRunner
|
|
* @param FilterProfiler $filterProfiler
|
|
* @param ChangeTagger $changeTagger
|
|
* @param FilterLookup $filterLookup
|
|
* @param RuleCheckerFactory $ruleCheckerFactory
|
|
* @param ConsequencesExecutorFactory $consExecutorFactory
|
|
* @param AbuseLoggerFactory $abuseLoggerFactory
|
|
* @param VariablesManager $varManager
|
|
* @param VariableGeneratorFactory $varGeneratorFactory
|
|
* @param EmergencyCache $emergencyCache
|
|
* @param UpdateHitCountWatcher $updateHitCountWatcher
|
|
* @param EmergencyWatcher $emergencyWatcher
|
|
* @param BagOStuff $localCache
|
|
* @param LoggerInterface $logger
|
|
* @param LoggerInterface $editStashLogger
|
|
* @param IBufferingStatsdDataFactory $statsdDataFactory
|
|
* @param ServiceOptions $options
|
|
*/
|
|
public function __construct(
|
|
AbuseFilterHookRunner $hookRunner,
|
|
FilterProfiler $filterProfiler,
|
|
ChangeTagger $changeTagger,
|
|
FilterLookup $filterLookup,
|
|
RuleCheckerFactory $ruleCheckerFactory,
|
|
ConsequencesExecutorFactory $consExecutorFactory,
|
|
AbuseLoggerFactory $abuseLoggerFactory,
|
|
VariablesManager $varManager,
|
|
VariableGeneratorFactory $varGeneratorFactory,
|
|
EmergencyCache $emergencyCache,
|
|
UpdateHitCountWatcher $updateHitCountWatcher,
|
|
EmergencyWatcher $emergencyWatcher,
|
|
BagOStuff $localCache,
|
|
LoggerInterface $logger,
|
|
LoggerInterface $editStashLogger,
|
|
IBufferingStatsdDataFactory $statsdDataFactory,
|
|
ServiceOptions $options
|
|
) {
|
|
$this->hookRunner = $hookRunner;
|
|
$this->filterProfiler = $filterProfiler;
|
|
$this->changeTagger = $changeTagger;
|
|
$this->filterLookup = $filterLookup;
|
|
$this->ruleCheckerFactory = $ruleCheckerFactory;
|
|
$this->consExecutorFactory = $consExecutorFactory;
|
|
$this->abuseLoggerFactory = $abuseLoggerFactory;
|
|
$this->varManager = $varManager;
|
|
$this->varGeneratorFactory = $varGeneratorFactory;
|
|
$this->emergencyCache = $emergencyCache;
|
|
$this->updateHitCountWatcher = $updateHitCountWatcher;
|
|
$this->emergencyWatcher = $emergencyWatcher;
|
|
$this->localCache = $localCache;
|
|
$this->logger = $logger;
|
|
$this->editStashLogger = $editStashLogger;
|
|
$this->statsdDataFactory = $statsdDataFactory;
|
|
$this->options = $options;
|
|
}
|
|
|
|
/**
|
|
* @param User $user
|
|
* @param Title $title
|
|
* @param VariableHolder $vars
|
|
* @param string $group
|
|
* @return FilterRunner
|
|
*/
|
|
public function newRunner(
|
|
User $user,
|
|
Title $title,
|
|
VariableHolder $vars,
|
|
string $group
|
|
): FilterRunner {
|
|
// TODO Add a method to this class taking these as params? Add a hook for custom watchers
|
|
$watchers = [ $this->updateHitCountWatcher, $this->emergencyWatcher ];
|
|
return new FilterRunner(
|
|
$this->hookRunner,
|
|
$this->filterProfiler,
|
|
$this->changeTagger,
|
|
$this->filterLookup,
|
|
$this->ruleCheckerFactory,
|
|
$this->consExecutorFactory,
|
|
$this->abuseLoggerFactory,
|
|
$this->varManager,
|
|
$this->varGeneratorFactory,
|
|
$this->emergencyCache,
|
|
$watchers,
|
|
new EditStashCache(
|
|
$this->localCache,
|
|
// Bots do not use edit stashing, so avoid distorting the stats
|
|
$user->isBot() ? new NullStatsdDataFactory() : $this->statsdDataFactory,
|
|
$this->varManager,
|
|
$this->editStashLogger,
|
|
$title,
|
|
$group
|
|
),
|
|
$this->logger,
|
|
$this->options,
|
|
$user,
|
|
$title,
|
|
$vars,
|
|
$group
|
|
);
|
|
}
|
|
}
|