]> scripts.mit.edu Git - autoinstalls/mediawiki.git/blob - includes/api/ApiFormatJson.php
MediaWiki 1.30.2-scripts2
[autoinstalls/mediawiki.git] / includes / api / ApiFormatJson.php
1 <?php
2 /**
3  *
4  *
5  * Created on Sep 19, 2006
6  *
7  * Copyright © 2006 Yuri Astrakhan "<Firstname><Lastname>@gmail.com"
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License along
20  * with this program; if not, write to the Free Software Foundation, Inc.,
21  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
22  * http://www.gnu.org/copyleft/gpl.html
23  *
24  * @file
25  */
26
27 /**
28  * API JSON output formatter
29  * @ingroup API
30  */
31 class ApiFormatJson extends ApiFormatBase {
32
33         private $isRaw;
34
35         public function __construct( ApiMain $main, $format ) {
36                 parent::__construct( $main, $format );
37                 $this->isRaw = ( $format === 'rawfm' );
38
39                 if ( $this->getMain()->getCheck( 'callback' ) ) {
40                         # T94015: jQuery appends a useless '_' parameter in jsonp mode.
41                         # Mark the parameter as used in that case to avoid a warning that's
42                         # outside the control of the end user.
43                         # (and do it here because ApiMain::reportUnusedParams() gets called
44                         # before our ::execute())
45                         $this->getMain()->markParamsUsed( '_' );
46                 }
47         }
48
49         public function getMimeType() {
50                 $params = $this->extractRequestParams();
51                 // callback:
52                 if ( isset( $params['callback'] ) ) {
53                         return 'text/javascript';
54                 }
55
56                 return 'application/json';
57         }
58
59         public function execute() {
60                 $params = $this->extractRequestParams();
61
62                 $opt = 0;
63                 if ( $this->isRaw ) {
64                         $opt |= FormatJson::ALL_OK;
65                         $transform = [];
66                 } else {
67                         switch ( $params['formatversion'] ) {
68                                 case 1:
69                                         $opt |= $params['utf8'] ? FormatJson::ALL_OK : FormatJson::XMLMETA_OK;
70                                         $transform = [
71                                                 'BC' => [],
72                                                 'Types' => [ 'AssocAsObject' => true ],
73                                                 'Strip' => 'all',
74                                         ];
75                                         break;
76
77                                 case 2:
78                                 case 'latest':
79                                         $opt |= $params['ascii'] ? FormatJson::XMLMETA_OK : FormatJson::ALL_OK;
80                                         $transform = [
81                                                 'Types' => [ 'AssocAsObject' => true ],
82                                                 'Strip' => 'all',
83                                         ];
84                                         break;
85
86                                 default:
87                                         // Should have been caught during parameter validation
88                                         $this->dieDebug( __METHOD__, 'Unknown value for \'formatversion\'' );
89                         }
90                 }
91                 $data = $this->getResult()->getResultData( null, $transform );
92                 $json = FormatJson::encode( $data, $this->getIsHtml(), $opt );
93
94                 // T68776: wfMangleFlashPolicy() is needed to avoid a nasty bug in
95                 // Flash, but what it does isn't friendly for the API, so we need to
96                 // work around it.
97                 if ( preg_match( '/\<\s*cross-domain-policy(?=\s|\>)/i', $json ) ) {
98                         $json = preg_replace(
99                                 '/\<(\s*cross-domain-policy(?=\s|\>))/i', '\\u003C$1', $json
100                         );
101                 }
102
103                 if ( isset( $params['callback'] ) ) {
104                         $callback = preg_replace( "/[^][.\\'\\\"_A-Za-z0-9]/", '', $params['callback'] );
105                         # Prepend a comment to try to avoid attacks against content
106                         # sniffers, such as T70187.
107                         $this->printText( "/**/$callback($json)" );
108                 } else {
109                         $this->printText( $json );
110                 }
111         }
112
113         public function getAllowedParams() {
114                 if ( $this->isRaw ) {
115                         return parent::getAllowedParams();
116                 }
117
118                 $ret = parent::getAllowedParams() + [
119                         'callback' => [
120                                 ApiBase::PARAM_HELP_MSG => 'apihelp-json-param-callback',
121                         ],
122                         'utf8' => [
123                                 ApiBase::PARAM_DFLT => false,
124                                 ApiBase::PARAM_HELP_MSG => 'apihelp-json-param-utf8',
125                         ],
126                         'ascii' => [
127                                 ApiBase::PARAM_DFLT => false,
128                                 ApiBase::PARAM_HELP_MSG => 'apihelp-json-param-ascii',
129                         ],
130                         'formatversion' => [
131                                 ApiBase::PARAM_TYPE => [ 1, 2, 'latest' ],
132                                 ApiBase::PARAM_DFLT => 1,
133                                 ApiBase::PARAM_HELP_MSG => 'apihelp-json-param-formatversion',
134                         ],
135                 ];
136                 return $ret;
137         }
138 }