Fixed undefined defines warnings introduced in change 5131
[mediawiki.git] / includes / api / ApiComparePages.php
blob87f096785ff5c6c915ae6c5bb06a530a10ed32ca
1 <?php
2 /**
4 * Created on May 1, 2011
6 * Copyright © 2011 Sam Reed
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License along
19 * with this program; if not, write to the Free Software Foundation, Inc.,
20 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
21 * http://www.gnu.org/copyleft/gpl.html
23 * @file
26 class ApiComparePages extends ApiBase {
28 public function __construct( $main, $action ) {
29 parent::__construct( $main, $action );
32 public function execute() {
33 $params = $this->extractRequestParams();
35 $rev1 = $this->revisionOrTitleOrId( $params['fromrev'], $params['fromtitle'], $params['fromid'] );
36 $rev2 = $this->revisionOrTitleOrId( $params['torev'], $params['totitle'], $params['toid'] );
38 $de = new DifferenceEngine( $this->getContext(),
39 $rev1,
40 $rev2,
41 null, // rcid
42 true,
43 false );
45 $vals = array();
46 if ( isset( $params['fromtitle'] ) ) {
47 $vals['fromtitle'] = $params['fromtitle'];
49 if ( isset( $params['fromid'] ) ) {
50 $vals['fromid'] = $params['fromid'];
52 $vals['fromrevid'] = $rev1;
53 if ( isset( $params['totitle'] ) ) {
54 $vals['totitle'] = $params['totitle'];
56 if ( isset( $params['toid'] ) ) {
57 $vals['toid'] = $params['toid'];
59 $vals['torevid'] = $rev2;
61 $difftext = $de->getDiffBody();
63 if ( $difftext === false ) {
64 $this->dieUsage( 'The diff cannot be retrieved. ' .
65 'Maybe one or both revisions do not exist or you do not have permission to view them.', 'baddiff' );
66 } else {
67 ApiResult::setContent( $vals, $difftext );
70 $this->getResult()->addValue( null, $this->getModuleName(), $vals );
73 /**
74 * @param $revision int
75 * @param $titleText string
76 * @param $titleId int
77 * @return int
79 private function revisionOrTitleOrId( $revision, $titleText, $titleId ) {
80 if( $revision ){
81 return $revision;
82 } elseif( $titleText ) {
83 $title = Title::newFromText( $titleText );
84 if( !$title ){
85 $this->dieUsageMsg( array( 'invalidtitle', $titleText ) );
87 return $title->getLatestRevID();
88 } elseif ( $titleId ) {
89 $title = Title::newFromID( $titleId );
90 if( !$title ) {
91 $this->dieUsageMsg( array( 'nosuchpageid', $titleId ) );
93 return $title->getLatestRevID();
95 $this->dieUsage( 'inputneeded', 'A title, a page ID, or a revision number is needed for both the from and the to parameters' );
98 public function getAllowedParams() {
99 return array(
100 'fromtitle' => null,
101 'fromid' => array(
102 ApiBase::PARAM_TYPE => 'integer'
104 'fromrev' => array(
105 ApiBase::PARAM_TYPE => 'integer'
107 'totitle' => null,
108 'toid' => array(
109 ApiBase::PARAM_TYPE => 'integer'
111 'torev' => array(
112 ApiBase::PARAM_TYPE => 'integer'
117 public function getParamDescription() {
118 return array(
119 'fromtitle' => 'First title to compare',
120 'fromid' => 'First page ID to compare',
121 'fromrev' => 'First revision to compare',
122 'totitle' => 'Second title to compare',
123 'toid' => 'Second page ID to compare',
124 'torev' => 'Second revision to compare',
127 public function getDescription() {
128 return array(
129 'Get the difference between 2 pages',
130 'You must pass a revision number or a page title or a page ID id for each part (1 and 2)'
134 public function getPossibleErrors() {
135 return array_merge( parent::getPossibleErrors(), array(
136 array( 'code' => 'inputneeded', 'info' => 'A title or a revision is needed' ),
137 array( 'invalidtitle', 'title' ),
138 array( 'nosuchpageid', 'pageid' ),
139 array( 'code' => 'baddiff', 'info' => 'The diff cannot be retrieved. Maybe one or both revisions do not exist or you do not have permission to view them.' ),
140 ) );
143 public function getExamples() {
144 return array(
145 'api.php?action=compare&fromrev=1&torev=2' => 'Create a diff between revision 1 and 2',
149 public function getVersion() {
150 return __CLASS__ . ': $Id$';