extractRequestParams(); $res = array(); foreach ( $params['type'] as $type ) { $type = strtolower( $type ); $func = 'get' . ucfirst( $type ) . 'Token'; if ( $type === 'patrol' ) { $val = call_user_func( array( 'ApiQueryRecentChanges', $func ), null, null ); } else { $val = call_user_func( array( 'ApiQueryInfo', $func ), null, null ); } if ( $val === false ) { $this->setWarning( "Action '$type' is not allowed for the current user" ); } else { $res[$type . 'token'] = $val; } } $this->getResult()->addValue( null, $this->getModuleName(), $res ); } public function getAllowedParams() { return array( 'type' => array( ApiBase::PARAM_DFLT => 'edit', ApiBase::PARAM_ISMULTI => true, ApiBase::PARAM_TYPE => array( 'edit', 'delete', 'protect', 'move', 'block', 'unblock', 'email', 'import', 'watch', 'patrol' ) ) ); } public function getParamDescription() { return array( 'type' => 'Type of token(s) to request' ); } public function getDescription() { return 'Gets tokens for data-modifying actions'; } protected function getExamples() { return array( 'api.php?action=tokens' => 'Retrieve an edit token (the default)', 'api.php?action=tokens&type=email|move' => 'Retrieve an email token and a move token' ); } public function getVersion() { return __CLASS__ . ': $Id$'; } }