X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2Fapi%2FApiMessage.php;h=6a8b7d0aed3905e63e31fdba61b34d11de023ff4;hb=ba26cf3bf9c87d4b3cecb21765277dc0bd1c1b23;hp=3347128757a2417050716626997235ac4d3f3d60;hpb=732b5e2745ca8f6153e19cc10c3c9acb1b2a6331;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/api/ApiMessage.php b/includes/api/ApiMessage.php index 3347128757..6a8b7d0aed 100644 --- a/includes/api/ApiMessage.php +++ b/includes/api/ApiMessage.php @@ -1,8 +1,5 @@ 'ratelimited', - 'autoblockedtext' => 'autoblocked', - 'badaccess-group0' => 'permissiondenied', - 'badaccess-groups' => 'permissiondenied', - 'badipaddress' => 'invalidip', - 'blankpage' => 'emptypage', - 'blockedtext' => 'blocked', - 'cannotdelete' => 'cantdelete', - 'cannotundelete' => 'cantundelete', - 'cantmove-titleprotected' => 'protectedtitle', - 'cantrollback' => 'onlyauthor', - 'confirmedittext' => 'confirmemail', - 'content-not-allowed-here' => 'contentnotallowedhere', - 'deleteprotected' => 'cantedit', - 'delete-toobig' => 'bigdelete', - 'edit-conflict' => 'editconflict', - 'imagenocrossnamespace' => 'nonfilenamespace', - 'imagetypemismatch' => 'filetypemismatch', - 'importbadinterwiki' => 'badinterwiki', - 'importcantopen' => 'cantopenfile', - 'import-noarticle' => 'badinterwiki', - 'importnofile' => 'nofile', - 'importuploaderrorpartial' => 'partialupload', - 'importuploaderrorsize' => 'filetoobig', - 'importuploaderrortemp' => 'notempdir', - 'ipb_already_blocked' => 'alreadyblocked', - 'ipb_blocked_as_range' => 'blockedasrange', - 'ipb_cant_unblock' => 'cantunblock', - 'ipb_expiry_invalid' => 'invalidexpiry', - 'ip_range_invalid' => 'invalidrange', - 'mailnologin' => 'cantsend', - 'markedaspatrollederror-noautopatrol' => 'noautopatrol', - 'movenologintext' => 'cantmove-anon', - 'movenotallowed' => 'cantmove', - 'movenotallowedfile' => 'cantmovefile', - 'namespaceprotected' => 'protectednamespace', - 'nocreate-loggedin' => 'cantcreate', - 'nocreatetext' => 'cantcreate-anon', - 'noname' => 'invaliduser', - 'nosuchusershort' => 'nosuchuser', - 'notanarticle' => 'missingtitle', - 'nouserspecified' => 'invaliduser', - 'ns-specialprotected' => 'unsupportednamespace', - 'protect-cantedit' => 'cantedit', - 'protectedinterface' => 'protectednamespace-interface', - 'protectedpagetext' => 'protectedpage', - 'range_block_disabled' => 'rangedisabled', - 'rcpatroldisabled' => 'patroldisabled', - 'readonlytext' => 'readonly', - 'sessionfailure' => 'badtoken', - 'systemblockedtext' => 'blocked', - 'titleprotected' => 'protectedtitle', - 'undo-failure' => 'undofailure', - 'userrights-nodatabase' => 'nosuchdatabase', - 'userrights-no-interwiki' => 'nointerwikiuserrights', - ]; - - protected $apiCode = null; - protected $apiData = []; - - public function getApiCode() { - if ( $this->apiCode === null ) { - $key = $this->getKey(); - if ( isset( self::$messageMap[$key] ) ) { - $this->apiCode = self::$messageMap[$key]; - } elseif ( $key === 'apierror-missingparam' ) { - /// @todo: Kill this case along with ApiBase::$messageMap - $this->apiCode = 'no' . $this->getParams()[0]; - } elseif ( substr( $key, 0, 8 ) === 'apiwarn-' ) { - $this->apiCode = substr( $key, 8 ); - } elseif ( substr( $key, 0, 9 ) === 'apierror-' ) { - $this->apiCode = substr( $key, 9 ); - } else { - $this->apiCode = $key; - } - } - return $this->apiCode; - } - - public function setApiCode( $code, array $data = null ) { - if ( $code !== null && !( is_string( $code ) && $code !== '' ) ) { - throw new InvalidArgumentException( "Invalid code \"$code\"" ); - } - - $this->apiCode = $code; - if ( $data !== null ) { - $this->setApiData( $data ); - } - } - - public function getApiData() { - return $this->apiData; - } - - public function setApiData( array $data ) { - $this->apiData = $data; - } - - public function serialize() { - return serialize( [ - 'parent' => parent::serialize(), - 'apiCode' => $this->apiCode, - 'apiData' => $this->apiData, - ] ); - } - - public function unserialize( $serialized ) { - $data = unserialize( $serialized ); - parent::unserialize( $data['parent'] ); - $this->apiCode = $data['apiCode']; - $this->apiData = $data['apiData']; - } -} - /** * Extension of Message implementing IApiMessage * @since 1.25 @@ -266,36 +87,3 @@ class ApiMessage extends Message implements IApiMessage { $this->setApiCode( $code, $data ); } } - -/** - * Extension of RawMessage implementing IApiMessage - * @since 1.25 - * @ingroup API - */ -class ApiRawMessage extends RawMessage implements IApiMessage { - use ApiMessageTrait; - - /** - * @param RawMessage|string|array $msg - * - RawMessage: is cloned - * - array: first element is $key, rest are $params to RawMessage::__construct - * - string: passed to RawMessage::__construct - * @param string|null $code - * @param array|null $data - */ - public function __construct( $msg, $code = null, array $data = null ) { - if ( $msg instanceof RawMessage ) { - foreach ( get_class_vars( get_class( $this ) ) as $key => $value ) { - if ( isset( $msg->$key ) ) { - $this->$key = $msg->$key; - } - } - } elseif ( is_array( $msg ) ) { - $key = array_shift( $msg ); - parent::__construct( $key, $msg ); - } else { - parent::__construct( $msg ); - } - $this->setApiCode( $code, $data ); - } -}