diff options
author | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-05-01 15:30:02 -0400 |
---|---|---|
committer | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-05-01 15:30:02 -0400 |
commit | 1de335ad3f395ca6861085393ba366a9e3fb4a0d (patch) | |
tree | f1fdd326034e05177596851be6a7127615d81498 /includes/api/ApiFormatPhp.php | |
parent | 9c75fa8ff6d4d38ef552c00fef5969fb154765e8 (diff) | |
parent | f6d65e533c62f6deb21342d4901ece24497b433e (diff) |
Merge commit 'f6d65'
# Conflicts:
# skins/ArchLinux/ArchLinux.php
Diffstat (limited to 'includes/api/ApiFormatPhp.php')
-rw-r--r-- | includes/api/ApiFormatPhp.php | 35 |
1 files changed, 32 insertions, 3 deletions
diff --git a/includes/api/ApiFormatPhp.php b/includes/api/ApiFormatPhp.php index 73ce80ef..d88dd40b 100644 --- a/includes/api/ApiFormatPhp.php +++ b/includes/api/ApiFormatPhp.php @@ -35,7 +35,29 @@ class ApiFormatPhp extends ApiFormatBase { } public function execute() { - $text = serialize( $this->getResultData() ); + $params = $this->extractRequestParams(); + + switch ( $params['formatversion'] ) { + case 1: + $transforms = array( + 'BC' => array(), + 'Types' => array(), + 'Strip' => 'all', + ); + break; + + case 2: + case 'latest': + $transforms = array( + 'Types' => array(), + 'Strip' => 'all', + ); + break; + + default: + $this->dieUsage( __METHOD__ . ': Unknown value for \'formatversion\'', 'unknownformatversion' ); + } + $text = serialize( $this->getResult()->getResultData( null, $transforms ) ); // Bug 66776: wfMangleFlashPolicy() is needed to avoid a nasty bug in // Flash, but what it does isn't friendly for the API. There's nothing @@ -54,7 +76,14 @@ class ApiFormatPhp extends ApiFormatBase { $this->printText( $text ); } - public function getDescription() { - return 'Output data in serialized PHP format' . parent::getDescription(); + public function getAllowedParams() { + $ret = array( + 'formatversion' => array( + ApiBase::PARAM_TYPE => array( 1, 2, 'latest' ), + ApiBase::PARAM_DFLT => 1, + ApiBase::PARAM_HELP_MSG => 'apihelp-php-param-formatversion', + ), + ); + return $ret; } } |