123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 |
- <?php
- /**
- * WPSEO plugin file.
- *
- * @package WPSEO\Internals\Options
- */
- /**
- * Site option for Multisite installs only
- *
- * Overloads a number of methods of the abstract class to ensure the use of the correct site_option
- * WP functions.
- */
- class WPSEO_Option_MS extends WPSEO_Option {
- /**
- * Option name.
- *
- * @var string
- */
- public $option_name = 'wpseo_ms';
- /**
- * Option group name for use in settings forms.
- *
- * @var string
- */
- public $group_name = 'yoast_wpseo_multisite_options';
- /**
- * Whether to include the option in the return for WPSEO_Options::get_all().
- *
- * @var bool
- */
- public $include_in_all = false;
- /**
- * Whether this option is only for when the install is multisite.
- *
- * @var bool
- */
- public $multisite_only = true;
- /**
- * Array of defaults for the option.
- *
- * Shouldn't be requested directly, use $this->get_defaults();
- *
- * @var array
- */
- protected $defaults = [];
- /**
- * Available options for the 'access' setting. Used for input validation.
- *
- * {@internal Important: Make sure the options added to the array here are in line
- * with the keys for the options set for the select box in the
- * admin/pages/network.php file.}}
- *
- * @var array
- */
- public static $allowed_access_options = [
- 'admin',
- 'superadmin',
- ];
- /**
- * Get the singleton instance of this class.
- *
- * @return object
- */
- public static function get_instance() {
- if ( ! ( self::$instance instanceof self ) ) {
- self::$instance = new self();
- }
- return self::$instance;
- }
- /**
- * Only run parent constructor in multisite context.
- */
- public function __construct() {
- $allow_prefix = self::ALLOW_KEY_PREFIX;
- $this->defaults = [
- 'access' => 'admin',
- 'defaultblog' => '', // Numeric blog ID or empty.
- "{$allow_prefix}disableadvanced_meta" => true,
- "{$allow_prefix}onpage_indexability" => true,
- "{$allow_prefix}content_analysis_active" => true,
- "{$allow_prefix}keyword_analysis_active" => true,
- "{$allow_prefix}enable_admin_bar_menu" => true,
- "{$allow_prefix}enable_cornerstone_content" => true,
- "{$allow_prefix}enable_xml_sitemap" => true,
- "{$allow_prefix}enable_text_link_counter" => true,
- ];
- if ( is_multisite() ) {
- parent::__construct();
- add_filter( 'admin_title', [ 'Yoast_Input_Validation', 'add_yoast_admin_document_title_errors' ] );
- }
- }
- /**
- * Add filters to make sure that the option default is returned if the option is not set
- *
- * @return void
- */
- public function add_default_filters() {
- // Don't change, needs to check for false as could return prio 0 which would evaluate to false.
- if ( has_filter( 'default_site_option_' . $this->option_name, [ $this, 'get_defaults' ] ) === false ) {
- add_filter( 'default_site_option_' . $this->option_name, [ $this, 'get_defaults' ] );
- }
- }
- /**
- * Remove the default filters.
- * Called from the validate() method to prevent failure to add new options.
- *
- * @return void
- */
- public function remove_default_filters() {
- remove_filter( 'default_site_option_' . $this->option_name, [ $this, 'get_defaults' ] );
- }
- /**
- * Add filters to make sure that the option is merged with its defaults before being returned.
- *
- * @return void
- */
- public function add_option_filters() {
- // Don't change, needs to check for false as could return prio 0 which would evaluate to false.
- if ( has_filter( 'site_option_' . $this->option_name, [ $this, 'get_option' ] ) === false ) {
- add_filter( 'site_option_' . $this->option_name, [ $this, 'get_option' ] );
- }
- }
- /**
- * Remove the option filters.
- * Called from the clean_up methods to make sure we retrieve the original old option.
- *
- * @return void
- */
- public function remove_option_filters() {
- remove_filter( 'site_option_' . $this->option_name, [ $this, 'get_option' ] );
- }
- /* *********** METHODS influencing add_uption(), update_option() and saving from admin pages *********** */
- /**
- * Validate the option.
- *
- * @param array $dirty New value for the option.
- * @param array $clean Clean value for the option, normally the defaults.
- * @param array $old Old value of the option.
- *
- * @return array Validated clean value for the option to be saved to the database.
- */
- protected function validate_option( $dirty, $clean, $old ) {
- foreach ( $clean as $key => $value ) {
- switch ( $key ) {
- case 'access':
- if ( isset( $dirty[ $key ] ) && in_array( $dirty[ $key ], self::$allowed_access_options, true ) ) {
- $clean[ $key ] = $dirty[ $key ];
- }
- elseif ( function_exists( 'add_settings_error' ) ) {
- add_settings_error(
- $this->group_name, // Slug title of the setting.
- $key, // Suffix-ID for the error message box.
- /* translators: %1$s expands to the option name and %2$sexpands to Yoast SEO */
- sprintf( __( '%1$s is not a valid choice for who should be allowed access to the %2$s settings. Value reset to the default.', 'wordpress-seo' ), esc_html( sanitize_text_field( $dirty[ $key ] ) ), 'Yoast SEO' ), // The error message.
- 'error' // Error type, either 'error' or 'updated'.
- );
- }
- break;
- case 'defaultblog':
- if ( isset( $dirty[ $key ] ) && ( $dirty[ $key ] !== '' && $dirty[ $key ] !== '-' ) ) {
- $int = WPSEO_Utils::validate_int( $dirty[ $key ] );
- if ( $int !== false && $int > 0 ) {
- // Check if a valid blog number has been received.
- $exists = get_blog_details( $int, false );
- if ( $exists && $exists->deleted === '0' ) {
- $clean[ $key ] = $int;
- }
- elseif ( function_exists( 'add_settings_error' ) ) {
- add_settings_error(
- $this->group_name, // Slug title of the setting.
- $key, // Suffix-ID for the error message box.
- esc_html__( 'The default blog setting must be the numeric blog id of the blog you want to use as default.', 'wordpress-seo' )
- . '<br>'
- . sprintf(
- /* translators: %s is the ID number of a blog. */
- esc_html__( 'This must be an existing blog. Blog %s does not exist or has been marked as deleted.', 'wordpress-seo' ),
- '<strong>' . esc_html( sanitize_text_field( $dirty[ $key ] ) ) . '</strong>'
- ), // The error message.
- 'error' // Error type, either 'error' or 'updated'.
- );
- }
- unset( $exists );
- }
- elseif ( function_exists( 'add_settings_error' ) ) {
- add_settings_error(
- $this->group_name, // Slug title of the setting.
- $key, // Suffix-ID for the error message box.
- esc_html__( 'The default blog setting must be the numeric blog id of the blog you want to use as default.', 'wordpress-seo' ) . '<br>' . esc_html__( 'No numeric value was received.', 'wordpress-seo' ), // The error message.
- 'error' // Error type, either 'error' or 'updated'.
- );
- }
- unset( $int );
- }
- break;
- default:
- $clean[ $key ] = ( isset( $dirty[ $key ] ) ? WPSEO_Utils::validate_bool( $dirty[ $key ] ) : false );
- break;
- }
- }
- return $clean;
- }
- /**
- * Clean a given option value.
- *
- * @param array $option_value Old (not merged with defaults or filtered) option value to
- * clean according to the rules for this option.
- * @param string $current_version (optional) Version from which to upgrade, if not set,
- * version specific upgrades will be disregarded.
- * @param array $all_old_option_values (optional) Only used when importing old options to have
- * access to the real old values, in contrast to the saved ones.
- *
- * @return array Cleaned option.
- */
- /*
- Protected function clean_option( $option_value, $current_version = null, $all_old_option_values = null ) {
- return $option_value;
- }
- */
- }
|