View file File name : crawl-settings-integration.php Content :<?php namespace Yoast\WP\SEO\Integrations\Admin; use WPSEO_Admin_Asset_Manager; use WPSEO_Option; use WPSEO_Shortlinker; use Yoast\WP\SEO\Conditionals\Admin_Conditional; use Yoast\WP\SEO\Integrations\Integration_Interface; use Yoast\WP\SEO\Presenters\Admin\Alert_Presenter; use Yoast_Form; /** * Crawl_Settings_Integration class */ class Crawl_Settings_Integration implements Integration_Interface { /** * The admin asset manager. * * @var WPSEO_Admin_Asset_Manager */ private $admin_asset_manager; /** * Holds the settings + labels for the head clean up piece. * * @var array */ private $basic_settings; /** * Holds the settings + labels for the feeds clean up. * * @var array */ private $feed_settings; /** * Holds the settings + labels for permalink cleanup settings. * * @var array */ private $permalink_cleanup_settings; /** * Holds the settings + labels for search cleanup settings. * * @var array */ private $search_cleanup_settings; /** * Holds the settings + labels for unused resources settings. * * @var array */ private $unused_resources_settings; /** * The shortlinker. * * @var WPSEO_Shortlinker */ private $shortlinker; /** * Returns the conditionals based in which this loadable should be active. * * In this case: when on an admin page. * * @return array<string> */ public static function get_conditionals() { return [ Admin_Conditional::class ]; } /** * Crawl_Settings_Integration constructor. * * @param WPSEO_Admin_Asset_Manager $admin_asset_manager The admin asset manager. * @param WPSEO_Shortlinker $shortlinker The shortlinker. */ public function __construct( WPSEO_Admin_Asset_Manager $admin_asset_manager, WPSEO_Shortlinker $shortlinker ) { $this->admin_asset_manager = $admin_asset_manager; $this->shortlinker = $shortlinker; } /** * Registers an action to add a new tab to the General page. * * @return void */ public function register_hooks() { $this->register_setting_labels(); \add_action( 'wpseo_settings_tab_crawl_cleanup_network', [ $this, 'add_crawl_settings_tab_content_network' ] ); \add_action( 'admin_enqueue_scripts', [ $this, 'enqueue_assets' ] ); } /** * Enqueue the workouts app. * * @return void */ public function enqueue_assets() { if ( ! \is_network_admin() ) { return; } // phpcs:ignore WordPress.Security.NonceVerification.Recommended -- Page is not processed or saved. if ( ! isset( $_GET['page'] ) || $_GET['page'] !== 'wpseo_dashboard' ) { return; } $this->admin_asset_manager->enqueue_script( 'crawl-settings' ); } /** * Connects the settings to their labels. * * @return void */ private function register_setting_labels() { $this->feed_settings = [ 'remove_feed_global' => \__( 'Global feed', 'wordpress-seo' ), 'remove_feed_global_comments' => \__( 'Global comment feeds', 'wordpress-seo' ), 'remove_feed_post_comments' => \__( 'Post comments feeds', 'wordpress-seo' ), 'remove_feed_authors' => \__( 'Post authors feeds', 'wordpress-seo' ), 'remove_feed_post_types' => \__( 'Post type feeds', 'wordpress-seo' ), 'remove_feed_categories' => \__( 'Category feeds', 'wordpress-seo' ), 'remove_feed_tags' => \__( 'Tag feeds', 'wordpress-seo' ), 'remove_feed_custom_taxonomies' => \__( 'Custom taxonomy feeds', 'wordpress-seo' ), 'remove_feed_search' => \__( 'Search results feeds', 'wordpress-seo' ), 'remove_atom_rdf_feeds' => \__( 'Atom/RDF feeds', 'wordpress-seo' ), ]; $this->basic_settings = [ 'remove_shortlinks' => \__( 'Shortlinks', 'wordpress-seo' ), 'remove_rest_api_links' => \__( 'REST API links', 'wordpress-seo' ), 'remove_rsd_wlw_links' => \__( 'RSD / WLW links', 'wordpress-seo' ), 'remove_oembed_links' => \__( 'oEmbed links', 'wordpress-seo' ), 'remove_generator' => \__( 'Generator tag', 'wordpress-seo' ), 'remove_pingback_header' => \__( 'Pingback HTTP header', 'wordpress-seo' ), 'remove_powered_by_header' => \__( 'Powered by HTTP header', 'wordpress-seo' ), ]; $this->permalink_cleanup_settings = [ 'clean_campaign_tracking_urls' => \__( 'Campaign tracking URL parameters', 'wordpress-seo' ), 'clean_permalinks' => \__( 'Unregistered URL parameters', 'wordpress-seo' ), ]; $this->search_cleanup_settings = [ 'search_cleanup' => \__( 'Filter search terms', 'wordpress-seo' ), 'search_cleanup_emoji' => \__( 'Filter searches with emojis and other special characters', 'wordpress-seo' ), 'search_cleanup_patterns' => \__( 'Filter searches with common spam patterns', 'wordpress-seo' ), 'deny_search_crawling' => \__( 'Prevent search engines from crawling site search URLs', 'wordpress-seo' ), 'redirect_search_pretty_urls' => \__( 'Redirect pretty URLs for search pages to raw format', 'wordpress-seo' ), ]; $this->unused_resources_settings = [ 'remove_emoji_scripts' => \__( 'Emoji scripts', 'wordpress-seo' ), 'deny_wp_json_crawling' => \__( 'Prevent search engines from crawling /wp-json/', 'wordpress-seo' ), 'deny_adsbot_crawling' => \__( 'Prevent Google AdsBot from crawling', 'wordpress-seo' ), ]; } /** * Adds content to the Crawl Cleanup network tab. * * @param Yoast_Form $yform The yoast form object. * * @return void */ public function add_crawl_settings_tab_content_network( $yform ) { $this->add_crawl_settings( $yform ); } /** * Print the settings sections. * * @param Yoast_Form $yform The Yoast form class. * * @return void */ private function add_crawl_settings( $yform ) { $this->print_toggles( $this->basic_settings, $yform, \__( 'Basic crawl settings', 'wordpress-seo' ) ); $this->print_toggles( $this->feed_settings, $yform, \__( 'Feed crawl settings', 'wordpress-seo' ) ); $this->print_toggles( $this->unused_resources_settings, $yform, \__( 'Remove unused resources', 'wordpress-seo' ) ); $first_search_setting = \array_slice( $this->search_cleanup_settings, 0, 1 ); $rest_search_settings = \array_slice( $this->search_cleanup_settings, 1 ); $search_settings_toggles = [ 'off' => \__( 'Disabled', 'wordpress-seo' ), 'on' => \__( 'Enabled', 'wordpress-seo' ), ]; $this->print_toggles( $first_search_setting, $yform, \__( 'Search cleanup settings', 'wordpress-seo' ), $search_settings_toggles ); $this->print_toggles( $rest_search_settings, $yform, '', $search_settings_toggles ); $permalink_warning = \sprintf( /* Translators: %1$s expands to an opening anchor tag for a link leading to the Yoast SEO page of the Permalink Cleanup features, %2$s expands to a closing anchor tag. */ \esc_html__( 'These are expert features, so make sure you know what you\'re doing before removing the parameters. %1$sRead more about how your site can be affected%2$s.', 'wordpress-seo' ), '<a href="' . \esc_url( $this->shortlinker->build_shortlink( 'https://yoa.st/permalink-cleanup' ) ) . '" target="_blank" rel="noopener noreferrer">', '</a>' ); $this->print_toggles( $this->permalink_cleanup_settings, $yform, \__( 'Permalink cleanup settings', 'wordpress-seo' ), [], $permalink_warning ); // Add the original option as hidden, so as not to lose any values if it's disabled and the form is saved. $yform->hidden( 'clean_permalinks_extra_variables', 'clean_permalinks_extra_variables' ); } /** * Prints a list of toggles for an array of settings with labels. * * @param array $settings The settings being displayed. * @param Yoast_Form $yform The Yoast form class. * @param string $title Optional title for the settings being displayed. * @param array $toggles Optional naming of the toggle buttons. * @param string $warning Optional warning to be displayed above the toggles. * * @return void */ private function print_toggles( array $settings, Yoast_Form $yform, $title = '', $toggles = [], $warning = '' ) { if ( ! empty( $title ) ) { echo '<h3 class="yoast-crawl-settings">', \esc_html( $title ), '</h3>'; } if ( ! empty( $warning ) ) { // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Output escaped in Alert_Presenter. echo new Alert_Presenter( $warning, 'warning' ); } if ( empty( $toggles ) ) { $toggles = [ 'off' => \__( 'Keep', 'wordpress-seo' ), 'on' => \__( 'Remove', 'wordpress-seo' ), ]; } $setting_prefix = WPSEO_Option::ALLOW_KEY_PREFIX; $toggles = [ // phpcs:ignore WordPress.WP.I18n.TextDomainMismatch -- Reason: text is originally from Yoast SEO. 'on' => \__( 'Allow Control', 'wordpress-seo' ), // phpcs:ignore WordPress.WP.I18n.TextDomainMismatch -- Reason: text is originally from Yoast SEO. 'off' => \__( 'Disable', 'wordpress-seo' ), ]; foreach ( $settings as $setting => $label ) { $attr = []; $variable = $setting_prefix . $setting; if ( $this->should_feature_be_disabled_permalink( $setting ) ) { $attr = [ 'disabled' => true, ]; $variable = $setting_prefix . $setting . '_disabled'; // Also add the original option as hidden, so as not to lose any values if it's disabled and the form is saved. $yform->hidden( $setting_prefix . $setting, $setting_prefix . $setting ); } elseif ( $this->should_feature_be_disabled_multisite( $setting ) ) { $attr = [ 'disabled' => true, 'preserve_disabled_value' => false, ]; } $yform->toggle_switch( $variable, $toggles, $label, '', $attr ); if ( $this->should_feature_be_disabled_permalink( $setting ) ) { echo '<p class="yoast-crawl-settings-help">'; if ( \current_user_can( 'manage_options' ) ) { \printf( /* translators: 1: Link start tag to the Permalinks settings page, 2: Link closing tag. */ \esc_html__( 'This feature is disabled when your site is not using %1$spretty permalinks%2$s.', 'wordpress-seo' ), '<a href="' . \esc_url( \admin_url( 'options-permalink.php' ) ) . '">', '</a>' ); } else { echo \esc_html__( 'This feature is disabled when your site is not using pretty permalinks.', 'wordpress-seo' ); } echo '</p>'; } } } /** * Checks if the feature should be disabled due to non-pretty permalinks. * * @param string $setting The setting to be displayed. * * @return bool */ protected function should_feature_be_disabled_permalink( $setting ) { return ( \in_array( $setting, [ 'clean_permalinks', 'clean_campaign_tracking_urls' ], true ) && empty( \get_option( 'permalink_structure' ) ) ); } /** * Checks if the feature should be disabled due to the site being a multisite. * * @param string $setting The setting to be displayed. * * @return bool */ protected function should_feature_be_disabled_multisite( $setting ) { return ( \in_array( $setting, [ 'deny_search_crawling', 'deny_wp_json_crawling', 'deny_adsbot_crawling' ], true ) && \is_multisite() ); } }