mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Echo
synced 2025-01-22 10:36:45 +00:00
73bd6e8ef1
Change-Id: I98c1d2f6b1aa04eb64cef299a6aca475658bdd74
161 lines
3.9 KiB
PHP
161 lines
3.9 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\Notifications\Api;
|
|
|
|
use ApiBase;
|
|
use ApiMain;
|
|
use MediaWiki\Cache\LinkBatchFactory;
|
|
use MediaWiki\Title\Title;
|
|
use MediaWiki\User\CentralId\CentralIdLookup;
|
|
use MediaWiki\User\Options\UserOptionsManager;
|
|
use Wikimedia\ParamValidator\ParamValidator;
|
|
|
|
class ApiEchoMute extends ApiBase {
|
|
|
|
/** @var CentralIdLookup */
|
|
private $centralIdLookup;
|
|
|
|
/** @var LinkBatchFactory */
|
|
private $linkBatchFactory;
|
|
|
|
/** @var UserOptionsManager */
|
|
private $userOptionsManager;
|
|
|
|
/** @var string[][] */
|
|
private const MUTE_LISTS = [
|
|
'user' => [
|
|
'pref' => 'echo-notifications-blacklist',
|
|
'type' => 'user',
|
|
],
|
|
'page-linked-title' => [
|
|
'pref' => 'echo-notifications-page-linked-title-muted-list',
|
|
'type' => 'title'
|
|
],
|
|
];
|
|
|
|
/**
|
|
* @param ApiMain $main
|
|
* @param string $action
|
|
* @param CentralIdLookup $centralIdLookup
|
|
* @param LinkBatchFactory $linkBatchFactory
|
|
* @param UserOptionsManager $userOptionsManager
|
|
*/
|
|
public function __construct(
|
|
ApiMain $main,
|
|
$action,
|
|
CentralIdLookup $centralIdLookup,
|
|
LinkBatchFactory $linkBatchFactory,
|
|
UserOptionsManager $userOptionsManager
|
|
) {
|
|
parent::__construct( $main, $action );
|
|
|
|
$this->centralIdLookup = $centralIdLookup;
|
|
$this->linkBatchFactory = $linkBatchFactory;
|
|
$this->userOptionsManager = $userOptionsManager;
|
|
}
|
|
|
|
public function execute() {
|
|
$user = $this->getUser();
|
|
if ( !$user || !$user->isRegistered() ) {
|
|
$this->dieWithError(
|
|
[ 'apierror-mustbeloggedin', $this->msg( 'action-editmyoptions' ) ],
|
|
'notloggedin'
|
|
);
|
|
}
|
|
|
|
$this->checkUserRightsAny( 'editmyoptions' );
|
|
|
|
$params = $this->extractRequestParams();
|
|
$mutelistInfo = self::MUTE_LISTS[ $params['type'] ];
|
|
$prefValue = $this->userOptionsManager->getOption( $user, $mutelistInfo['pref'] );
|
|
$ids = $this->parsePref( $prefValue );
|
|
$targetsToMute = $params['mute'] ?? [];
|
|
$targetsToUnmute = $params['unmute'] ?? [];
|
|
|
|
$changed = false;
|
|
$addIds = $this->lookupIds( $targetsToMute, $mutelistInfo['type'] );
|
|
foreach ( $addIds as $id ) {
|
|
if ( !in_array( $id, $ids ) ) {
|
|
$ids[] = $id;
|
|
$changed = true;
|
|
}
|
|
}
|
|
$removeIds = $this->lookupIds( $targetsToUnmute, $mutelistInfo['type'] );
|
|
foreach ( $removeIds as $id ) {
|
|
$index = array_search( $id, $ids );
|
|
if ( $index !== false ) {
|
|
array_splice( $ids, $index, 1 );
|
|
$changed = true;
|
|
}
|
|
}
|
|
|
|
if ( $changed ) {
|
|
$this->userOptionsManager->setOption(
|
|
$user,
|
|
$mutelistInfo['pref'],
|
|
$this->serializePref( $ids )
|
|
);
|
|
$this->userOptionsManager->saveOptions( $user );
|
|
}
|
|
|
|
$this->getResult()->addValue( null, $this->getModuleName(), 'success' );
|
|
}
|
|
|
|
private function lookupIds( $names, $type ) {
|
|
if ( $type === 'title' ) {
|
|
$linkBatch = $this->linkBatchFactory->newLinkBatch();
|
|
foreach ( $names as $name ) {
|
|
$linkBatch->addObj( Title::newFromText( $name ) );
|
|
}
|
|
$linkBatch->execute();
|
|
|
|
$ids = [];
|
|
foreach ( $names as $name ) {
|
|
$title = Title::newFromText( $name );
|
|
if ( $title instanceof Title && $title->getArticleID() > 0 ) {
|
|
$ids[] = $title->getArticleID();
|
|
}
|
|
}
|
|
return $ids;
|
|
} elseif ( $type === 'user' ) {
|
|
return $this->centralIdLookup->centralIdsFromNames( $names, CentralIdLookup::AUDIENCE_PUBLIC );
|
|
}
|
|
}
|
|
|
|
private function parsePref( $prefValue ) {
|
|
return preg_split( '/\n/', $prefValue, -1, PREG_SPLIT_NO_EMPTY );
|
|
}
|
|
|
|
private function serializePref( $ids ) {
|
|
return implode( "\n", $ids );
|
|
}
|
|
|
|
public function getAllowedParams( $flags = 0 ) {
|
|
return [
|
|
'type' => [
|
|
ParamValidator::PARAM_REQUIRED => true,
|
|
ParamValidator::PARAM_TYPE => array_keys( self::MUTE_LISTS ),
|
|
],
|
|
'mute' => [
|
|
ParamValidator::PARAM_ISMULTI => true,
|
|
],
|
|
'unmute' => [
|
|
ParamValidator::PARAM_ISMULTI => true,
|
|
]
|
|
];
|
|
}
|
|
|
|
public function needsToken() {
|
|
return 'csrf';
|
|
}
|
|
|
|
public function mustBePosted() {
|
|
return true;
|
|
}
|
|
|
|
public function isWriteMode() {
|
|
return true;
|
|
}
|
|
|
|
}
|