Fix wp_guess_url() to work in every scenario I could find, allows us to use it to determine the correct path to the WordPress Site URL before installation for install.php and setup-config.php redirects. Fixes #24480 Fixes #16884
git-svn-id: https://develop.svn.wordpress.org/trunk@25396 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
285db00ed4
commit
cccac649d5
@ -55,6 +55,9 @@ wp_load_translations_early();
|
|||||||
// Turn register_globals off.
|
// Turn register_globals off.
|
||||||
wp_unregister_GLOBALS();
|
wp_unregister_GLOBALS();
|
||||||
|
|
||||||
|
// Standardize $_SERVER variables across setups.
|
||||||
|
wp_fix_server_vars();
|
||||||
|
|
||||||
require_once(ABSPATH . WPINC . '/compat.php');
|
require_once(ABSPATH . WPINC . '/compat.php');
|
||||||
require_once(ABSPATH . WPINC . '/class-wp-error.php');
|
require_once(ABSPATH . WPINC . '/class-wp-error.php');
|
||||||
require_once(ABSPATH . WPINC . '/formatting.php');
|
require_once(ABSPATH . WPINC . '/formatting.php');
|
||||||
@ -198,12 +201,11 @@ switch($step) {
|
|||||||
if ( ! $no_api ) {
|
if ( ! $no_api ) {
|
||||||
require_once( ABSPATH . WPINC . '/class-http.php' );
|
require_once( ABSPATH . WPINC . '/class-http.php' );
|
||||||
require_once( ABSPATH . WPINC . '/http.php' );
|
require_once( ABSPATH . WPINC . '/http.php' );
|
||||||
wp_fix_server_vars();
|
|
||||||
/**#@+
|
/**#@+
|
||||||
* @ignore
|
* @ignore
|
||||||
*/
|
*/
|
||||||
function get_bloginfo() {
|
function get_bloginfo() {
|
||||||
return ( ( is_ssl() ? 'https://' : 'http://' ) . $_SERVER['HTTP_HOST'] . str_replace( $_SERVER['PHP_SELF'], '/wp-admin/setup-config.php', '' ) );
|
return wp_guess_url();
|
||||||
}
|
}
|
||||||
/**#@-*/
|
/**#@-*/
|
||||||
$secret_keys = wp_remote_get( 'https://api.wordpress.org/secret-key/1.1/salt/' );
|
$secret_keys = wp_remote_get( 'https://api.wordpress.org/secret-key/1.1/salt/' );
|
||||||
|
@ -3231,8 +3231,31 @@ function wp_guess_url() {
|
|||||||
if ( defined('WP_SITEURL') && '' != WP_SITEURL ) {
|
if ( defined('WP_SITEURL') && '' != WP_SITEURL ) {
|
||||||
$url = WP_SITEURL;
|
$url = WP_SITEURL;
|
||||||
} else {
|
} else {
|
||||||
|
// The request is for the admin
|
||||||
|
if ( strpos( $_SERVER['REQUEST_URI'], 'wp-admin' ) !== false || strpos( $_SERVER['REQUEST_URI'], 'wp-login.php' ) !== false ) {
|
||||||
|
$path = preg_replace( '#/(wp-admin/.*|wp-login.php)#i', '', $_SERVER['REQUEST_URI'] );
|
||||||
|
|
||||||
|
// The request is for a file in ABSPATH
|
||||||
|
} elseif ( dirname( $_SERVER['SCRIPT_FILENAME'] ) . '/' == ABSPATH ) {
|
||||||
|
// Strip off any file/query params in the path
|
||||||
|
$path = preg_replace( '#/[^/]*$#i', '', $_SERVER['PHP_SELF'] );
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if ( false !== strpos( $_SERVER['SCRIPT_FILENAME'], ABSPATH ) ) {
|
||||||
|
// Request is hitting a file inside ABSPATH
|
||||||
|
$directory = str_replace( ABSPATH, '', dirname( $_SERVER['SCRIPT_FILENAME'] ) );
|
||||||
|
// Strip off the sub directory, and any file/query paramss
|
||||||
|
$path = preg_replace( '#/' . preg_quote( $directory, '#' ) . '/[^/]*$#i', '' , $_SERVER['REQUEST_URI'] );
|
||||||
|
} else {
|
||||||
|
// Request is hitting a file above ABSPATH
|
||||||
|
$subdirectory = str_replace( dirname( $_SERVER['SCRIPT_FILENAME'] ), '', ABSPATH );
|
||||||
|
// Strip off any file/query params from the path, appending the sub directory to the install
|
||||||
|
$path = preg_replace( '#/[^/]*$#i', '' , $_SERVER['REQUEST_URI'] ) . $subdirectory;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$schema = is_ssl() ? 'https://' : 'http://'; // set_url_scheme() is not defined yet
|
$schema = is_ssl() ? 'https://' : 'http://'; // set_url_scheme() is not defined yet
|
||||||
$url = preg_replace( '#/(wp-admin/.*|wp-login.php)#i', '', $schema . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'] );
|
$url = $schema . $_SERVER['HTTP_HOST'] . $path;
|
||||||
}
|
}
|
||||||
|
|
||||||
return rtrim($url, '/');
|
return rtrim($url, '/');
|
||||||
|
@ -445,12 +445,12 @@ function wp_not_installed() {
|
|||||||
if ( ! is_blog_installed() && ! defined( 'WP_INSTALLING' ) )
|
if ( ! is_blog_installed() && ! defined( 'WP_INSTALLING' ) )
|
||||||
wp_die( __( 'The site you have requested is not installed properly. Please contact the system administrator.' ) );
|
wp_die( __( 'The site you have requested is not installed properly. Please contact the system administrator.' ) );
|
||||||
} elseif ( ! is_blog_installed() && false === strpos( $_SERVER['PHP_SELF'], 'install.php' ) && !defined( 'WP_INSTALLING' ) ) {
|
} elseif ( ! is_blog_installed() && false === strpos( $_SERVER['PHP_SELF'], 'install.php' ) && !defined( 'WP_INSTALLING' ) ) {
|
||||||
|
|
||||||
$link = wp_guess_url() . '/wp-admin/install.php';
|
|
||||||
|
|
||||||
require( ABSPATH . WPINC . '/kses.php' );
|
require( ABSPATH . WPINC . '/kses.php' );
|
||||||
require( ABSPATH . WPINC . '/pluggable.php' );
|
require( ABSPATH . WPINC . '/pluggable.php' );
|
||||||
require( ABSPATH . WPINC . '/formatting.php' );
|
require( ABSPATH . WPINC . '/formatting.php' );
|
||||||
|
|
||||||
|
$link = wp_guess_url() . '/wp-admin/install.php';
|
||||||
|
|
||||||
wp_redirect( $link );
|
wp_redirect( $link );
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
@ -50,15 +50,7 @@ if ( file_exists( ABSPATH . 'wp-config.php') ) {
|
|||||||
|
|
||||||
require_once( ABSPATH . WPINC . '/functions.php' );
|
require_once( ABSPATH . WPINC . '/functions.php' );
|
||||||
|
|
||||||
// Set a path for the link to the installer
|
$path = wp_guess_url() . '/wp-admin/setup-config.php';
|
||||||
if ( strpos( $_SERVER['PHP_SELF'], 'wp-admin' ) !== false ) {
|
|
||||||
$path = 'setup-config.php';
|
|
||||||
} elseif ( file_exists( dirname( $_SERVER['SCRIPT_FILENAME'] ) . '/wp-admin/setup-config.php' ) ) {
|
|
||||||
$path = 'wp-admin/setup-config.php';
|
|
||||||
} else {
|
|
||||||
// WordPress files are in a sub directory, and the user is hitting the index.php in the parent directory
|
|
||||||
$path = str_replace( dirname( $_SERVER['SCRIPT_FILENAME'] ) . '/', '', dirname( __FILE__ ) . '/wp-admin/setup-config.php' );
|
|
||||||
}
|
|
||||||
|
|
||||||
// Die with an error message
|
// Die with an error message
|
||||||
$die = __( "There doesn't seem to be a <code>wp-config.php</code> file. I need this before we can get started." ) . '</p>';
|
$die = __( "There doesn't seem to be a <code>wp-config.php</code> file. I need this before we can get started." ) . '</p>';
|
||||||
|
Loading…
Reference in New Issue
Block a user