getContext(), [ $this->getModulePrefix(), $this->getModuleName(), $this->getModulePath(), AuthManager::ACTION_LOGIN, self::needsToken(), ] ); return $msgs; } public function execute() { $params = $this->extractRequestParams(); $this->requireAtLeastOneParameter( $params, 'continue', 'returnurl' ); if ( $params['returnurl'] !== null ) { $bits = wfParseUrl( $params['returnurl'] ); if ( !$bits || $bits['scheme'] === '' ) { $encParamName = $this->encodeParamName( 'returnurl' ); $this->dieWithError( [ 'apierror-badurl', $encParamName, wfEscapeWikiText( $params['returnurl'] ) ], "badurl_{$encParamName}" ); } } $helper = new ApiAuthManagerHelper( $this ); $manager = AuthManager::singleton(); // Make sure it's possible to log in if ( !$manager->canAuthenticateNow() ) { $this->getResult()->addValue( null, 'clientlogin', $helper->formatAuthenticationResponse( AuthenticationResponse::newFail( $this->msg( 'userlogin-cannot-' . AuthManager::ACTION_LOGIN ) ) ) ); $helper->logAuthenticationResult( 'login', 'userlogin-cannot-' . AuthManager::ACTION_LOGIN ); return; } // Perform the login step if ( $params['continue'] ) { $reqs = $helper->loadAuthenticationRequests( AuthManager::ACTION_LOGIN_CONTINUE ); $res = $manager->continueAuthentication( $reqs ); } else { $reqs = $helper->loadAuthenticationRequests( AuthManager::ACTION_LOGIN ); if ( $params['preservestate'] ) { $req = $helper->getPreservedRequest(); if ( $req ) { $reqs[] = $req; } } $res = $manager->beginAuthentication( $reqs, $params['returnurl'] ); } // Remove CreateFromLoginAuthenticationRequest from $res->neededRequests. // It's there so a RESTART treated as UI will work right, but showing // it to the API client is just confusing. $res->neededRequests = ApiAuthManagerHelper::blacklistAuthenticationRequests( $res->neededRequests, [ CreateFromLoginAuthenticationRequest::class ] ); $this->getResult()->addValue( null, 'clientlogin', $helper->formatAuthenticationResponse( $res ) ); $helper->logAuthenticationResult( 'login', $res ); } public function isReadMode() { return false; } public function needsToken() { return 'login'; } public function getAllowedParams() { return ApiAuthManagerHelper::getStandardParams( AuthManager::ACTION_LOGIN, 'requests', 'messageformat', 'mergerequestfields', 'preservestate', 'returnurl', 'continue' ); } public function dynamicParameterDocumentation() { return [ 'api-help-authmanagerhelper-additional-params', AuthManager::ACTION_LOGIN ]; } protected function getExamplesMessages() { return [ 'action=clientlogin&username=Example&password=ExamplePassword&' . 'loginreturnurl=http://example.org/&logintoken=123ABC' => 'apihelp-clientlogin-example-login', 'action=clientlogin&logincontinue=1&OATHToken=987654&logintoken=123ABC' => 'apihelp-clientlogin-example-login2', ]; } public function getHelpUrls() { return 'https://www.mediawiki.org/wiki/Special:MyLanguage/API:Login'; } }