mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/AbuseFilter.git
synced 2024-12-25 03:52:55 +00:00
52dcd4624f
The motivation is to have a single immutable object providing information about the action. It can represent the current action being filtered, but also a past action stored in the abuse log. It will hopefully help us get rid of passing User(Identity) and Title/LinkTarget objects around together. Change-Id: I52fa3a7ea14c98d33607d4260acfed3d3ba60f65
80 lines
1.5 KiB
PHP
80 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\AbuseFilter\Consequences;
|
|
|
|
use MediaWiki\Extension\AbuseFilter\ActionSpecifier;
|
|
use MediaWiki\Extension\AbuseFilter\Filter\ExistingFilter;
|
|
use MediaWiki\Linker\LinkTarget;
|
|
use MediaWiki\User\UserIdentity;
|
|
|
|
/**
|
|
* Immutable value object that provides "base" parameters to Consequence objects
|
|
*/
|
|
class Parameters {
|
|
/** @var ExistingFilter */
|
|
private $filter;
|
|
|
|
/** @var bool */
|
|
private $isGlobalFilter;
|
|
|
|
/** @var ActionSpecifier */
|
|
private $specifier;
|
|
|
|
/**
|
|
* @param ExistingFilter $filter
|
|
* @param bool $isGlobalFilter
|
|
* @param ActionSpecifier $specifier
|
|
*/
|
|
public function __construct(
|
|
ExistingFilter $filter,
|
|
bool $isGlobalFilter,
|
|
ActionSpecifier $specifier
|
|
) {
|
|
$this->filter = $filter;
|
|
$this->isGlobalFilter = $isGlobalFilter;
|
|
$this->specifier = $specifier;
|
|
}
|
|
|
|
/**
|
|
* @return ExistingFilter
|
|
*/
|
|
public function getFilter(): ExistingFilter {
|
|
return $this->filter;
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
public function getIsGlobalFilter(): bool {
|
|
return $this->isGlobalFilter;
|
|
}
|
|
|
|
/**
|
|
* @return ActionSpecifier
|
|
*/
|
|
public function getActionSpecifier(): ActionSpecifier {
|
|
return $this->specifier;
|
|
}
|
|
|
|
/**
|
|
* @return UserIdentity
|
|
*/
|
|
public function getUser(): UserIdentity {
|
|
return $this->specifier->getUser();
|
|
}
|
|
|
|
/**
|
|
* @return LinkTarget
|
|
*/
|
|
public function getTarget(): LinkTarget {
|
|
return $this->specifier->getTitle();
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function getAction(): string {
|
|
return $this->specifier->getAction();
|
|
}
|
|
}
|