diff options
Diffstat (limited to 'plugins/jetpack/_inc/lib/class.jetpack-iframe-embed.php')
-rw-r--r-- | plugins/jetpack/_inc/lib/class.jetpack-iframe-embed.php | 74 |
1 files changed, 47 insertions, 27 deletions
diff --git a/plugins/jetpack/_inc/lib/class.jetpack-iframe-embed.php b/plugins/jetpack/_inc/lib/class.jetpack-iframe-embed.php index 4445cb65..a4a5ed3c 100644 --- a/plugins/jetpack/_inc/lib/class.jetpack-iframe-embed.php +++ b/plugins/jetpack/_inc/lib/class.jetpack-iframe-embed.php @@ -1,20 +1,32 @@ -<?php +<?php // phpcs:ignore WordPress.Files.FileName.InvalidClassFileName /** - * Tweak the preview when rendered in an iframe + * Tweak a preview when rendered in an iframe. + * This is used when rendering iFrames in the Calypso app. + * + * This file is shared between WordPress.com and Jetpack. + * The canonical source is Jetpack and no WordPress.com-specific code should exist in this file. + * + * @package automattic/jetpack */ +/** + * Tweak a preview when rendered in an iframe. + */ class Jetpack_Iframe_Embed { - static function init() { + /** + * Initialize class. + */ + public static function init() { if ( ! self::is_embedding_in_iframe() ) { return; } - // Disable the admin bar + // Disable the admin bar. if ( ! defined( 'IFRAME_REQUEST' ) ) { define( 'IFRAME_REQUEST', true ); } - // Prevent canonical redirects + // Prevent canonical redirects. remove_filter( 'template_redirect', 'redirect_canonical' ); add_action( 'wp_head', array( 'Jetpack_Iframe_Embed', 'noindex' ), 1 ); @@ -23,36 +35,44 @@ class Jetpack_Iframe_Embed { add_filter( 'shortcode_atts_video', array( 'Jetpack_Iframe_Embed', 'disable_autoplay' ) ); add_filter( 'shortcode_atts_audio', array( 'Jetpack_Iframe_Embed', 'disable_autoplay' ) ); + $ver = sprintf( '%s-%s', gmdate( 'oW' ), defined( 'JETPACK__VERSION' ) ? JETPACK__VERSION : '' ); if ( defined( 'IS_WPCOM' ) && IS_WPCOM ) { - wp_enqueue_script( 'jetpack-iframe-embed', WPMU_PLUGIN_URL . '/jetpack-iframe-embed/jetpack-iframe-embed.js', array( 'jquery' ) ); + wp_enqueue_script( + 'jetpack-iframe-embed', + WPMU_PLUGIN_URL . '/jetpack-iframe-embed/jetpack-iframe-embed.js', + array( 'jquery' ), + $ver, + false + ); } else { - $ver = sprintf( '%s-%s', gmdate( 'oW' ), defined( 'JETPACK__VERSION' ) ? JETPACK__VERSION : '' ); - wp_enqueue_script( 'jetpack-iframe-embed', '//s0.wp.com/wp-content/mu-plugins/jetpack-iframe-embed/jetpack-iframe-embed.js', array( 'jquery' ), $ver ); + wp_enqueue_script( + 'jetpack-iframe-embed', + '//s0.wp.com/wp-content/mu-plugins/jetpack-iframe-embed/jetpack-iframe-embed.js', + array( 'jquery' ), + $ver, + false + ); } wp_localize_script( 'jetpack-iframe-embed', '_previewSite', array( 'siteURL' => get_site_url() ) ); } - static function is_embedding_in_iframe() { + /** + * Check that we are in an iFrame. + * + * @return bool + */ + private static function is_embedding_in_iframe() { return ( - self::has_iframe_get_param() && ( - self::has_preview_get_param() || - self::has_preview_theme_preview_param() + // phpcs:disable WordPress.Security.NonceVerification.Recommended -- No nonce needed, we're only checking for a specific screen view. + isset( $_GET['iframe'] ) && 'true' === $_GET['iframe'] + && ( + isset( $_GET['preview'] ) && 'true' === $_GET['preview'] + || isset( $_GET['theme_preview'] ) && 'true' === $_GET['theme_preview'] ) + // phpcs:enable WordPress.Security.NonceVerification.Recommended ); } - private static function has_iframe_get_param() { - return isset( $_GET['iframe'] ) && $_GET['iframe'] === 'true'; - } - - private static function has_preview_get_param() { - return isset( $_GET['preview'] ) && $_GET['preview'] === 'true'; - } - - private static function has_preview_theme_preview_param() { - return isset( $_GET['theme_preview'] ) && $_GET['theme_preview'] === 'true'; - } - /** * Disable `autoplay` shortcode attribute in context of an iframe * Added via `shortcode_atts_video` & `shortcode_atts_audio` in `init` @@ -61,7 +81,7 @@ class Jetpack_Iframe_Embed { * * @return array The output array of shortcode attributes. */ - static function disable_autoplay( $atts ) { + public static function disable_autoplay( $atts ) { return array_merge( $atts, array( 'autoplay' => false ) ); } @@ -69,7 +89,7 @@ class Jetpack_Iframe_Embed { * We don't want search engines to index iframe previews * Added via `wp_head` action in `init` */ - static function noindex() { + public static function noindex() { echo '<meta name="robots" content="noindex,nofollow" />'; } @@ -78,7 +98,7 @@ class Jetpack_Iframe_Embed { * (unless overridden on client-side by JS) * Added via `wp_head` action in `init` */ - static function base_target_blank() { + public static function base_target_blank() { echo '<base target="_blank" />'; } } |