Server : Apache System : Linux pod-100823:apache2_74:v0.5.7 5.4.0-1138-gcp #147~18.04.1-Ubuntu SMP Mon Oct 7 21:46:26 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33.7 Disable Function : apache_child_terminate,apache_get_modules,apache_get_version,apache_getenv,apache_note,apache_setenv,disk_free_space,disk_total_space,diskfreespace,dl,exec,fastcgi_finish_request,link,opcache_compile_file,opcache_get_configuration,opcache_invalidate,opcache_is_script_cached,opcache_reset,passthru,pclose,pcntl_exec,popen,posix_getpid,posix_getppid,posix_getpwuid,posix_kill,posix_mkfifo,posix_setegid,posix_seteuid,posix_setgid,posix_setpgid,posix_setsid,posix_setuid,posix_uname,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,realpath_cache_get,shell_exec,show_source,symlink,system Directory : /nas/content/live/attorneyexperi/wp-content/plugins/diva/src/ |
<?php /** * Class ObsoleteBlockAttributeRemover. * * @package AmpProject\AmpWP */ namespace AmpProject\AmpWP; use AmpProject\AmpWP\Infrastructure\Delayed; use AmpProject\AmpWP\Infrastructure\Registerable; use AmpProject\AmpWP\Infrastructure\Service; use WP_REST_Response; /** * Removes obsolete data-amp-* attributes from block markup in post content. * * These HTML attributes serve as processing instructions to control how the sanitizers handle converting HTML to AMP. * For each HTML attribute there is also a block attribute, so if there is a data-amp-carousel HTML attribute then there * is also an ampCarousel block attribute. The block attributes were originally mirrored onto the HTML attributes because * the 'render_block' filter was not available in Gutenberg (or WordPress Core) when this was first implemented; now that * this filter is available, there is no need to duplicate/mirror the attributes, and so they are injected into the * root HTML element via `AMP_Core_Block_Handler::filter_rendered_block()`. In hindsight, instead of having the data * mirrored between block attributes and HTML attributes, the block attributes should have perhaps used an 'attribute' * as the block attribute 'source'. Then again, that may have complicated things yet further to migrate away from using * these data attributes. A key reason for why these HTML data-* attributes are bad is that they cause block validation * errors. If someone creates a Gallery block and enables a carousel, then if they go and deactivate the AMP plugin, * this block will then show as having a block validation error. If, however, we restrict the block attributes to only * be in the block comment, then no block validation errors occur. Also, since the 'render_block' filter is now * available, the reason for storing these block attributes as data-amp-* HTML attributes in post_content is now obsolete. * * @see AMP_Core_Block_Handler::filter_rendered_block() * @see AMP_Gallery_Block_Sanitizer * @link https://github.com/ampproject/amp-wp/pull/4775 * * @package AmpProject\AmpWP * @since 2.0 * @internal */ final class ObsoleteBlockAttributeRemover implements Service, Registerable, Delayed { /** * Obsolete attributes. * * @var string[] */ const OBSOLETE_ATTRIBUTES = [ 'data-amp-carousel', 'data-amp-layout', 'data-amp-lightbox', 'data-amp-noloading', ]; /** * Get registration action. * * @return string */ public static function get_registration_action() { return 'rest_api_init'; } /** * Register the service with the system. * * @return void */ public function register() { foreach ( get_post_types_by_support( 'editor' ) as $post_type ) { add_filter( "rest_prepare_{$post_type}", [ $this, 'filter_rest_prepare_post' ] ); } } /** * Get obsolete attribute regular expression to match the obsolete attribute key/value pair in an HTML start tag.. * * @return string Regular expression pattern. */ protected function get_obsolete_attribute_pattern() { static $pattern = null; if ( ! $pattern ) { $pattern = sprintf( '/\s(%s)="[^"]*+"/', implode( '|', self::OBSOLETE_ATTRIBUTES ) ); } return $pattern; } /** * Filter post response object to purge obsolete attributes from the raw content. * * @param WP_REST_Response $response Response. * @return WP_REST_Response Response. */ public function filter_rest_prepare_post( WP_REST_Response $response ) { if ( isset( $response->data['content']['raw'] ) ) { $response->data['content']['raw'] = preg_replace_callback( '#(?P<block_comment>(?><!--\s*+wp:\w+.*?-->)\s*+)(?P<start_tag><[a-z][a-z0-9_:-]*+\s[^>]*+>)#s', function ( $matches ) { return $matches['block_comment'] . preg_replace( $this->get_obsolete_attribute_pattern(), '', $matches['start_tag'] ); }, $response->data['content']['raw'] ); } return $response; } }