]> scripts.mit.edu Git - autoinstalls/mediawiki.git/blob - includes/WebStart.php
MediaWiki 1.30.2
[autoinstalls/mediawiki.git] / includes / WebStart.php
1 <?php
2 /**
3  * This does the initial set up for a web request.
4  *
5  * It does some security checks, loads autoloaders, constants, and
6  * global functions, starts the profiler, loads the configuration,
7  * and loads Setup.php, which loads extensions using the extension
8  * registration system and initializes the application's global state.
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License along
21  * with this program; if not, write to the Free Software Foundation, Inc.,
22  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
23  * http://www.gnu.org/copyleft/gpl.html
24  *
25  * @file
26  */
27
28 if ( ini_get( 'mbstring.func_overload' ) ) {
29         die( 'MediaWiki does not support installations where mbstring.func_overload is non-zero.' );
30 }
31
32 # T17461: Make IE8 turn off content sniffing. Everybody else should ignore this
33 # We're adding it here so that it's *always* set, even for alternate entry
34 # points and when $wgOut gets disabled or overridden.
35 header( 'X-Content-Type-Options: nosniff' );
36
37 /**
38  * @var float Request start time as fractional seconds since epoch
39  * @deprecated since 1.25; use $_SERVER['REQUEST_TIME_FLOAT'] or
40  *   WebRequest::getElapsedTime() instead.
41  */
42 $wgRequestTime = $_SERVER['REQUEST_TIME_FLOAT'];
43
44 unset( $IP );
45
46 # Valid web server entry point, enable includes.
47 # Please don't move this line to includes/Defines.php. This line essentially
48 # defines a valid entry point. If you put it in includes/Defines.php, then
49 # any script that includes it becomes an entry point, thereby defeating
50 # its purpose.
51 define( 'MEDIAWIKI', true );
52
53 # Full path to working directory.
54 # Makes it possible to for example to have effective exclude path in apc.
55 # __DIR__ breaks symlinked includes, but realpath() returns false
56 # if we don't have permissions on parent directories.
57 $IP = getenv( 'MW_INSTALL_PATH' );
58 if ( $IP === false ) {
59         $IP = realpath( '.' ) ?: dirname( __DIR__ );
60 }
61
62 require_once "$IP/includes/PreConfigSetup.php";
63
64 # Assert that composer dependencies were successfully loaded
65 # Purposely no leading \ due to it breaking HHVM RepoAuthorative mode
66 # PHP works fine with both versions
67 # See https://github.com/facebook/hhvm/issues/5833
68 if ( !interface_exists( 'Psr\Log\LoggerInterface' ) ) {
69         $message = (
70                 'MediaWiki requires the <a href="https://github.com/php-fig/log">PSR-3 logging ' .
71                 "library</a> to be present. This library is not embedded directly in MediaWiki's " .
72                 "git repository and must be installed separately by the end user.\n\n" .
73                 'Please see <a href="https://www.mediawiki.org/wiki/Download_from_Git' .
74                 '#Fetch_external_libraries">mediawiki.org</a> for help on installing ' .
75                 'the required components.'
76         );
77         echo $message;
78         trigger_error( $message, E_USER_ERROR );
79         die( 1 );
80 }
81
82 # Install a header callback
83 MediaWiki\HeaderCallback::register();
84
85 if ( defined( 'MW_CONFIG_CALLBACK' ) ) {
86         # Use a callback function to configure MediaWiki
87         call_user_func( MW_CONFIG_CALLBACK );
88 } else {
89         if ( !defined( 'MW_CONFIG_FILE' ) ) {
90                 define( 'MW_CONFIG_FILE', "$IP/LocalSettings.php" );
91         }
92
93         # LocalSettings.php is the per site customization file. If it does not exist
94         # the wiki installer needs to be launched or the generated file uploaded to
95         # the root wiki directory. Give a hint, if it is not readable by the server.
96         if ( !is_readable( MW_CONFIG_FILE ) ) {
97                 require_once "$IP/includes/NoLocalSettings.php";
98                 die();
99         }
100
101         # Include site settings. $IP may be changed (hopefully before the AutoLoader is invoked)
102         require_once MW_CONFIG_FILE;
103 }
104
105 # Initialise output buffering
106 # Check that there is no previous output or previously set up buffers, because
107 # that would cause us to potentially mix gzip and non-gzip output, creating a
108 # big mess.
109 if ( ob_get_level() == 0 ) {
110         require_once "$IP/includes/OutputHandler.php";
111         ob_start( 'wfOutputHandler' );
112 }
113
114 require_once "$IP/includes/Setup.php";
115
116 # Multiple DBs or commits might be used; keep the request as transactional as possible
117 if ( isset( $_SERVER['REQUEST_METHOD'] ) && $_SERVER['REQUEST_METHOD'] === 'POST' ) {
118         ignore_user_abort( true );
119 }
120
121 if ( !defined( 'MW_API' ) &&
122         RequestContext::getMain()->getRequest()->getHeader( 'Promise-Non-Write-API-Action' )
123 ) {
124         header( 'Cache-Control: no-cache' );
125         header( 'Content-Type: text/html; charset=utf-8' );
126         HttpStatus::header( 400 );
127         $error = wfMessage( 'nonwrite-api-promise-error' )->escaped();
128         $content = <<<EOT
129 <!DOCTYPE html>
130 <html>
131 <head><meta charset="UTF-8" /></head>
132 <body>
133 $error
134 </body>
135 </html>
136
137 EOT;
138         header( 'Content-Length: ' . strlen( $content ) );
139         echo $content;
140         die();
141 }