mediawiki-extensions-AbuseF.../includes/Api/UnblockAutopromote.php
Umherirrender 6757ee9d32 Use type-declaration on api module constructor
Parent class constructor gets type-declaration in 1145328459
Remove simple doc-blocks without further information

Change-Id: I5d2179af0c7b826ca48df239152412205702cd77
2024-10-25 19:02:04 +02:00

100 lines
2.3 KiB
PHP

<?php
namespace MediaWiki\Extension\AbuseFilter\Api;
use MediaWiki\Api\ApiBase;
use MediaWiki\Api\ApiMain;
use MediaWiki\Extension\AbuseFilter\BlockAutopromoteStore;
use MediaWiki\ParamValidator\TypeDef\UserDef;
use Wikimedia\ParamValidator\ParamValidator;
class UnblockAutopromote extends ApiBase {
private BlockAutopromoteStore $afBlockAutopromoteStore;
public function __construct(
ApiMain $main,
string $action,
BlockAutopromoteStore $afBlockAutopromoteStore
) {
parent::__construct( $main, $action );
$this->afBlockAutopromoteStore = $afBlockAutopromoteStore;
}
/**
* @inheritDoc
*/
public function execute() {
$this->checkUserRightsAny( 'abusefilter-modify' );
$params = $this->extractRequestParams();
$target = $params['user'];
$block = $this->getAuthority()->getBlock();
if ( $block && $block->isSitewide() ) {
$this->dieBlocked( $block );
}
$msg = $this->msg( 'abusefilter-tools-restoreautopromote' )->inContentLanguage()->text();
$res = $this->afBlockAutopromoteStore->unblockAutopromote( $target, $this->getUser(), $msg );
if ( !$res ) {
$this->dieWithError( [ 'abusefilter-reautoconfirm-none', $target->getName() ], 'notsuspended' );
}
$finalResult = [ 'user' => $target->getName() ];
$this->getResult()->addValue( null, $this->getModuleName(), $finalResult );
}
/**
* @codeCoverageIgnore Merely declarative
* @inheritDoc
*/
public function mustBePosted() {
return true;
}
/**
* @codeCoverageIgnore Merely declarative
* @inheritDoc
*/
public function isWriteMode() {
return true;
}
/**
* @codeCoverageIgnore Merely declarative
* @inheritDoc
*/
public function getAllowedParams() {
return [
'user' => [
ParamValidator::PARAM_TYPE => 'user',
ParamValidator::PARAM_REQUIRED => true,
UserDef::PARAM_RETURN_OBJECT => true,
UserDef::PARAM_ALLOWED_USER_TYPES => [ 'name' ],
],
'token' => null,
];
}
/**
* @codeCoverageIgnore Merely declarative
* @inheritDoc
*/
public function needsToken() {
return 'csrf';
}
/**
* @codeCoverageIgnore Merely declarative
* @inheritDoc
*/
protected function getExamplesMessages() {
return [
'action=abusefilterunblockautopromote&user=Example&token=123ABC'
=> 'apihelp-abusefilterunblockautopromote-example-1',
];
}
}