X-Git-Url: http://git.cyclocoop.org/%7B%24www_url%7Dadmin/password.php?a=blobdiff_plain;f=api.php;h=e031dfac7e292ac0df22504c8c0a5d58fd57e534;hb=726760153c557cfd2aea8bbeb3256f2c726d4847;hp=1a443317b60ec78dd2e1634e96075112d37b536b;hpb=1fee715ceab01292a44dd1ff140721dad9c5efb2;p=lhc%2Fweb%2Fwiklou.git diff --git a/api.php b/api.php index 1a443317b6..e031dfac7e 100644 --- a/api.php +++ b/api.php @@ -1,25 +1,27 @@ @gmail.com -* -* 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., -* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -* http://www.gnu.org/copyleft/gpl.html -*/ +/** + * API for MediaWiki 1.8+ + * + * Copyright (C) 2006 Yuri Astrakhan @gmail.com + * + * 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., + * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * http://www.gnu.org/copyleft/gpl.html + * + * @file + */ /** * This file is the entry point for all API queries. It begins by checking @@ -49,10 +51,10 @@ wfProfileIn('api.php'); // // Ensure that all access is through the canonical entry point... // -if( isset( $_SERVER['SCRIPT_URL'] ) ) { - $url = $_SERVER['SCRIPT_URL']; +if( isset( $_SERVER['SCRIPT_NAME'] ) ) { + $url = $_SERVER['SCRIPT_NAME']; } else { - $url = $_SERVER['PHP_SELF']; + $url = $_SERVER['URL']; } if( strcmp( "$wgScriptPath/api$wgScriptExtension", $url ) ) { wfHttpError( 403, 'Forbidden', @@ -64,9 +66,16 @@ if( strcmp( "$wgScriptPath/api$wgScriptExtension", $url ) ) { if (!$wgEnableAPI) { echo 'MediaWiki API is not enabled for this site. Add the following line to your LocalSettings.php'; echo '
$wgEnableAPI=true;
'; - die(-1); + die(1); } +// So extensions can check whether they're running in API mode +define('MW_API', true); + +// Set a dummy $wgTitle, because $wgTitle == null breaks various things +// In a perfect world this wouldn't be necessary +$wgTitle = Title::newFromText('API'); + /* Construct an ApiMain with the arguments passed via the URL. What we get back * is some form of an ApiMain, possibly even one that produces an error message, * but we don't care here, as that is handled by the ctor. @@ -77,11 +86,12 @@ $processor = new ApiMain($wgRequest, $wgEnableWriteAPI); $processor->execute(); // Execute any deferred updates -$mediawiki = new MediaWiki(); -$mediawiki->doUpdates($wgDeferredUpdateList); -$mediawiki->doUpdates($wgPostCommitUpdateList); +wfDoUpdates(); // Log what the user did, for book-keeping purposes. wfProfileOut('api.php'); wfLogProfilingData(); +// Shut down the database +wfGetLBFactory()->shutdown(); +