MediaWiki REL1_37
|
The MediaWiki class is the helper class for the index.php entry point. More...
Public Member Functions | |
__construct (IContextSource $context=null) | |
doPostOutputShutdown () | |
This function does work that can be done after the user gets the HTTP response so they don't block on it. | |
doPreOutputCommit (callable $postCommitWork=null) | |
getAction () | |
Returns the name of the action that will be executed. | |
getTitle () | |
Get the Title object that we'll be acting on, as specified in the WebRequest. | |
restInPeace () | |
Ends this task peacefully. | |
run () | |
Run the current MediaWiki instance; index.php just calls this. | |
Static Public Member Functions | |
static | emitBufferedStatsdData (IBufferingStatsdDataFactory $stats, Config $config) |
Send out any buffered statsd data according to sampling rules. | |
static | preOutputCommit (IContextSource $context, callable $postCommitWork=null) |
This function commits all DB and session changes as needed before the client can receive a response (in case DB commit fails) and thus also before the response can trigger a subsequent related request by the client. | |
Private Member Functions | |
initializeArticle () | |
Initialize the main Article object for "standard" actions (view, etc) Create an Article object for the page, following redirects if needed. | |
main () | |
Determine and send the response headers and body for this web request. | |
maybeDoHttpsRedirect () | |
If the stars are suitably aligned, do an HTTP->HTTPS redirect. | |
outputResponsePayload ( $content) | |
Print a response body to the current buffer (if there is one) or the server (otherwise) | |
parseTitle () | |
Parse the request to get the Title object. | |
performAction (Article $article, Title $requestTitle) | |
Perform one of the "standard" actions. | |
performRequest () | |
Performs the request. | |
schedulePostSendJobs () | |
If enabled, after everything specific to this request is done, occasionally run jobs. | |
setDBProfilingAgent () | |
Add a comment to future SQL queries for easy SHOW PROCESSLIST interpretation. | |
shouldDoHttpRedirect () | |
Check if an HTTP->HTTPS redirect should be done. | |
triggerAsyncJobs ( $n, LoggerInterface $runJobsLogger) | |
triggerSyncJobs ( $n) | |
tryNormaliseRedirect (Title $title) | |
Handle redirects for uncanonical title requests. | |
Static Private Member Functions | |
static | getUrlDomainDistance ( $url) |
Private Attributes | |
string | $action |
Cache what action this request is. | |
Config | $config |
IContextSource | $context |
int | $postSendStrategy |
Class DEFER_* constant; how non-blocking post-response tasks should run. | |
const | DEFER_CLI_MODE = 3 |
Do not try to make post-send updates async (e.g. | |
const | DEFER_FASTCGI_FINISH_REQUEST = 1 |
Call fastcgi_finish_request() to make post-send updates async. | |
const | DEFER_SET_LENGTH_AND_FLUSH = 2 |
Set Content-Length and call ob_end_flush()/flush() to make post-send updates async. | |
The MediaWiki class is the helper class for the index.php entry point.
Definition at line 36 of file MediaWiki.php.
MediaWiki::__construct | ( | IContextSource | $context = null | ) |
IContextSource | null | $context |
Definition at line 59 of file MediaWiki.php.
MediaWiki::doPostOutputShutdown | ( | ) |
This function does work that can be done after the user gets the HTTP response so they don't block on it.
This manages deferred updates, job insertion, final commit, and the logging of profiling data
Definition at line 822 of file MediaWiki.php.
MediaWiki::doPreOutputCommit | ( | callable | $postCommitWork = null | ) |
callable | null | $postCommitWork | [default: null] |
Definition at line 657 of file MediaWiki.php.
|
static |
Send out any buffered statsd data according to sampling rules.
IBufferingStatsdDataFactory | $stats | |
Config | $config |
ConfigException |
Definition at line 1163 of file MediaWiki.php.
References IBufferingStatsdDataFactory\clearData(), Config\get(), IBufferingStatsdDataFactory\getData(), and IBufferingStatsdDataFactory\hasData().
MediaWiki::getAction | ( | ) |
Returns the name of the action that will be executed.
Definition at line 174 of file MediaWiki.php.
MediaWiki::getTitle | ( | ) |
Get the Title object that we'll be acting on, as specified in the WebRequest.
Definition at line 158 of file MediaWiki.php.
References SpecialPage\getTitleFor(), and parseTitle().
|
staticprivate |
string | $url |
Definition at line 801 of file MediaWiki.php.
|
private |
|
private |
Determine and send the response headers and body for this web request.
Definition at line 867 of file MediaWiki.php.
References $cache, $title, $wgTitle, getTitle(), NS_SPECIAL, ErrorPageError\report(), ErrorPageError\STAGE_OUTPUT, and HTMLFileCache\useFileCache().
|
private |
If the stars are suitably aligned, do an HTTP->HTTPS redirect.
Note: Do this after $wgTitle is setup, otherwise the hooks run from isRegistered() will do all sorts of weird stuff.
Definition at line 1012 of file MediaWiki.php.
References $title, NS_MAIN, and wfDebugLog().
|
private |
Print a response body to the current buffer (if there is one) or the server (otherwise)
This method should be called after doPreOutputCommit() and before doPostOutputShutdown()
Any accompanying Content-Type header is assumed to have already been set
string | $content | Response content, usually from OutputPage::output() |
Definition at line 1053 of file MediaWiki.php.
|
private |
Parse the request to get the Title object.
MalformedTitleException | If a title has been provided by the user, but is invalid. |
Definition at line 78 of file MediaWiki.php.
References $title, MediaWiki\MediaWikiServices\getInstance(), SpecialPage\getTitleFor(), NS_FILE, and NS_MEDIA.
Referenced by getTitle().
Perform one of the "standard" actions.
Definition at line 498 of file MediaWiki.php.
References $t, $title, PROTO_INTERNAL, and wfExpandUrl().
|
private |
Performs the request.
MWException|PermissionsError|BadTitleError|HttpError |
Definition at line 194 of file MediaWiki.php.
References $title, $wgTitle, and SpecialPage\getTitleFor().
|
static |
This function commits all DB and session changes as needed before the client can receive a response (in case DB commit fails) and thus also before the response can trigger a subsequent related request by the client.
If there is a significant amount of content to flush, it can be done in $postCommitWork
IContextSource | $context | |
callable | null | $postCommitWork | [default: null] |
Definition at line 672 of file MediaWiki.php.
References IContextSource\getConfig(), IContextSource\getOutput(), IContextSource\getRequest(), IContextSource\getUser(), wfDebug(), and wfDebugLog().
MediaWiki::restInPeace | ( | ) |
Ends this task peacefully.
Definition at line 1124 of file MediaWiki.php.
References wfDebug(), and wfLogProfilingData().
MediaWiki::run | ( | ) |
Run the current MediaWiki instance; index.php just calls this.
Definition at line 560 of file MediaWiki.php.
References $cache, MWExceptionRenderer\getHTML(), HTMLFileCache\MODE_OUTAGE, print, and HTMLFileCache\useFileCache().
|
private |
If enabled, after everything specific to this request is done, occasionally run jobs.
Definition at line 605 of file MediaWiki.php.
References getTitle(), and wfReadOnly().
|
private |
Add a comment to future SQL queries for easy SHOW PROCESSLIST interpretation.
Definition at line 594 of file MediaWiki.php.
|
private |
Check if an HTTP->HTTPS redirect should be done.
It may still be aborted by a hook, so this is not the final word.
Definition at line 968 of file MediaWiki.php.
References PROTO_HTTPS, and wfExpandUrl().
|
private |
int | $n | Number of jobs to try to run |
LoggerInterface | $runJobsLogger |
Definition at line 1198 of file MediaWiki.php.
References SpecialRunJobs\getQuerySignature(), and wfParseUrl().
|
private |
int | $n | Number of jobs to try to run |
Definition at line 1186 of file MediaWiki.php.
|
private |
Handle redirects for uncanonical title requests.
Handles:
Behaviour:
Title | $title |
HttpError |
Definition at line 354 of file MediaWiki.php.
References $title, SpecialPage\getTitleFor(), PROTO_CURRENT, and wfExpandUrl().
|
private |
Cache what action this request is.
Definition at line 45 of file MediaWiki.php.
|
private |
Definition at line 42 of file MediaWiki.php.
|
private |
Definition at line 40 of file MediaWiki.php.
|
private |
Class DEFER_* constant; how non-blocking post-response tasks should run.
Definition at line 47 of file MediaWiki.php.
|
private |
Do not try to make post-send updates async (e.g.
for CLI mode)
Definition at line 54 of file MediaWiki.php.
|
private |
Call fastcgi_finish_request() to make post-send updates async.
Definition at line 50 of file MediaWiki.php.
|
private |
Set Content-Length and call ob_end_flush()/flush() to make post-send updates async.
Definition at line 52 of file MediaWiki.php.