X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/fa11948979fd6a4ea5705dc613b239699a459db3..073c5ed6408e2f00dc1863b463fe205467628905:/wp-load.php?ds=inline diff --git a/wp-load.php b/wp-load.php index fb859533..76dda74b 100644 --- a/wp-load.php +++ b/wp-load.php @@ -19,31 +19,36 @@ */ /** Define ABSPATH as this file's directory */ -define( 'ABSPATH', dirname(__FILE__) . '/' ); +if ( ! defined( 'ABSPATH' ) ) { + define( 'ABSPATH', dirname( __FILE__ ) . '/' ); +} error_reporting( E_CORE_ERROR | E_CORE_WARNING | E_COMPILE_ERROR | E_ERROR | E_WARNING | E_PARSE | E_USER_ERROR | E_USER_WARNING | E_RECOVERABLE_ERROR ); +/* + * If wp-config.php exists in the WordPress root, or if it exists in the root and wp-settings.php + * doesn't, load wp-config.php. The secondary check for wp-settings.php has the added benefit + * of avoiding cases where the current directory is a nested installation, e.g. / is WordPress(a) + * and /blog/ is WordPress(b). + * + * If neither set of conditions is true, initiate loading the setup process. + */ if ( file_exists( ABSPATH . 'wp-config.php') ) { /** The config file resides in ABSPATH */ require_once( ABSPATH . 'wp-config.php' ); -} elseif ( file_exists( dirname(ABSPATH) . '/wp-config.php' ) && ! file_exists( dirname(ABSPATH) . '/wp-settings.php' ) ) { +} elseif ( @file_exists( dirname( ABSPATH ) . '/wp-config.php' ) && ! @file_exists( dirname( ABSPATH ) . '/wp-settings.php' ) ) { /** The config file resides one level above ABSPATH but is not part of another install */ - require_once( dirname(ABSPATH) . '/wp-config.php' ); + require_once( dirname( ABSPATH ) . '/wp-config.php' ); } else { // A config file doesn't exist define( 'WPINC', 'wp-includes' ); - define( 'WP_CONTENT_DIR', ABSPATH . 'wp-content' ); require_once( ABSPATH . WPINC . '/load.php' ); - require_once( ABSPATH . WPINC . '/version.php' ); - - wp_check_php_mysql_versions(); - wp_load_translations_early(); // Standardize $_SERVER variables across setups. wp_fix_server_vars(); @@ -52,10 +57,38 @@ if ( file_exists( ABSPATH . 'wp-config.php') ) { $path = wp_guess_url() . '/wp-admin/setup-config.php'; + /* + * We're going to redirect to setup-config.php. While this shouldn't result + * in an infinite loop, that's a silly thing to assume, don't you think? If + * we're traveling in circles, our last-ditch effort is "Need more help?" + */ + if ( false === strpos( $_SERVER['REQUEST_URI'], 'setup-config' ) ) { + header( 'Location: ' . $path ); + exit; + } + + define( 'WP_CONTENT_DIR', ABSPATH . 'wp-content' ); + require_once( ABSPATH . WPINC . '/version.php' ); + + wp_check_php_mysql_versions(); + wp_load_translations_early(); + // Die with an error message - $die = __( "There doesn't seem to be a wp-config.php file. I need this before we can get started." ) . '

'; - $die .= '

' . __( "Need more help? We got it." ) . '

'; - $die .= '

' . __( "You can create a wp-config.php file through a web interface, but this doesn't work for all server setups. The safest way is to manually create the file." ) . '

'; + $die = sprintf( + /* translators: %s: wp-config.php */ + __( "There doesn't seem to be a %s file. I need this before we can get started." ), + 'wp-config.php' + ) . '

'; + $die .= '

' . sprintf( + /* translators: %s: Codex URL */ + __( "Need more help? We got it." ), + __( 'https://codex.wordpress.org/Editing_wp-config.php' ) + ) . '

'; + $die .= '

' . sprintf( + /* translators: %s: wp-config.php */ + __( "You can create a %s file through a web interface, but this doesn't work for all server setups. The safest way is to manually create the file." ), + 'wp-config.php' + ) . '

'; $die .= '

' . __( "Create a Configuration File" ) . ''; wp_die( $die, __( 'WordPress › Error' ) );