2010-01-15 23:03:41 +01:00
< ? php
/**
* These functions are needed to load WordPress .
*
2011-06-29 18:50:07 +02:00
* @ internal This file must be parsable by PHP4 .
2011-06-29 18:46:46 +02:00
*
2010-01-15 23:03:41 +01:00
* @ package WordPress
*/
/**
* Turn register globals off .
*
* @ access private
* @ since 2.1 . 0
* @ return null Will return null if register_globals PHP directive was disabled
*/
function wp_unregister_GLOBALS () {
2010-01-19 18:27:03 +01:00
if ( ! ini_get ( 'register_globals' ) )
2010-01-15 23:03:41 +01:00
return ;
2010-01-19 18:27:03 +01:00
if ( isset ( $_REQUEST [ 'GLOBALS' ] ) )
2012-01-26 21:34:27 +01:00
die ( 'GLOBALS overwrite attempt detected' );
2010-01-15 23:03:41 +01:00
// Variables that shouldn't be unset
2010-03-06 06:53:20 +01:00
$no_unset = array ( 'GLOBALS' , '_GET' , '_POST' , '_COOKIE' , '_REQUEST' , '_SERVER' , '_ENV' , '_FILES' , 'table_prefix' );
2010-01-15 23:03:41 +01:00
2010-01-19 18:27:03 +01:00
$input = array_merge ( $_GET , $_POST , $_COOKIE , $_SERVER , $_ENV , $_FILES , isset ( $_SESSION ) && is_array ( $_SESSION ) ? $_SESSION : array () );
2010-01-15 23:03:41 +01:00
foreach ( $input as $k => $v )
2010-03-06 06:53:20 +01:00
if ( ! in_array ( $k , $no_unset ) && isset ( $GLOBALS [ $k ] ) ) {
$GLOBALS [ $k ] = null ;
2010-01-19 18:27:03 +01:00
unset ( $GLOBALS [ $k ] );
2010-01-15 23:03:41 +01:00
}
}
2010-01-19 18:27:03 +01:00
/**
* Fix $_SERVER variables for various setups .
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_fix_server_vars () {
global $PHP_SELF ;
2010-03-26 20:36:49 +01:00
2010-03-25 16:33:35 +01:00
$default_server_values = array (
'SERVER_SOFTWARE' => '' ,
'REQUEST_URI' => '' ,
);
$_SERVER = array_merge ( $default_server_values , $_SERVER );
2010-03-26 20:36:49 +01:00
2010-01-15 23:03:41 +01:00
// Fix for IIS when running with PHP ISAPI
if ( empty ( $_SERVER [ 'REQUEST_URI' ] ) || ( php_sapi_name () != 'cgi-fcgi' && preg_match ( '/^Microsoft-IIS\//' , $_SERVER [ 'SERVER_SOFTWARE' ] ) ) ) {
// IIS Mod-Rewrite
2010-01-19 18:27:03 +01:00
if ( isset ( $_SERVER [ 'HTTP_X_ORIGINAL_URL' ] ) ) {
2010-01-15 23:03:41 +01:00
$_SERVER [ 'REQUEST_URI' ] = $_SERVER [ 'HTTP_X_ORIGINAL_URL' ];
}
// IIS Isapi_Rewrite
2010-01-19 18:27:03 +01:00
else if ( isset ( $_SERVER [ 'HTTP_X_REWRITE_URL' ] ) ) {
2010-01-15 23:03:41 +01:00
$_SERVER [ 'REQUEST_URI' ] = $_SERVER [ 'HTTP_X_REWRITE_URL' ];
2010-03-06 06:57:24 +01:00
} else {
2010-01-15 23:03:41 +01:00
// Use ORIG_PATH_INFO if there is no PATH_INFO
2010-01-19 18:27:03 +01:00
if ( ! isset ( $_SERVER [ 'PATH_INFO' ] ) && isset ( $_SERVER [ 'ORIG_PATH_INFO' ] ) )
2010-01-15 23:03:41 +01:00
$_SERVER [ 'PATH_INFO' ] = $_SERVER [ 'ORIG_PATH_INFO' ];
// Some IIS + PHP configurations puts the script-name in the path-info (No need to append it twice)
2010-01-19 18:27:03 +01:00
if ( isset ( $_SERVER [ 'PATH_INFO' ] ) ) {
2010-01-15 23:03:41 +01:00
if ( $_SERVER [ 'PATH_INFO' ] == $_SERVER [ 'SCRIPT_NAME' ] )
$_SERVER [ 'REQUEST_URI' ] = $_SERVER [ 'PATH_INFO' ];
else
$_SERVER [ 'REQUEST_URI' ] = $_SERVER [ 'SCRIPT_NAME' ] . $_SERVER [ 'PATH_INFO' ];
}
// Append the query string if it exists and isn't null
2010-03-19 22:29:21 +01:00
if ( ! empty ( $_SERVER [ 'QUERY_STRING' ] ) ) {
2010-01-15 23:03:41 +01:00
$_SERVER [ 'REQUEST_URI' ] .= '?' . $_SERVER [ 'QUERY_STRING' ];
}
}
}
// Fix for PHP as CGI hosts that set SCRIPT_FILENAME to something ending in php.cgi for all requests
2010-01-19 18:27:03 +01:00
if ( isset ( $_SERVER [ 'SCRIPT_FILENAME' ] ) && ( strpos ( $_SERVER [ 'SCRIPT_FILENAME' ], 'php.cgi' ) == strlen ( $_SERVER [ 'SCRIPT_FILENAME' ] ) - 7 ) )
2010-01-15 23:03:41 +01:00
$_SERVER [ 'SCRIPT_FILENAME' ] = $_SERVER [ 'PATH_TRANSLATED' ];
// Fix for Dreamhost and other PHP as CGI hosts
2010-01-19 18:27:03 +01:00
if ( strpos ( $_SERVER [ 'SCRIPT_NAME' ], 'php.cgi' ) !== false )
unset ( $_SERVER [ 'PATH_INFO' ] );
2010-01-15 23:03:41 +01:00
// Fix empty PHP_SELF
$PHP_SELF = $_SERVER [ 'PHP_SELF' ];
2010-01-19 18:27:03 +01:00
if ( empty ( $PHP_SELF ) )
2010-03-06 06:57:24 +01:00
$_SERVER [ 'PHP_SELF' ] = $PHP_SELF = preg_replace ( '/(\?.*)?$/' , '' , $_SERVER [ " REQUEST_URI " ] );
2010-01-15 23:03:41 +01:00
}
2010-01-19 18:27:03 +01:00
/**
* Check for the required PHP version , and the MySQL extension or a database drop - in .
*
* Dies if requirements are not met .
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_check_php_mysql_versions () {
global $required_php_version , $wp_version ;
$php_version = phpversion ();
2012-01-26 21:34:27 +01:00
if ( version_compare ( $required_php_version , $php_version , '>' ) ) {
wp_load_translations_early ();
wp_die ( sprintf ( __ ( 'Your server is running PHP version %1$s but WordPress %2$s requires at least %3$s.' ), $php_version , $wp_version , $required_php_version ) );
}
2010-01-15 23:03:41 +01:00
2012-01-26 21:34:27 +01:00
if ( ! extension_loaded ( 'mysql' ) && ! file_exists ( WP_CONTENT_DIR . '/db.php' ) ) {
wp_load_translations_early ();
wp_die ( __ ( 'Your PHP installation appears to be missing the MySQL extension which is required by WordPress.' ) );
}
2010-01-15 23:03:41 +01:00
}
2010-02-19 00:41:50 +01:00
/**
* Don ' t load all of WordPress when handling a favicon . ico request .
* Instead , send the headers for a zero - length favicon and bail .
*
* @ since 3.0 . 0
*/
function wp_favicon_request () {
2010-03-06 06:57:24 +01:00
if ( '/favicon.ico' == $_SERVER [ 'REQUEST_URI' ] ) {
header ( 'Content-Type: image/vnd.microsoft.icon' );
header ( 'Content-Length: 0' );
exit ;
}
2010-02-19 00:41:50 +01:00
}
2010-01-19 18:27:03 +01:00
/**
* Dies with a maintenance message when conditions are met .
*
* Checks for a file in the WordPress root directory named " .maintenance " .
* This file will contain the variable $upgrading , set to the time the file
* was created . If the file was created less than 10 minutes ago , WordPress
* enters maintenance mode and displays a message .
*
* The default message can be replaced by using a drop - in ( maintenance . php in
* the wp - content directory ) .
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_maintenance () {
2010-01-19 18:27:03 +01:00
if ( ! file_exists ( ABSPATH . '.maintenance' ) || defined ( 'WP_INSTALLING' ) )
return ;
2010-01-15 23:03:41 +01:00
2010-06-04 17:16:17 +02:00
global $upgrading ;
2010-01-19 18:27:03 +01:00
include ( ABSPATH . '.maintenance' );
// If the $upgrading timestamp is older than 10 minutes, don't die.
if ( ( time () - $upgrading ) >= 600 )
return ;
if ( file_exists ( WP_CONTENT_DIR . '/maintenance.php' ) ) {
require_once ( WP_CONTENT_DIR . '/maintenance.php' );
die ();
}
2012-01-26 21:34:27 +01:00
wp_load_translations_early ();
2010-01-19 18:27:03 +01:00
$protocol = $_SERVER [ " SERVER_PROTOCOL " ];
if ( 'HTTP/1.1' != $protocol && 'HTTP/1.0' != $protocol )
$protocol = 'HTTP/1.0' ;
header ( " $protocol 503 Service Unavailable " , true , 503 );
header ( 'Content-Type: text/html; charset=utf-8' );
header ( 'Retry-After: 600' );
?>
2011-07-22 02:25:41 +02:00
<! DOCTYPE html >
2012-02-08 07:05:35 +01:00
< html xmlns = " http://www.w3.org/1999/xhtml " < ? php if ( is_rtl () ) echo ' dir="rtl"' ; ?> >
2010-01-15 23:03:41 +01:00
< head >
< meta http - equiv = " Content-Type " content = " text/html; charset=utf-8 " />
2012-01-26 21:34:27 +01:00
< title >< ? php _e ( 'Maintenance' ); ?> </title>
2010-01-15 23:03:41 +01:00
</ head >
< body >
2012-01-26 21:34:27 +01:00
< h1 >< ? php _e ( 'Briefly unavailable for scheduled maintenance. Check back in a minute.' ); ?> </h1>
2010-01-15 23:03:41 +01:00
</ body >
</ html >
2010-01-19 18:27:03 +01:00
< ? php
die ();
2010-01-15 23:03:41 +01:00
}
/**
2011-12-20 22:36:53 +01:00
* PHP 5 standard microtime start capture .
2010-01-15 23:03:41 +01:00
*
* @ access private
* @ since 0.71
2011-12-20 22:36:53 +01:00
* @ global float $timestart Seconds from when function is called .
2010-01-15 23:03:41 +01:00
* @ return bool Always returns true .
*/
function timer_start () {
global $timestart ;
2011-12-20 22:36:53 +01:00
$timestart = microtime ( true );
2010-01-15 23:03:41 +01:00
return true ;
}
/**
* Return and / or display the time from the page start to when function is called .
*
* You can get the results and print them by doing :
* < code >
* $nTimePageTookToExecute = timer_stop ();
* echo $nTimePageTookToExecute ;
* </ code >
*
* Or instead , you can do :
* < code >
* timer_stop ( 1 );
* </ code >
* which will do what the above does . If you need the result , you can assign it to a variable , but
2011-09-30 00:57:43 +02:00
* in most cases , you only need to echo it .
2010-01-15 23:03:41 +01:00
*
* @ since 0.71
2011-12-20 22:36:53 +01:00
* @ global float $timestart Seconds from when timer_start () is called
* @ global float $timeend Seconds from when function is called
2010-01-15 23:03:41 +01:00
*
* @ param int $display Use '0' or null to not echo anything and 1 to echo the total time
* @ param int $precision The amount of digits from the right of the decimal to display . Default is 3.
* @ return float The " second.microsecond " finished time calculation
*/
2010-01-19 18:27:03 +01:00
function timer_stop ( $display = 0 , $precision = 3 ) { // if called like timer_stop(1), will echo $timetotal
2010-01-15 23:03:41 +01:00
global $timestart , $timeend ;
2011-12-20 22:36:53 +01:00
$timeend = microtime ( true );
2010-02-26 20:09:29 +01:00
$timetotal = $timeend - $timestart ;
2010-04-22 23:39:37 +02:00
$r = ( function_exists ( 'number_format_i18n' ) ) ? number_format_i18n ( $timetotal , $precision ) : number_format ( $timetotal , $precision );
2010-01-15 23:03:41 +01:00
if ( $display )
echo $r ;
return $r ;
}
2010-01-19 18:27:03 +01:00
/**
2010-02-17 14:14:45 +01:00
* Sets PHP error handling and handles WordPress debug mode .
2010-01-19 18:27:03 +01:00
*
2010-02-17 14:14:45 +01:00
* Uses three constants : WP_DEBUG , WP_DEBUG_DISPLAY , and WP_DEBUG_LOG . All three can be
* defined in wp - config . php . Example : < code > define ( 'WP_DEBUG' , true ); </ code >
2010-01-19 18:27:03 +01:00
*
2010-02-17 14:14:45 +01:00
* WP_DEBUG_DISPLAY and WP_DEBUG_LOG perform no function unless WP_DEBUG is true .
2010-02-26 06:46:08 +01:00
* WP_DEBUG defaults to false .
2010-01-19 18:27:03 +01:00
*
2010-02-17 14:14:45 +01:00
* When WP_DEBUG is true , all PHP notices are reported . WordPress will also display
* notices , including one when a deprecated WordPress function , function argument ,
* or file is used . Deprecated code may be removed from a later version .
*
2010-02-17 21:36:00 +01:00
* It is strongly recommended that plugin and theme developers use WP_DEBUG in their
2010-02-17 14:14:45 +01:00
* development environments .
*
* When WP_DEBUG_DISPLAY is true , WordPress will force errors to be displayed .
2011-08-13 20:59:05 +02:00
* WP_DEBUG_DISPLAY defaults to true . Defining it as null prevents WordPress from
* changing the global configuration setting . Defining WP_DEBUG_DISPLAY as false
* will force errors to be hidden .
2010-02-17 14:14:45 +01:00
*
* When WP_DEBUG_LOG is true , errors will be logged to wp - content / debug . log .
* WP_DEBUG_LOG defaults to false .
2010-01-19 18:27:03 +01:00
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_debug_mode () {
if ( WP_DEBUG ) {
2010-12-31 22:01:30 +01:00
// E_DEPRECATED is a core PHP constant in PHP 5.3. Don't define this yourself.
// The two statements are equivalent, just one is for 5.3+ and for less than 5.3.
2012-01-05 08:43:40 +01:00
if ( defined ( 'E_DEPRECATED' ) )
error_reporting ( E_ALL & ~ E_DEPRECATED & ~ E_STRICT );
else
error_reporting ( E_ALL );
2010-01-15 23:03:41 +01:00
if ( WP_DEBUG_DISPLAY )
2010-01-19 18:27:03 +01:00
ini_set ( 'display_errors' , 1 );
2011-08-13 20:59:05 +02:00
elseif ( null !== WP_DEBUG_DISPLAY )
ini_set ( 'display_errors' , 0 );
2010-01-15 23:03:41 +01:00
if ( WP_DEBUG_LOG ) {
2010-01-19 18:27:03 +01:00
ini_set ( 'log_errors' , 1 );
ini_set ( 'error_log' , WP_CONTENT_DIR . '/debug.log' );
2010-01-15 23:03:41 +01:00
}
} else {
2011-04-12 11:21:13 +02: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 );
2010-01-15 23:03:41 +01:00
}
}
2010-01-19 18:27:03 +01:00
/**
* Sets the location of the language directory .
*
* To set directory manually , define < code > WP_LANG_DIR </ code > in wp - config . php .
*
2011-09-30 00:57:43 +02:00
* If the language directory exists within WP_CONTENT_DIR , that is used .
* Otherwise if the language directory exists within WPINC , that ' s used .
* Finally , if neither of the preceding directories are found ,
2011-03-31 10:11:30 +02:00
* WP_CONTENT_DIR / languages is used .
2010-01-19 18:27:03 +01:00
*
* The WP_LANG_DIR constant was introduced in 2.1 . 0.
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_set_lang_dir () {
2010-01-19 18:27:03 +01:00
if ( ! defined ( 'WP_LANG_DIR' ) ) {
2011-03-31 10:11:30 +02:00
if ( file_exists ( WP_CONTENT_DIR . '/languages' ) && @ is_dir ( WP_CONTENT_DIR . '/languages' ) || !@ is_dir ( ABSPATH . WPINC . '/languages' ) ) {
2010-01-19 18:27:03 +01:00
define ( 'WP_LANG_DIR' , WP_CONTENT_DIR . '/languages' ); // no leading slash, no trailing slash, full path, not relative to ABSPATH
if ( ! defined ( 'LANGDIR' ) ) {
2010-01-15 23:03:41 +01:00
// Old static relative path maintained for limited backwards compatibility - won't work in some cases
2010-01-19 18:27:03 +01:00
define ( 'LANGDIR' , 'wp-content/languages' );
2010-01-15 23:03:41 +01:00
}
} else {
2010-01-19 18:27:03 +01:00
define ( 'WP_LANG_DIR' , ABSPATH . WPINC . '/languages' ); // no leading slash, no trailing slash, full path, not relative to ABSPATH
if ( ! defined ( 'LANGDIR' ) ) {
2010-01-15 23:03:41 +01:00
// Old relative path maintained for backwards compatibility
2010-01-19 18:27:03 +01:00
define ( 'LANGDIR' , WPINC . '/languages' );
2010-01-15 23:03:41 +01:00
}
}
}
}
2010-09-20 21:13:47 +02:00
/**
* Load the correct database class file .
*
* This function is used to load the database class file either at runtime or by
* wp - admin / setup - config . php . We must globalize $wpdb to ensure that it is
* defined globally by the inline code in wp - db . php .
*
* @ since 2.5 . 0
* @ global $wpdb WordPress Database Object
*/
function require_wp_db () {
global $wpdb ;
require_once ( ABSPATH . WPINC . '/wp-db.php' );
if ( file_exists ( WP_CONTENT_DIR . '/db.php' ) )
require_once ( WP_CONTENT_DIR . '/db.php' );
if ( isset ( $wpdb ) )
return ;
$wpdb = new wpdb ( DB_USER , DB_PASSWORD , DB_NAME , DB_HOST );
}
2010-01-19 18:27:03 +01:00
/**
* Sets the database table prefix and the format specifiers for database table columns .
*
* Columns not listed here default to % s .
*
* @ see wpdb :: $field_types Since 2.8 . 0
* @ see wpdb :: prepare ()
* @ see wpdb :: insert ()
* @ see wpdb :: update ()
* @ see wpdb :: set_prefix ()
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_set_wpdb_vars () {
global $wpdb , $table_prefix ;
2010-01-19 18:27:03 +01:00
if ( ! empty ( $wpdb -> error ) )
2010-01-15 23:03:41 +01:00
dead_db ();
$wpdb -> field_types = array ( 'post_author' => '%d' , 'post_parent' => '%d' , 'menu_order' => '%d' , 'term_id' => '%d' , 'term_group' => '%d' , 'term_taxonomy_id' => '%d' ,
2012-07-30 18:16:13 +02:00
'parent' => '%d' , 'count' => '%d' , 'object_id' => '%d' , 'term_order' => '%d' , 'ID' => '%d' , 'comment_ID' => '%d' , 'comment_post_ID' => '%d' , 'comment_parent' => '%d' ,
2010-01-15 23:03:41 +01:00
'user_id' => '%d' , 'link_id' => '%d' , 'link_owner' => '%d' , 'link_rating' => '%d' , 'option_id' => '%d' , 'blog_id' => '%d' , 'meta_id' => '%d' , 'post_id' => '%d' ,
2010-01-27 20:13:00 +01:00
'user_status' => '%d' , 'umeta_id' => '%d' , 'comment_karma' => '%d' , 'comment_count' => '%d' ,
// multisite:
'active' => '%d' , 'cat_id' => '%d' , 'deleted' => '%d' , 'lang_id' => '%d' , 'mature' => '%d' , 'public' => '%d' , 'site_id' => '%d' , 'spam' => '%d' ,
);
2010-01-15 23:03:41 +01:00
2010-01-19 18:27:03 +01:00
$prefix = $wpdb -> set_prefix ( $table_prefix );
2010-01-15 23:03:41 +01:00
2012-01-26 21:34:27 +01:00
if ( is_wp_error ( $prefix ) ) {
wp_load_translations_early ();
wp_die ( __ ( '<strong>ERROR</strong>: <code>$table_prefix</code> in <code>wp-config.php</code> can only contain numbers, letters, and underscores.' ) );
}
2010-01-15 23:03:41 +01:00
}
2010-01-19 18:27:03 +01:00
/**
* Starts the WordPress object cache .
*
* If an object - cache . php file exists in the wp - content directory ,
* it uses that drop - in as an external object cache .
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_start_object_cache () {
2012-08-02 20:31:14 +02:00
global $_wp_using_ext_object_cache , $blog_id ;
2010-04-21 22:37:54 +02:00
2010-02-12 18:06:43 +01:00
$first_init = false ;
if ( ! function_exists ( 'wp_cache_init' ) ) {
2010-01-28 18:28:44 +01:00
if ( file_exists ( WP_CONTENT_DIR . '/object-cache.php' ) ) {
require_once ( WP_CONTENT_DIR . '/object-cache.php' );
$_wp_using_ext_object_cache = true ;
} else {
require_once ( ABSPATH . WPINC . '/cache.php' );
$_wp_using_ext_object_cache = false ;
}
2010-02-12 18:06:43 +01:00
$first_init = true ;
2010-04-21 22:34:32 +02:00
} else if ( ! $_wp_using_ext_object_cache && file_exists ( WP_CONTENT_DIR . '/object-cache.php' ) ) {
// Sometimes advanced-cache.php can load object-cache.php before it is loaded here.
// This breaks the function_exists check above and can result in $_wp_using_ext_object_cache
2011-09-30 00:57:43 +02:00
// being set incorrectly. Double check if an external cache exists.
2010-04-21 22:34:32 +02:00
$_wp_using_ext_object_cache = true ;
2010-01-15 23:03:41 +01:00
}
2010-02-12 18:06:43 +01:00
// If cache supports reset, reset instead of init if already initialized.
// Reset signals to the cache that global IDs have changed and it may need to update keys
// and cleanup caches.
2012-08-02 20:31:14 +02:00
if ( ! $first_init && function_exists ( 'wp_cache_switch_to_blog' ) )
wp_cache_switch_to_blog ( $blog_id );
2010-02-12 18:06:43 +01:00
else
wp_cache_init ();
2010-01-19 18:27:03 +01:00
if ( function_exists ( 'wp_cache_add_global_groups' ) ) {
2010-07-30 23:30:06 +02:00
wp_cache_add_global_groups ( array ( 'users' , 'userlogins' , 'usermeta' , 'user_meta' , 'site-transient' , 'site-options' , 'site-lookup' , 'blog-lookup' , 'blog-details' , 'rss' , 'global-posts' ) );
2012-08-20 21:47:52 +02:00
wp_cache_add_non_persistent_groups ( array ( 'comment' , 'counts' , 'plugins' , 'post_ancestors' ) );
2010-01-15 23:03:41 +01:00
}
}
2010-01-19 18:27:03 +01:00
/**
* Redirects to the installer if WordPress is not installed .
*
* Dies with an error message when multisite is enabled .
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_not_installed () {
2010-01-15 23:25:40 +01:00
if ( is_multisite () ) {
2010-02-20 14:51:32 +01:00
if ( ! is_blog_installed () && ! defined ( 'WP_INSTALLING' ) )
2010-04-30 03:54:32 +02:00
wp_die ( __ ( 'The site you have requested is not installed properly. Please contact the system administrator.' ) );
2010-02-20 14:51:32 +01:00
} elseif ( ! is_blog_installed () && false === strpos ( $_SERVER [ 'PHP_SELF' ], 'install.php' ) && ! defined ( 'WP_INSTALLING' ) ) {
2010-10-02 05:08:02 +02:00
$link = wp_guess_url () . '/wp-admin/install.php' ;
2010-02-20 14:51:32 +01:00
require ( ABSPATH . WPINC . '/kses.php' );
require ( ABSPATH . WPINC . '/pluggable.php' );
require ( ABSPATH . WPINC . '/formatting.php' );
2010-01-19 18:27:03 +01:00
wp_redirect ( $link );
2010-01-15 23:03:41 +01:00
die ();
}
}
2010-01-19 18:27:03 +01:00
/**
* Returns array of must - use plugin files to be included in global scope .
*
* The default directory is wp - content / mu - plugins . To change the default directory
* manually , define < code > WPMU_PLUGIN_DIR </ code > and < code > WPMU_PLUGIN_URL </ code >
* in wp - config . php .
*
* @ access private
* @ since 3.0 . 0
* @ return array Files to include
*/
2010-02-12 08:59:11 +01:00
function wp_get_mu_plugins () {
2010-01-19 18:27:03 +01:00
$mu_plugins = array ();
if ( ! is_dir ( WPMU_PLUGIN_DIR ) )
return $mu_plugins ;
if ( ! $dh = opendir ( WPMU_PLUGIN_DIR ) )
return $mu_plugins ;
while ( ( $plugin = readdir ( $dh ) ) !== false ) {
if ( substr ( $plugin , - 4 ) == '.php' )
$mu_plugins [] = WPMU_PLUGIN_DIR . '/' . $plugin ;
2010-01-15 23:03:41 +01:00
}
2010-01-19 18:27:03 +01:00
closedir ( $dh );
sort ( $mu_plugins );
return $mu_plugins ;
2010-01-15 23:03:41 +01:00
}
2010-01-19 18:27:03 +01:00
/**
* Returns array of plugin files to be included in global scope .
*
* The default directory is wp - content / plugins . To change the default directory
* manually , define < code > WP_PLUGIN_DIR </ code > and < code > WP_PLUGIN_URL </ code >
* in wp - config . php .
*
* @ access private
* @ since 3.0 . 0
* @ return array Files to include
*/
2010-02-12 08:59:11 +01:00
function wp_get_active_and_valid_plugins () {
2010-01-19 18:27:03 +01:00
$plugins = array ();
2010-02-04 19:50:36 +01:00
$active_plugins = ( array ) get_option ( 'active_plugins' , array () );
2010-02-02 22:41:17 +01:00
2010-02-04 19:50:36 +01:00
// Check for hacks file if the option is enabled
if ( get_option ( 'hack_file' ) && file_exists ( ABSPATH . 'my-hacks.php' ) ) {
_deprecated_file ( 'my-hacks.php' , '1.5' );
array_unshift ( $plugins , ABSPATH . 'my-hacks.php' );
}
2010-02-02 22:41:17 +01:00
if ( empty ( $active_plugins ) || defined ( 'WP_INSTALLING' ) )
2010-01-19 18:27:03 +01:00
return $plugins ;
2010-02-02 22:41:17 +01:00
2010-11-24 01:19:38 +01:00
$network_plugins = is_multisite () ? wp_get_active_network_plugins () : false ;
2010-01-19 18:27:03 +01:00
foreach ( $active_plugins as $plugin ) {
2010-02-02 22:41:17 +01:00
if ( ! validate_file ( $plugin ) // $plugin must validate as file
&& '.php' == substr ( $plugin , - 4 ) // $plugin must end with '.php'
&& file_exists ( WP_PLUGIN_DIR . '/' . $plugin ) // $plugin must exist
2010-11-24 01:19:38 +01:00
// not already included as a network plugin
&& ( ! $network_plugins || ! in_array ( WP_PLUGIN_DIR . '/' . $plugin , $network_plugins ) )
2010-01-19 18:27:03 +01:00
)
$plugins [] = WP_PLUGIN_DIR . '/' . $plugin ;
2010-01-15 23:03:41 +01:00
}
2010-01-19 18:27:03 +01:00
return $plugins ;
2010-01-15 23:03:41 +01:00
}
2010-01-19 18:27:03 +01:00
/**
* Sets internal encoding using mb_internal_encoding () .
*
* In most cases the default internal encoding is latin1 , which is of no use ,
* since we want to use the mb_ functions for utf - 8 strings .
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_set_internal_encoding () {
2010-01-19 18:27:03 +01:00
if ( function_exists ( 'mb_internal_encoding' ) ) {
if ( !@ mb_internal_encoding ( get_option ( 'blog_charset' ) ) )
mb_internal_encoding ( 'UTF-8' );
2010-01-15 23:03:41 +01:00
}
}
2010-01-19 18:27:03 +01:00
/**
* Add magic quotes to $_GET , $_POST , $_COOKIE , and $_SERVER .
*
* Also forces $_REQUEST to be $_GET + $_POST . If $_SERVER , $_COOKIE ,
* or $_ENV are needed , use those superglobals directly .
*
* @ access private
* @ since 3.0 . 0
*/
2010-01-15 23:03:41 +01:00
function wp_magic_quotes () {
// If already slashed, strip.
if ( get_magic_quotes_gpc () ) {
2010-01-19 18:27:03 +01:00
$_GET = stripslashes_deep ( $_GET );
$_POST = stripslashes_deep ( $_POST );
$_COOKIE = stripslashes_deep ( $_COOKIE );
2010-01-15 23:03:41 +01:00
}
// Escape with wpdb.
2010-01-19 18:27:03 +01:00
$_GET = add_magic_quotes ( $_GET );
$_POST = add_magic_quotes ( $_POST );
$_COOKIE = add_magic_quotes ( $_COOKIE );
$_SERVER = add_magic_quotes ( $_SERVER );
2010-01-15 23:03:41 +01:00
2010-01-19 18:27:03 +01:00
// Force REQUEST to be GET + POST.
$_REQUEST = array_merge ( $_GET , $_POST );
2010-01-15 23:03:41 +01:00
}
/**
* Runs just before PHP shuts down execution .
*
* @ access private
* @ since 1.2 . 0
*/
function shutdown_action_hook () {
2010-01-19 18:27:03 +01:00
do_action ( 'shutdown' );
2010-01-15 23:03:41 +01:00
wp_cache_close ();
}
2011-04-22 19:46:02 +02:00
/**
* Copy an object .
*
* @ since 2.7 . 0
* @ deprecated 3.2
*
* @ param object $object The object to clone
* @ return object The cloned object
*/
function wp_clone ( $object ) {
2011-12-14 00:45:31 +01:00
// Use parens for clone to accommodate PHP 4. See #17880
2011-06-24 23:32:40 +02:00
return clone ( $object );
2011-04-22 19:46:02 +02:00
}
2010-01-15 23:03:41 +01:00
/**
2010-09-02 17:03:39 +02:00
* Whether the current request is for a network or blog admin page
2010-01-15 23:03:41 +01:00
*
* Does not inform on whether the user is an admin ! Use capability checks to
* tell if the user should be accessing a section or not .
*
* @ since 1.5 . 1
*
* @ return bool True if inside WordPress administration pages .
*/
function is_admin () {
2012-08-31 19:16:46 +02:00
if ( isset ( $GLOBALS [ 'current_screen' ] ) )
return $GLOBALS [ 'current_screen' ] -> in_admin ();
elseif ( defined ( 'WP_ADMIN' ) )
2010-01-15 23:03:41 +01:00
return WP_ADMIN ;
2012-08-31 19:16:46 +02:00
2010-01-15 23:03:41 +01:00
return false ;
}
2010-07-30 22:34:54 +02:00
/**
2010-09-02 17:03:39 +02:00
* Whether the current request is for a blog admin screen / wp - admin /
*
* Does not inform on whether the user is a blog admin ! Use capability checks to
* tell if the user should be accessing a section or not .
*
* @ since 3.1 . 0
*
* @ return bool True if inside WordPress network administration pages .
*/
function is_blog_admin () {
2012-08-31 19:16:46 +02:00
if ( isset ( $GLOBALS [ 'current_screen' ] ) )
return $GLOBALS [ 'current_screen' ] -> in_admin ( 'blog' );
elseif ( defined ( 'WP_BLOG_ADMIN' ) )
2010-09-02 17:03:39 +02:00
return WP_BLOG_ADMIN ;
2012-08-31 19:16:46 +02:00
2010-09-02 17:03:39 +02:00
return false ;
}
/**
* Whether the current request is for a network admin screen / wp - admin / network /
2010-07-30 22:34:54 +02:00
*
* Does not inform on whether the user is a network admin ! Use capability checks to
* tell if the user should be accessing a section or not .
*
* @ since 3.1 . 0
*
* @ return bool True if inside WordPress network administration pages .
*/
function is_network_admin () {
2012-08-31 19:16:46 +02:00
if ( isset ( $GLOBALS [ 'current_screen' ] ) )
return $GLOBALS [ 'current_screen' ] -> in_admin ( 'network' );
elseif ( defined ( 'WP_NETWORK_ADMIN' ) )
2010-07-30 22:34:54 +02:00
return WP_NETWORK_ADMIN ;
2012-08-31 19:16:46 +02:00
2010-07-30 22:34:54 +02:00
return false ;
}
2010-10-07 21:34:18 +02:00
/**
* Whether the current request is for a user admin screen / wp - admin / user /
*
* Does not inform on whether the user is an admin ! Use capability checks to
* tell if the user should be accessing a section or not .
*
* @ since 3.1 . 0
*
* @ return bool True if inside WordPress user administration pages .
*/
function is_user_admin () {
2012-08-31 19:16:46 +02:00
if ( isset ( $GLOBALS [ 'current_screen' ] ) )
return $GLOBALS [ 'current_screen' ] -> in_admin ( 'user' );
elseif ( defined ( 'WP_USER_ADMIN' ) )
2010-10-07 21:34:18 +02:00
return WP_USER_ADMIN ;
2012-08-31 19:16:46 +02:00
2010-10-07 21:34:18 +02:00
return false ;
}
2010-01-15 23:03:41 +01:00
/**
* Whether Multisite support is enabled
*
2010-02-20 14:51:32 +01:00
* @ since 3.0 . 0
2010-01-15 23:03:41 +01:00
*
* @ return bool True if multisite is enabled , false otherwise .
*/
function is_multisite () {
2010-04-08 04:39:17 +02:00
if ( defined ( 'MULTISITE' ) )
return MULTISITE ;
2010-04-05 02:00:13 +02:00
2010-10-26 05:45:13 +02:00
if ( defined ( 'SUBDOMAIN_INSTALL' ) || defined ( 'VHOST' ) || defined ( 'SUNRISE' ) )
2010-01-15 23:03:41 +01:00
return true ;
return false ;
}
2012-01-26 21:34:27 +01:00
2012-08-09 15:17:14 +02:00
/**
* Retrieve the current blog id
*
* @ since 3.1 . 0
*
* @ return int Blog id
*/
function get_current_blog_id () {
global $blog_id ;
return absint ( $blog_id );
}
2012-01-26 21:34:27 +01:00
/**
* Attempts an early load of translations .
*
* Used for errors encountered during the initial loading process , before the locale has been
* properly detected and loaded .
*
* Designed for unusual load sequences ( like setup - config . php ) or for when the script will then
* terminate with an error , otherwise there is a risk that a file can be double - included .
*
* @ since 3.4 . 0
* @ access private
*/
function wp_load_translations_early () {
global $text_direction , $wp_locale ;
static $loaded = false ;
if ( $loaded )
return ;
$loaded = true ;
if ( function_exists ( 'did_action' ) && did_action ( 'init' ) )
return ;
// We need $wp_local_package
require ABSPATH . WPINC . '/version.php' ;
// Translation and localization
require_once ABSPATH . WPINC . '/pomo/mo.php' ;
require_once ABSPATH . WPINC . '/l10n.php' ;
require_once ABSPATH . WPINC . '/locale.php' ;
// General libraries
require_once ABSPATH . WPINC . '/functions.php' ;
require_once ABSPATH . WPINC . '/plugin.php' ;
$locales = $locations = array ();
while ( true ) {
if ( defined ( 'WPLANG' ) ) {
if ( '' == WPLANG )
break ;
$locales [] = WPLANG ;
}
if ( isset ( $wp_local_package ) )
$locales [] = $wp_local_package ;
if ( ! $locales )
break ;
if ( defined ( 'WP_LANG_DIR' ) && @ is_dir ( WP_LANG_DIR ) )
$locations [] = WP_LANG_DIR ;
if ( defined ( 'WP_CONTENT_DIR' ) && @ is_dir ( WP_CONTENT_DIR . '/languages' ) )
$locations [] = WP_CONTENT_DIR . '/languages' ;
if ( @ is_dir ( ABSPATH . 'wp-content/languages' ) )
$locations [] = ABSPATH . 'wp-content/languages' ;
if ( @ is_dir ( ABSPATH . WPINC . '/languages' ) )
$locations [] = ABSPATH . WPINC . '/languages' ;
if ( ! $locations )
break ;
$locations = array_unique ( $locations );
foreach ( $locales as $locale ) {
foreach ( $locations as $location ) {
if ( file_exists ( $location . '/' . $locale . '.mo' ) ) {
load_textdomain ( 'default' , $location . '/' . $locale . '.mo' );
2012-01-29 21:49:34 +01:00
if ( defined ( 'WP_SETUP_CONFIG' ) && file_exists ( $location . '/admin-' . $locale . '.mo' ) )
load_textdomain ( 'default' , $location . '/admin-' . $locale . '.mo' );
2012-01-26 21:34:27 +01:00
break 2 ;
}
}
}
break ;
}
$wp_locale = new WP_Locale ();
}