options = $options; } /** * Return an array of events that this subscriber wants to listen to. * * @since 3.7 * * @return array */ public static function get_subscribed_events() { return [ 'init' => [ 'remove_wp_vars_and_hooks', 9999 ], 'rest_endpoints' => 'remove_embed_endpoint', 'oembed_response_data' => 'empty_oembed_response_data', 'embed_oembed_discover' => 'return_false', 'rewrite_rules_array' => 'remove_embeds_rewrite_rules', 'enqueue_block_editor_assets' => 'enqueue_disable_embeds_script', 'wp_default_scripts' => 'remove_wp_embed_dependency', ]; } /** * Remove WP Query Vars and hooks relating to embeds. * * Replaces old architecture's rocket_disable_embeds_init(). * * @since 3.7 * * @return void */ public function remove_wp_vars_and_hooks() { if ( ! $this->can_disable_embeds() ) { return; } global $wp; // Remove the embed query var. $wp->public_query_vars = array_diff( $wp->public_query_vars, [ 'embed', ] ); // Don't filter oEmbed results. remove_filter( 'oembed_dataparse', 'wp_filter_oembed_result', 10 ); // Remove oEmbed discovery links. remove_action( 'wp_head', 'wp_oembed_add_discovery_links' ); // Remove oEmbed-specific JavaScript from the front-end and back-end. remove_action( 'wp_head', 'wp_oembed_add_host_js' ); // Remove filter of the oEmbed result before any HTTP requests are made. remove_filter( 'pre_oembed_result', 'wp_filter_pre_oembed_result', 10 ); } /** * Remove all rewrite rules related to embeds. * * @since 3.7 Moved to new architecture. * @since 2.10 * * @param array $rules WordPress rewrite rules. * * @return array Rewrite rules without embeds rules. */ public function remove_embeds_rewrite_rules( $rules ) { if ( empty( $rules ) || ! $this->can_disable_embeds() ) { return $rules; } foreach ( $rules as $rule => $rewrite ) { if ( false !== strpos( $rewrite, 'embed=true' ) ) { unset( $rules[ $rule ] ); } } return $rules; } /** * Remove the oembed/1.0/embed REST route. * * @since 3.7 Moved to new architecture. * @since 3.3.3 * * @param array $endpoints Registered REST API endpoints. * * @return array Filtered REST API endpoints. */ public function remove_embed_endpoint( $endpoints ) { if ( ! $this->can_disable_embeds() ) { return $endpoints; } unset( $endpoints['/oembed/1.0/embed'] ); return $endpoints; } /** * Disables sending internal oEmbed response data in proxy endpoint. * * @since 3.7 Moved to new architecture. * @since 3.3.3 * * @param array $data The response data. * * @return array Response data */ public function empty_oembed_response_data( $data ) { if ( ! rocket_get_constant( 'REST_REQUEST' ) || ! $this->can_disable_embeds() ) { return $data; } return []; } /** * Enqueue JavaScript for the block editor. * * This is used to unregister the `core-embed/wordpress` block type. * * @since 3.7 Moved to new architecture. * @since 3.3.3 * * @return void */ public function enqueue_disable_embeds_script() { if ( ! $this->can_disable_embeds() ) { return; } } /** * Remove wp-embed dependency of core packages. * * @since 3.7 Moved to new architecture. * @since 3.3.3 * * @param \WP_Scripts $scripts WP_Scripts instance, passed by reference. */ public function remove_wp_embed_dependency( $scripts ) { if ( ! $this->can_disable_embeds() ) { return; } if ( ! empty( $scripts->registered['wp-edit-post'] ) ) { $scripts->registered['wp-edit-post']->deps = array_diff( $scripts->registered['wp-edit-post']->deps, [ 'wp-embed' ] ); } } /** * Check for embeds enabled. * * @since 3.7 * * @return bool */ private function can_disable_embeds() { return ! rocket_bypass() && (bool) $this->options->get( 'embeds', 0 ); } }