getUserOptionsManager(); $preferencesFactory ??= $services->getPreferencesFactory(); parent::__construct( $main, $action, $userOptionsManager, $preferencesFactory ); } protected function runHook( $user, $changes, $resetKinds ) { $this->getHookRunner()->onApiOptions( $this, $user, $changes, $resetKinds ); } protected function shouldIgnoreKey( $key ) { $user = $this->getUserForUpdates(); $manager = $this->getUserOptionsManager(); if ( $this->getGlobalParam() === 'ignore' && $manager->isOptionGlobal( $user, $key ) ) { $this->addWarning( $this->msg( 'apiwarn-global-option-ignored', $key ) ); return true; } return false; } protected function resetPreferences( array $kinds ) { $optionNames = $this->getPreferencesFactory()->getOptionNamesForReset( $this->getUserForUpdates(), $this->getContext(), $kinds ); $this->getUserOptionsManager()->resetOptionsByName( $this->getUserForUpdates(), $optionNames ); } protected function setPreference( $preference, $value ) { $globalUpdateType = [ 'ignore' => UserOptionsManager::GLOBAL_IGNORE, 'update' => UserOptionsManager::GLOBAL_UPDATE, 'override' => UserOptionsManager::GLOBAL_OVERRIDE ][ $this->getGlobalParam() ]; $this->getUserOptionsManager()->setOption( $this->getUserForUpdates(), $preference, $value, $globalUpdateType ); } private function getGlobalParam(): string { return $this->extractRequestParams()['global']; } protected function commitChanges() { $this->getUserForUpdates()->saveSettings(); } public function getHelpUrls() { return 'https://www.mediawiki.org/wiki/Special:MyLanguage/API:Options'; } protected function getExamplesMessages() { return [ 'action=options&reset=&token=123ABC' => 'apihelp-options-example-reset', 'action=options&change=skin=vector|hideminor=1&token=123ABC' => 'apihelp-options-example-change', 'action=options&reset=&change=skin=monobook&optionname=nickname&' . 'optionvalue=[[User:Beau|Beau]]%20([[User_talk:Beau|talk]])&token=123ABC' => 'apihelp-options-example-complex', ]; } public function getAllowedParams() { return parent::getAllowedParams() + [ 'global' => [ ParamValidator::PARAM_TYPE => [ 'ignore', 'update', 'override' ], ParamValidator::PARAM_DEFAULT => 'ignore' ] ]; } } /** @deprecated class alias since 1.43 */ class_alias( ApiOptions::class, 'ApiOptions' );