%PDF- %PDF-
Direktori : /www/varak.net/wiki.varak.net/includes/api/ |
Current File : /www/varak.net/wiki.varak.net/includes/api/IApiMessage.php |
<?php /** * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * http://www.gnu.org/copyleft/gpl.html * * @file */ /** * Interface for messages with machine-readable data for use by the API * * The idea is that it's a Message that has some extra data for the API to use when interpreting it * as an error (or, in the future, as a warning). Internals of MediaWiki often use messages (or * message keys, or Status objects containing messages) to pass information about errors to the user * (see e.g. Title::getUserPermissionsErrors()) and the API has to make do with that. * * @since 1.25 * @note This interface exists to work around PHP's inheritance, so ApiMessage * can extend Message and ApiRawMessage can extend RawMessage while still * allowing an instanceof check for a Message object including this * functionality. If for some reason you feel the need to implement this * interface on some other class, that class must also implement all the * public methods the Message class provides (not just those from * MessageSpecifier, which as written is fairly useless). * @ingroup API */ interface IApiMessage extends MessageSpecifier { /** * Returns a machine-readable code for use by the API * * If no code was specifically set, the message key is used as the code * after removing "apiwarn-" or "apierror-" prefixes and applying * backwards-compatibility mappings. * * @return string */ public function getApiCode(); /** * Returns additional machine-readable data about the error condition * @return array */ public function getApiData(); /** * Sets the machine-readable code for use by the API * @param string|null $code If null, uses the default (see self::getApiCode()) * @param array|null $data If non-null, passed to self::setApiData() */ public function setApiCode( $code, array $data = null ); /** * Sets additional machine-readable data about the error condition * @param array $data */ public function setApiData( array $data ); }