X-Git-Url: http://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FWebStart.php;h=247f81008929eb7391f9381e5d665971251fb192;hb=31a551d947295b89026f8dd37819bb9b0b58b474;hp=bb2f2766cc605d5ef22731e9c604c5080fac1c86;hpb=938a8eb347d1f14a726729390adbaa3e65ba1bfa;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/WebStart.php b/includes/WebStart.php index bb2f2766cc..247f810089 100644 --- a/includes/WebStart.php +++ b/includes/WebStart.php @@ -5,27 +5,28 @@ * configuration, and optionally loads Setup.php depending on whether * MW_NO_SETUP is defined. * + * 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., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * http://www.gnu.org/copyleft/gpl.html + * * @file */ -/** - * Detect compiled mode by looking for a function that only exists if compiled - * in. Note that we can't use function_exists(), because it is terribly broken - * under HipHop due to the "volatile" feature. - */ -function wfDetectCompiledMode() { - try { - $r = new ReflectionFunction( 'wfHipHopCompilerVersion' ); - } catch ( ReflectionException $e ) { - $r = false; - } - return $r !== false; -} - # Protect against register_globals # This must be done before any globals are set by the code if ( ini_get( 'register_globals' ) ) { - if ( isset( $_REQUEST['GLOBALS'] ) ) { + if ( isset( $_REQUEST['GLOBALS'] ) || isset( $_FILES['GLOBALS'] ) ) { die( '$GLOBALS overwrite vulnerability'); } $verboten = array( @@ -56,6 +57,11 @@ if ( ini_get( 'register_globals' ) ) { } } +# bug 15461: Make IE8 turn off content sniffing. Everbody else should ignore this +# We're adding it here so that it's *always* set, even for alternate entry +# points and when $wgOut gets disabled or overridden. +header( 'X-Content-Type-Options: nosniff' ); + $wgRequestTime = microtime(true); # getrusage() does not exist on the Microsoft Windows platforms, catching this if ( function_exists ( 'getrusage' ) ) { @@ -75,33 +81,32 @@ define( 'MEDIAWIKI', true ); # Full path to working directory. # Makes it possible to for example to have effective exclude path in apc. # Also doesn't break installations using symlinked includes, like -# dirname( __FILE__ ) would do. +# __DIR__ would do. $IP = getenv( 'MW_INSTALL_PATH' ); if ( $IP === false ) { $IP = realpath( '.' ); } -if ( wfDetectCompiledMode() ) { +if ( isset( $_SERVER['MW_COMPILED'] ) ) { define( 'MW_COMPILED', 1 ); -} - -if ( !defined( 'MW_COMPILED' ) ) { +} else { # Get MWInit class require_once( "$IP/includes/Init.php" ); - # Start profiler - # FIXME: rewrite wfProfileIn/wfProfileOut so that they can work in compiled mode - if ( file_exists( "$IP/StartProfiler.php" ) ) { - require_once( "$IP/StartProfiler.php" ); - } else { - require_once( "$IP/includes/ProfilerStub.php" ); - } + # Start the autoloader, so that extensions can derive classes from core files + require_once( "$IP/includes/AutoLoader.php" ); + + # Load the profiler + require_once( "$IP/includes/profiler/Profiler.php" ); # Load up some global defines. require_once( "$IP/includes/Defines.php" ); +} - # Start the autoloader, so that extensions can derive classes from core files - require_once( "$IP/includes/AutoLoader.php" ); +# Start the profiler +$wgProfiler = array(); +if ( file_exists( "$IP/StartProfiler.php" ) ) { + require( "$IP/StartProfiler.php" ); } wfProfileIn( 'WebStart.php-conf' ); @@ -121,26 +126,8 @@ if ( defined( 'MW_CONFIG_CALLBACK' ) ) { # the wiki installer needs to be launched or the generated file uploaded to # the root wiki directory if( !file_exists( MW_CONFIG_FILE ) ) { - $script = $_SERVER['SCRIPT_NAME']; - $path = htmlspecialchars( str_replace( '//', '/', pathinfo( $script, PATHINFO_DIRNAME ) ) ); - $ext = htmlspecialchars( pathinfo( $script, PATHINFO_EXTENSION ) ); - - # Check to see if the installer is running - if ( !function_exists( 'session_name' ) ) { - $installerStarted = false; - } else { - session_name( 'mw_installer_session' ); - $oldReporting = error_reporting( E_ALL & ~E_NOTICE ); - $success = session_start(); - error_reporting( $oldReporting ); - $installerStarted = ( $success && isset( $_SESSION['installData'] ) ); - } - - $please = $installerStarted - ? "Please complete the installation and download LocalSettings.php." - : "Please set up the wiki first."; - - wfDie( "

LocalSettings.php not found.

$please

" ); + require_once( "$IP/includes/templates/NoLocalSettings.php" ); + die(); } # Include site settings. $IP may be changed (hopefully before the AutoLoader is invoked) @@ -169,4 +156,3 @@ wfProfileOut( 'WebStart.php-ob_start' ); if ( !defined( 'MW_NO_SETUP' ) ) { require_once( MWInit::compiledPath( "includes/Setup.php" ) ); } -