50 $starttime = microtime(
true );
54 if ( isset( $_SERVER[
'PATH_INFO'] ) && $_SERVER[
'PATH_INFO'] !=
'' ) {
57 header(
"Location: $correctUrl",
true, 301 );
58 echo
'This endpoint does not support "path info", i.e. extra text between "api.php"'
59 .
'and the "?". Remove any such text and try again.';
65 $wgTitle = Title::makeTitle(
NS_SPECIAL,
'Badtitle/dummy title for API calls set in api.php' );
69 RequestContext::getMain()->setTitle(
$wgTitle );
75 $processor =
new ApiMain( RequestContext::getMain(),
true );
78 Hooks::runner()->onApiBeforeMain( $processor );
79 if ( !$processor instanceof
ApiMain ) {
80 throw new MWException(
'ApiBeforeMain hook set $processor to a non-ApiMain class' );
82 }
catch ( Throwable $e ) {
84 ApiMain::handleApiBeforeMainException( $e );
90 $processor->execute();
94 $endtime = microtime(
true );
100 $endtime - $starttime,
104 $items[] =
$wgRequest->wasPosted() ?
'POST' :
'GET';
107 $manager = $processor->getModuleManager();
108 $module = $manager->getModule(
$wgRequest->getRawVal(
'action' ),
'action' );
109 }
catch ( Throwable $ex ) {
112 if ( !$module || $module->mustBePosted() ) {
113 $items[] =
"action=" .
$wgRequest->getRawVal(
'action' );
118 $items[] =
"failed in ApiBeforeMain";
121 wfDebug(
"Logged API request to $wgAPIRequestLog" );
wfDebug( $text, $dest='all', array $context=[])
Sends a line to the debug log if enabled or, optionally, to a comment in output.
wfArrayToCgi( $array1, $array2=null, $prefix='')
This function takes one or two arrays as input, and returns a CGI-style string, e....
This is the main API class, used for both external and internal processing.