2013-10-24 18:58:23 -04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Bootstrap file for setting the ABSPATH constant
|
|
|
|
* and loading the wp-config.php file. The wp-config.php
|
|
|
|
* file will then load the wp-settings.php file, which
|
|
|
|
* will then set up the WordPress environment.
|
|
|
|
*
|
|
|
|
* If the wp-config.php file is not found then an error
|
|
|
|
* will be displayed asking the visitor to set up the
|
|
|
|
* wp-config.php file.
|
|
|
|
*
|
|
|
|
* Will also search for wp-config.php in WordPress' parent
|
|
|
|
* directory to allow the WordPress directory to remain
|
|
|
|
* untouched.
|
|
|
|
*
|
|
|
|
* @package WordPress
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** Define ABSPATH as this file's directory */
|
2016-04-14 13:53:28 -04:00
|
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
2020-02-06 01:33:11 -05:00
|
|
|
define( 'ABSPATH', __DIR__ . '/' );
|
2016-04-14 13:53:28 -04:00
|
|
|
}
|
2013-10-24 18:58:23 -04:00
|
|
|
|
2021-02-27 06:09:07 -05:00
|
|
|
/*
|
|
|
|
* The error_reporting() function can be disabled in php.ini. On systems where that is the case,
|
|
|
|
* it's best to add a dummy function to the wp-config.php file, but as this call to the function
|
|
|
|
* is run prior to wp-config.php loading, it is wrapped in a function_exists() check.
|
|
|
|
*/
|
|
|
|
if ( function_exists( 'error_reporting' ) ) {
|
2021-05-15 13:38:05 -04:00
|
|
|
/*
|
|
|
|
* Initialize error reporting to a known set of levels.
|
|
|
|
*
|
|
|
|
* This will be adapted in wp_debug_mode() located in wp-includes/load.php based on WP_DEBUG.
|
2023-02-18 09:23:21 -05:00
|
|
|
* @see https://www.php.net/manual/en/errorfunc.constants.php List of known error levels.
|
2021-05-15 13:38:05 -04:00
|
|
|
*/
|
2021-02-27 06:09:07 -05:00
|
|
|
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 );
|
|
|
|
}
|
2013-10-24 18:58:23 -04:00
|
|
|
|
2015-02-14 06:39:27 -05:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*/
|
2017-11-30 18:11:00 -05:00
|
|
|
if ( file_exists( ABSPATH . 'wp-config.php' ) ) {
|
2013-10-24 18:58:23 -04:00
|
|
|
|
|
|
|
/** The config file resides in ABSPATH */
|
2020-02-06 01:33:11 -05:00
|
|
|
require_once ABSPATH . 'wp-config.php';
|
2013-10-24 18:58:23 -04:00
|
|
|
|
2015-10-06 10:20:25 -04:00
|
|
|
} elseif ( @file_exists( dirname( ABSPATH ) . '/wp-config.php' ) && ! @file_exists( dirname( ABSPATH ) . '/wp-settings.php' ) ) {
|
2013-10-24 18:58:23 -04:00
|
|
|
|
2017-08-22 07:52:48 -04:00
|
|
|
/** The config file resides one level above ABSPATH but is not part of another installation */
|
2020-02-06 01:33:11 -05:00
|
|
|
require_once dirname( ABSPATH ) . '/wp-config.php';
|
2013-10-24 18:58:23 -04:00
|
|
|
|
|
|
|
} else {
|
|
|
|
|
2020-01-28 19:45:18 -05:00
|
|
|
// A config file doesn't exist.
|
2013-10-24 18:58:23 -04:00
|
|
|
|
|
|
|
define( 'WPINC', 'wp-includes' );
|
2020-02-06 01:33:11 -05:00
|
|
|
require_once ABSPATH . WPINC . '/load.php';
|
2013-10-24 18:58:23 -04:00
|
|
|
|
|
|
|
// Standardize $_SERVER variables across setups.
|
|
|
|
wp_fix_server_vars();
|
|
|
|
|
2020-02-06 01:33:11 -05:00
|
|
|
require_once ABSPATH . WPINC . '/functions.php';
|
2013-10-24 18:58:23 -04:00
|
|
|
|
|
|
|
$path = wp_guess_url() . '/wp-admin/setup-config.php';
|
|
|
|
|
Docs: Revise comments using “we” in WordPress root directory files.
This updates some inline comments to better match the guidelines and recommendations set forth in the make/core and make/docs handbooks:
> In general, use second person in your documentation. Second person depicts a friendly tone, with a perfect focus on the reader. In addition to this, directly addressing the reader helps avoid passive voice; thereby preventing unwanted confusion.
> ...
> the word “we” should be avoided (...) unless its made very clear which group is speaking.
Includes:
* Replacing first-person usage of "we" with second person point of view.
* Making small clarification adjustments where the voice is much too casual or lacks clear context, especially for non-native English speakers.
References:
* [https://make.wordpress.org/docs/style-guide/language-grammar/grammatical-person/ Style Guide: Grammatical person]
* [https://make.wordpress.org/docs/handbook/documentation-team-handbook/handbooks-style-and-formatting-guide/ Handbooks & HelpHub Style and Formatting Guide]
* [https://make.wordpress.org/core/handbook/best-practices/post-comment-guidelines/#style-and-substance Post & Comment Guidelines: Style and Substance]
Follow-up to [2176], [3430], [4676], [6009], [7991], [12688], [12762], [26008], [28978], [44488], [44962], [51979], [53131], [53132], [53156], [53131], [54200].
Props ironprogrammer, costdev, jorbin, SergeyBiryukov.
See #57052.
Built from https://develop.svn.wordpress.org/trunk@54866
git-svn-id: http://core.svn.wordpress.org/trunk@54418 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-11-23 10:43:13 -05:00
|
|
|
// Redirect to setup-config.php.
|
Code Modernization: Replace usage of `strpos()` with `str_contains()`.
`str_contains()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) contains the given substring (needle).
WordPress core includes a polyfill for `str_contains()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `false !== strpos( ... )` with `str_contains()` in core files, making the code more readable and consistent, as well as better aligned with modern development practices.
Follow-up to [52039], [52040], [52326], [55703], [55710], [55987].
Props Soean, spacedmonkey, costdev, dingo_d, azaozz, mikeschroder, flixos90, peterwilsoncc, SergeyBiryukov.
Fixes #58206.
Built from https://develop.svn.wordpress.org/trunk@55988
git-svn-id: http://core.svn.wordpress.org/trunk@55500 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-22 10:36:26 -04:00
|
|
|
if ( ! str_contains( $_SERVER['REQUEST_URI'], 'setup-config' ) ) {
|
2014-07-03 15:57:14 -04:00
|
|
|
header( 'Location: ' . $path );
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
define( 'WP_CONTENT_DIR', ABSPATH . 'wp-content' );
|
2020-02-06 01:33:11 -05:00
|
|
|
require_once ABSPATH . WPINC . '/version.php';
|
2014-07-03 15:57:14 -04:00
|
|
|
|
|
|
|
wp_check_php_mysql_versions();
|
|
|
|
wp_load_translations_early();
|
|
|
|
|
2021-01-10 14:28:08 -05:00
|
|
|
// Die with an error message.
|
|
|
|
$die = '<p>' . sprintf(
|
2015-11-05 18:59:26 -05:00
|
|
|
/* translators: %s: wp-config.php */
|
2022-09-19 04:59:11 -04:00
|
|
|
__( "There doesn't seem to be a %s file. It is needed before the installation can continue." ),
|
2015-11-05 18:59:26 -05:00
|
|
|
'<code>wp-config.php</code>'
|
|
|
|
) . '</p>';
|
|
|
|
$die .= '<p>' . sprintf(
|
2022-04-11 21:47:07 -04:00
|
|
|
/* translators: 1: Documentation URL, 2: wp-config.php */
|
|
|
|
__( 'Need more help? <a href="%1$s">Read the support article on %2$s</a>.' ),
|
2023-02-23 05:38:21 -05:00
|
|
|
__( 'https://wordpress.org/documentation/article/editing-wp-config-php/' ),
|
2022-04-11 21:47:07 -04:00
|
|
|
'<code>wp-config.php</code>'
|
2015-11-05 18:59:26 -05:00
|
|
|
) . '</p>';
|
|
|
|
$die .= '<p>' . 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." ),
|
|
|
|
'<code>wp-config.php</code>'
|
|
|
|
) . '</p>';
|
2021-01-10 14:28:08 -05:00
|
|
|
$die .= '<p><a href="' . $path . '" class="button button-large">' . __( 'Create a Configuration File' ) . '</a></p>';
|
2013-10-24 18:58:23 -04:00
|
|
|
|
|
|
|
wp_die( $die, __( 'WordPress › Error' ) );
|
|
|
|
}
|