2003-06-11 18:59:14 -04:00
< ? php
2008-08-16 03:27:34 -04:00
/**
2011-04-28 11:24:49 -04:00
* Options Management Administration Screen .
2008-08-16 03:27:34 -04:00
*
2010-02-17 12:50:42 -05:00
* If accessed directly in a browser this page shows a list of all saved options
* along with editable fields for their values . Serialized data is not supported
* and there is no way to remove options via this page . It is not linked to from
* anywhere else in the admin .
2008-08-16 03:27:34 -04:00
*
2010-02-17 12:50:42 -05:00
* This file is also the target of the forms in core and custom options pages
* that use the Settings API . In this case it saves the new option values
* and returns the user to their page of origin .
2008-08-16 03:27:34 -04:00
*
* @ package WordPress
* @ subpackage Administration
*/
/** WordPress Administration Bootstrap */
2013-09-24 20:18:11 -04:00
require_once ( dirname ( __FILE__ ) . '/admin.php' );
2004-06-13 12:14:58 -04:00
2008-02-13 19:39:38 -05:00
$title = __ ( 'Settings' );
2006-11-18 02:31:29 -05:00
$this_file = 'options.php' ;
$parent_file = 'options-general.php' ;
2010-03-09 05:57:49 -05:00
wp_reset_vars ( array ( 'action' , 'option_page' ));
2011-05-22 17:32:22 -04:00
$capability = 'manage_options' ;
2014-06-25 17:48:15 -04:00
// This is for back compat and will eventually be removed.
if ( empty ( $option_page ) ) {
2010-03-09 05:57:49 -05:00
$option_page = 'options' ;
2014-06-25 17:48:15 -04:00
} else {
2013-09-11 23:44:08 -04:00
2013-10-24 22:29:52 -04:00
/**
* Filter the capability required when using the Settings API .
*
* By default , the options groups for all registered settings require the manage_options capability .
* This filter is required to change the capability required for a certain options page .
*
2013-09-11 23:44:08 -04:00
* @ since 3.2 . 0
2013-10-24 22:29:52 -04:00
*
* @ param string $capability The capability used for the page , which is manage_options by default .
2013-09-11 23:44:08 -04:00
*/
2011-05-22 17:32:22 -04:00
$capability = apply_filters ( " option_page_capability_ { $option_page } " , $capability );
2014-06-25 17:48:15 -04:00
}
2010-03-09 05:57:49 -05:00
2011-05-22 17:32:22 -04:00
if ( ! current_user_can ( $capability ) )
2014-11-16 01:16:22 -05:00
wp_die ( __ ( 'Cheatin’ uh?' ), 403 );
2010-03-17 12:27:25 -04:00
2010-04-26 13:55:41 -04:00
// Handle admin email change requests
if ( is_multisite () ) {
if ( ! empty ( $_GET [ 'adminhash' ] ) ) {
$new_admin_details = get_option ( 'adminhash' );
$redirect = 'options-general.php?updated=false' ;
if ( is_array ( $new_admin_details ) && $new_admin_details [ 'hash' ] == $_GET [ 'adminhash' ] && ! empty ( $new_admin_details [ 'newemail' ]) ) {
update_option ( 'admin_email' , $new_admin_details [ 'newemail' ] );
delete_option ( 'adminhash' );
delete_option ( 'new_admin_email' );
$redirect = 'options-general.php?updated=true' ;
}
wp_redirect ( admin_url ( $redirect ) );
exit ;
} elseif ( ! empty ( $_GET [ 'dismiss' ] ) && 'new_admin_email' == $_GET [ 'dismiss' ] ) {
delete_option ( 'adminhash' );
delete_option ( 'new_admin_email' );
wp_redirect ( admin_url ( 'options-general.php?updated=true' ) );
exit ;
}
}
2010-03-09 05:57:49 -05:00
if ( is_multisite () && ! is_super_admin () && 'update' != $action )
2014-11-16 01:16:22 -05:00
wp_die ( __ ( 'Cheatin’ uh?' ), 403 );
2003-06-12 18:48:52 -04:00
2008-09-03 21:11:18 -04:00
$whitelist_options = array (
Introducing Site Icon, favicon management for WordPress.
This v1 marries Jetpack's Site Icon module with the Media Modal, reusing code
from the Custom Header admin. For now, the core-provided icons will be limited
to a favicon, an iOS app icon, and a Windows tile icon, leaving `.ico` support
and additional icons to plugins to add.
Props obenland, tyxla, flixos90, jancbeck, markjaquith, scruffian.
See #16434.
Built from https://develop.svn.wordpress.org/trunk@32994
git-svn-id: http://core.svn.wordpress.org/trunk@32965 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-06-29 08:58:25 -04:00
'general' => array ( 'blogname' , 'blogdescription' , 'site_icon' , 'gmt_offset' , 'date_format' , 'time_format' , 'start_of_week' , 'timezone_string' , 'WPLANG' ),
2010-05-15 00:56:56 -04:00
'discussion' => array ( 'default_pingback_flag' , 'default_ping_status' , 'default_comment_status' , 'comments_notify' , 'moderation_notify' , 'comment_moderation' , 'require_name_email' , 'comment_whitelist' , 'comment_max_links' , 'moderation_keys' , 'blacklist_keys' , 'show_avatars' , 'avatar_rating' , 'avatar_default' , 'close_comments_for_old_posts' , 'close_comments_days_old' , 'thread_comments' , 'thread_comments_depth' , 'page_comments' , 'comments_per_page' , 'default_comments_page' , 'comment_order' , 'comment_registration' ),
2012-09-25 03:10:09 -04:00
'media' => array ( 'thumbnail_size_w' , 'thumbnail_size_h' , 'thumbnail_crop' , 'medium_size_w' , 'medium_size_h' , 'large_size_w' , 'large_size_h' , 'image_default_size' , 'image_default_align' , 'image_default_link_type' ),
2012-11-18 20:28:32 -05:00
'reading' => array ( 'posts_per_page' , 'posts_per_rss' , 'rss_use_excerpt' , 'show_on_front' , 'page_on_front' , 'page_for_posts' , 'blog_public' ),
2015-05-08 07:59:26 -04:00
'writing' => array ( 'default_category' , 'default_email_category' , 'default_link_category' , 'default_post_format' )
2012-09-13 13:28:57 -04:00
);
$whitelist_options [ 'misc' ] = $whitelist_options [ 'options' ] = $whitelist_options [ 'privacy' ] = array ();
2010-01-25 16:33:49 -05:00
$mail_options = array ( 'mailserver_url' , 'mailserver_port' , 'mailserver_login' , 'mailserver_pass' );
2012-09-13 23:23:06 -04:00
if ( ! in_array ( get_option ( 'blog_charset' ), array ( 'utf8' , 'utf-8' , 'UTF8' , 'UTF-8' ) ) )
$whitelist_options [ 'reading' ][] = 'blog_charset' ;
2015-05-08 07:59:26 -04:00
if ( get_site_option ( 'initial_db_version' ) < 32453 ) {
$whitelist_options [ 'writing' ][] = 'use_smilies' ;
$whitelist_options [ 'writing' ][] = 'use_balanceTags' ;
}
2010-01-25 16:33:49 -05:00
if ( ! is_multisite () ) {
2010-03-09 05:57:49 -05:00
if ( ! defined ( 'WP_SITEURL' ) )
$whitelist_options [ 'general' ][] = 'siteurl' ;
if ( ! defined ( 'WP_HOME' ) )
$whitelist_options [ 'general' ][] = 'home' ;
2010-01-25 16:33:49 -05:00
$whitelist_options [ 'general' ][] = 'admin_email' ;
$whitelist_options [ 'general' ][] = 'users_can_register' ;
$whitelist_options [ 'general' ][] = 'default_role' ;
$whitelist_options [ 'writing' ] = array_merge ( $whitelist_options [ 'writing' ], $mail_options );
$whitelist_options [ 'writing' ][] = 'ping_sites' ;
2010-03-02 05:31:06 -05:00
2012-09-14 17:00:39 -04:00
$whitelist_options [ 'media' ][] = 'uploads_use_yearmonth_folders' ;
// If upload_url_path and upload_path are both default values, they're locked.
if ( get_option ( 'upload_url_path' ) || ( get_option ( 'upload_path' ) != 'wp-content/uploads' && get_option ( 'upload_path' ) ) ) {
$whitelist_options [ 'media' ][] = 'upload_path' ;
$whitelist_options [ 'media' ][] = 'upload_url_path' ;
}
2010-01-25 16:33:49 -05:00
} else {
$whitelist_options [ 'general' ][] = 'new_admin_email' ;
2013-10-24 22:29:52 -04:00
2013-09-11 23:44:08 -04:00
/**
2014-04-11 20:01:15 -04:00
* Filter whether the post - by - email functionality is enabled .
2013-09-11 23:44:08 -04:00
*
* @ since 3.0 . 0
*
2014-04-11 20:01:15 -04:00
* @ param bool $enabled Whether post - by - email configuration is enabled . Default true .
2013-09-11 23:44:08 -04:00
*/
2010-03-09 05:57:49 -05:00
if ( apply_filters ( 'enable_post_by_email_configuration' , true ) )
2010-01-25 16:33:49 -05:00
$whitelist_options [ 'writing' ] = array_merge ( $whitelist_options [ 'writing' ], $mail_options );
}
2008-09-03 21:11:18 -04:00
2013-09-11 23:44:08 -04:00
/**
2013-10-24 22:29:52 -04:00
* Filter the options white list .
*
2013-09-11 23:44:08 -04:00
* @ since 2.7 . 0
*
* @ param array White list options .
*/
2008-09-03 21:11:18 -04:00
$whitelist_options = apply_filters ( 'whitelist_options' , $whitelist_options );
2010-03-21 03:38:10 -04:00
/*
2010-02-17 12:50:42 -05:00
* If $_GET [ 'action' ] == 'update' we are saving settings sent from a settings page
*/
2010-03-09 05:57:49 -05:00
if ( 'update' == $action ) {
2010-03-21 03:38:10 -04:00
if ( 'options' == $option_page && ! isset ( $_POST [ 'option_page' ] ) ) { // This is for back compat and will eventually be removed.
$unregistered = true ;
2008-10-19 20:40:36 -04:00
check_admin_referer ( 'update-options' );
2010-03-21 03:38:10 -04:00
} else {
$unregistered = false ;
2010-03-09 05:57:49 -05:00
check_admin_referer ( $option_page . '-options' );
2010-03-21 03:38:10 -04:00
}
2005-11-30 02:27:39 -05:00
2008-09-03 21:11:18 -04:00
if ( ! isset ( $whitelist_options [ $option_page ] ) )
2011-09-30 13:18:35 -04:00
wp_die ( __ ( '<strong>ERROR</strong>: options page not found.' ) );
2008-09-03 21:11:18 -04:00
2010-03-21 03:38:10 -04:00
if ( 'options' == $option_page ) {
2010-03-16 16:59:26 -04:00
if ( is_multisite () && ! is_super_admin () )
2010-03-15 18:00:48 -04:00
wp_die ( __ ( 'You do not have sufficient permissions to modify unregistered settings for this site.' ) );
2013-03-01 12:14:09 -05:00
$options = explode ( ',' , wp_unslash ( $_POST [ 'page_options' ] ) );
2010-03-16 16:59:26 -04:00
} else {
2008-09-03 21:11:18 -04:00
$options = $whitelist_options [ $option_page ];
2010-03-16 16:59:26 -04:00
}
2004-02-13 04:59:47 -05:00
2008-10-13 14:32:16 -04:00
if ( 'general' == $option_page ) {
2014-11-13 12:01:24 -05:00
// Handle custom date/time formats.
2013-03-01 12:14:09 -05:00
if ( ! empty ( $_POST [ 'date_format' ]) && isset ( $_POST [ 'date_format_custom' ]) && '\c\u\s\t\o\m' == wp_unslash ( $_POST [ 'date_format' ] ) )
2008-10-13 14:32:16 -04:00
$_POST [ 'date_format' ] = $_POST [ 'date_format_custom' ];
2013-03-01 12:14:09 -05:00
if ( ! empty ( $_POST [ 'time_format' ]) && isset ( $_POST [ 'time_format_custom' ]) && '\c\u\s\t\o\m' == wp_unslash ( $_POST [ 'time_format' ] ) )
2008-10-13 14:32:16 -04:00
$_POST [ 'time_format' ] = $_POST [ 'time_format_custom' ];
2009-12-23 09:16:36 -05:00
// Map UTC+- timezones to gmt_offsets and set timezone_string to empty.
if ( ! empty ( $_POST [ 'timezone_string' ]) && preg_match ( '/^UTC[+-]/' , $_POST [ 'timezone_string' ]) ) {
$_POST [ 'gmt_offset' ] = $_POST [ 'timezone_string' ];
$_POST [ 'gmt_offset' ] = preg_replace ( '/UTC\+?/' , '' , $_POST [ 'gmt_offset' ]);
$_POST [ 'timezone_string' ] = '' ;
}
2014-11-13 12:01:24 -05:00
// Handle translation install.
if ( ! empty ( $_POST [ 'WPLANG' ] ) && ( ! is_multisite () || is_super_admin () ) ) { // @todo: Skip if already installed
require_once ( ABSPATH . 'wp-admin/includes/translation-install.php' );
if ( wp_can_install_language_pack () ) {
$language = wp_download_language_pack ( $_POST [ 'WPLANG' ] );
if ( $language ) {
$_POST [ 'WPLANG' ] = $language ;
}
}
}
2008-10-13 14:32:16 -04:00
}
if ( $options ) {
foreach ( $options as $option ) {
2010-03-20 21:49:00 -04:00
if ( $unregistered )
2015-04-12 17:29:32 -04:00
_deprecated_argument ( 'options.php' , '2.7' , sprintf ( __ ( 'The <code>%1$s</code> setting is unregistered. Unregistered settings are deprecated. See https://codex.wordpress.org/Settings_API' ), $option , $option_page ) );
2010-03-20 21:49:00 -04:00
2012-09-14 15:12:35 -04:00
$option = trim ( $option );
2008-11-03 22:22:24 -05:00
$value = null ;
2012-09-14 15:12:35 -04:00
if ( isset ( $_POST [ $option ] ) ) {
$value = $_POST [ $option ];
if ( ! is_array ( $value ) )
$value = trim ( $value );
2013-03-01 12:14:09 -05:00
$value = wp_unslash ( $value );
2012-09-14 15:12:35 -04:00
}
update_option ( $option , $value );
2006-01-09 17:24:57 -05:00
}
2014-08-26 15:59:16 -04:00
// Switch translation in case WPLANG was changed.
$language = get_option ( 'WPLANG' );
if ( $language ) {
load_default_textdomain ( $language );
} else {
unload_textdomain ( 'default' );
}
2006-01-09 17:24:57 -05:00
}
2007-06-13 22:25:30 -04:00
2010-02-17 12:50:42 -05:00
/**
2011-12-14 12:36:38 -05:00
* Handle settings errors and return to options page
2010-02-17 12:50:42 -05:00
*/
// If no settings errors were registered add a general 'updated' message.
if ( ! count ( get_settings_errors () ) )
add_settings_error ( 'general' , 'settings_updated' , __ ( 'Settings saved.' ), 'updated' );
set_transient ( 'settings_errors' , get_settings_errors (), 30 );
/**
* Redirect back to the settings page that was submitted
*/
2010-12-03 05:59:20 -05:00
$goback = add_query_arg ( 'settings-updated' , 'true' , wp_get_referer () );
2008-10-13 14:32:16 -04:00
wp_redirect ( $goback );
2010-03-09 05:57:49 -05:00
exit ;
}
2010-01-12 16:11:52 -05:00
2013-09-24 20:18:11 -04:00
include ( ABSPATH . 'wp-admin/admin-header.php' ); ?>
2004-04-11 04:15:10 -04:00
2003-06-11 18:59:14 -04:00
< div class = " wrap " >
2015-06-27 11:41:25 -04:00
< h1 >< ? php esc_html_e ( 'All Settings' ); ?> </h1>
2006-10-04 07:28:38 -04:00
< form name = " form " action = " options.php " method = " post " id = " all-options " >
2008-09-03 21:11:18 -04:00
< ? php wp_nonce_field ( 'options-options' ) ?>
2003-12-16 20:07:40 -05:00
< input type = " hidden " name = " action " value = " update " />
2014-05-19 01:04:16 -04:00
< input type = " hidden " name = " option_page " value = " options " />
2008-02-23 23:33:10 -05:00
< table class = " form-table " >
2003-06-11 18:59:14 -04:00
< ? php
2010-02-27 17:50:00 -05:00
$options = $wpdb -> get_results ( " SELECT * FROM $wpdb->options ORDER BY option_name " );
2004-04-24 17:21:19 -04:00
2010-02-27 17:50:00 -05:00
foreach ( ( array ) $options as $option ) :
2010-03-11 12:12:23 -05:00
$disabled = false ;
2010-01-18 15:34:48 -05:00
if ( $option -> option_name == '' )
2010-01-12 16:11:52 -05:00
continue ;
2010-02-27 17:50:00 -05:00
if ( is_serialized ( $option -> option_value ) ) {
if ( is_serialized_string ( $option -> option_value ) ) {
2014-07-17 05:14:16 -04:00
// This is a serialized string, so we should display it.
2010-02-27 17:50:00 -05:00
$value = maybe_unserialize ( $option -> option_value );
2006-10-12 19:54:36 -04:00
$options_to_update [] = $option -> option_name ;
$class = 'all-options' ;
} else {
$value = 'SERIALIZED DATA' ;
2010-03-11 12:12:23 -05:00
$disabled = true ;
2006-10-12 19:54:36 -04:00
$class = 'all-options disabled' ;
}
} else {
2007-08-01 15:24:51 -04:00
$value = $option -> option_value ;
2006-10-12 19:54:36 -04:00
$options_to_update [] = $option -> option_name ;
$class = 'all-options' ;
}
2010-02-27 17:50:00 -05:00
$name = esc_attr ( $option -> option_name );
2014-05-19 13:10:15 -04:00
?>
2004-09-04 20:24:28 -04:00
< tr >
2014-05-19 13:10:15 -04:00
< th scope = " row " >< label for = " <?php echo $name ?> " >< ? php echo esc_html ( $option -> option_name ); ?> </label></th>
< td >
< ? php if ( strpos ( $value , " \n " ) !== false ) : ?>
< textarea class = " <?php echo $class ?> " name = " <?php echo $name ?> " id = " <?php echo $name ?> " cols = " 30 " rows = " 5 " >< ? php
echo esc_textarea ( $value );
?> </textarea>
< ? php else : ?>
< input class = " regular-text <?php echo $class ?> " type = " text " name = " <?php echo $name ?> " id = " <?php echo $name ?> " value = " <?php echo esc_attr( $value ) ?> " < ? php disabled ( $disabled , true ) ?> />
< ? php endif ?> </td>
</ tr >
< ? php endforeach ; ?>
2003-06-11 18:59:14 -04:00
</ table >
2010-10-17 14:24:34 -04:00
< input type = " hidden " name = " page_options " value = " <?php echo esc_attr( implode( ',', $options_to_update ) ); ?> " />
2010-10-28 17:56:43 -04:00
< ? php submit_button ( __ ( 'Save Changes' ), 'primary' , 'Update' ); ?>
2010-10-17 14:24:34 -04:00
2003-12-16 20:07:40 -05:00
</ form >
2003-06-11 18:59:14 -04:00
</ div >
< ? php
2013-09-24 20:18:11 -04:00
include ( ABSPATH . 'wp-admin/admin-footer.php' );