630 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			630 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
namespace WpAssetCleanUp;
 | 
						|
 | 
						|
use WpAssetCleanUp\OptimiseAssets\OptimizeCommon;
 | 
						|
 | 
						|
/**
 | 
						|
 * Class CleanUp
 | 
						|
 * @package WpAssetCleanUp
 | 
						|
 */
 | 
						|
class CleanUp
 | 
						|
{
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function init()
 | 
						|
	{
 | 
						|
		// Is "Test Mode" is enabled and the page is viewed by a regular visitor (not administrator with plugin activation privileges)?
 | 
						|
		// Stop here as the script will NOT PREVENT any of the elements below to load
 | 
						|
		// They will load as they used to for the regular visitor while the admin debugs the website
 | 
						|
		add_action('init', array($this, 'doClean'), 12);
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function doClean()
 | 
						|
	{
 | 
						|
		if ( ! method_exists( '\WpAssetCleanUp\Plugin', 'preventAnyFrontendOptimization' ) ) {
 | 
						|
			return; // something's funny as, for some reason, on very rare occasions, the class is not found, so don't continue
 | 
						|
		}
 | 
						|
 | 
						|
		if ( (defined('WPACU_ALLOW_ONLY_UNLOAD_RULES') && WPACU_ALLOW_ONLY_UNLOAD_RULES) || Main::instance()->preventAssetsSettings() || Plugin::preventAnyFrontendOptimization() ) {
 | 
						|
			return;
 | 
						|
		}
 | 
						|
 | 
						|
		$settings = Main::instance()->settings;
 | 
						|
 | 
						|
		// Remove "Really Simple Discovery (RSD)" link?
 | 
						|
		if ($settings['remove_rsd_link'] == 1 || $settings['disable_xmlrpc'] === 'disable_all') {
 | 
						|
			// <link rel="EditURI" type="application/rsd+xml" title="RSD" href="https://yourwebsite.com/xmlrpc.php?rsd" />
 | 
						|
			remove_action('wp_head', 'rsd_link');
 | 
						|
		}
 | 
						|
 | 
						|
		// Remove "Windows Live Writer" link?
 | 
						|
		if ($settings['remove_wlw_link'] == 1) {
 | 
						|
			// <link rel="wlwmanifest" type="application/wlwmanifest+xml" href="http://yourwebsite.com/wp-includes/wlwmanifest.xml">
 | 
						|
			remove_action('wp_head', 'wlwmanifest_link');
 | 
						|
		}
 | 
						|
 | 
						|
		// Remove "REST API" link?
 | 
						|
		if ($settings['remove_rest_api_link'] == 1) {
 | 
						|
			// <link rel='https://api.w.org/' href='https://yourwebsite.com/wp-json/' />
 | 
						|
			remove_action('wp_head', 'rest_output_link_wp_head');
 | 
						|
 | 
						|
			// Removes the following printed within "Response headers":
 | 
						|
			// <https://yourwebsite.com/wp-json/>; rel="https://api.w.org/"
 | 
						|
			remove_action( 'template_redirect', 'rest_output_link_header', 11 );
 | 
						|
		}
 | 
						|
 | 
						|
		// Remove "Shortlink"?
 | 
						|
		if ($settings['remove_shortlink'] == 1) {
 | 
						|
			// <link rel='shortlink' href="https://yourdomain.com/?p=1">
 | 
						|
			remove_action('wp_head', 'wp_shortlink_wp_head');
 | 
						|
 | 
						|
			// link: <https://yourdomainname.com/wp-json/>; rel="https://api.w.org/", <https://yourdomainname.com/?p=[post_id_here]>; rel=shortlink
 | 
						|
			remove_action('template_redirect', 'wp_shortlink_header', 11);
 | 
						|
		}
 | 
						|
 | 
						|
		// Remove "Post's Relational Links"?
 | 
						|
		if ($settings['remove_posts_rel_links'] == 1) {
 | 
						|
			// <link rel='prev' title='Title of adjacent post' href='https://yourdomain.com/adjacent-post-slug-here/' />
 | 
						|
			remove_action('wp_head', 'adjacent_posts_rel_link_wp_head');
 | 
						|
		}
 | 
						|
 | 
						|
		// Remove "WordPress version" tag?
 | 
						|
		if ($settings['remove_wp_version']) {
 | 
						|
			// <meta name="generator" content="WordPress 4.9.8" />
 | 
						|
			remove_action('wp_head', 'wp_generator');
 | 
						|
 | 
						|
			// also hide it from RSS
 | 
						|
			add_filter('the_generator', '__return_false');
 | 
						|
		}
 | 
						|
 | 
						|
		if ($settings['disable_rss_feed']) {
 | 
						|
			$this->doDisableRssFeed();
 | 
						|
		}
 | 
						|
 | 
						|
		// Remove Main RSS Feed Link?
 | 
						|
		if ($settings['remove_main_feed_link']) {
 | 
						|
			add_filter('feed_links_show_posts_feed', '__return_false');
 | 
						|
			remove_action('wp_head', 'feed_links_extra', 3);
 | 
						|
		}
 | 
						|
 | 
						|
		// Remove Comment RSS Feed Link?
 | 
						|
		if ($settings['remove_comment_feed_link']) {
 | 
						|
			add_filter('feed_links_show_comments_feed', '__return_false');
 | 
						|
		}
 | 
						|
 | 
						|
		// Disable XML-RPC protocol support (partially or completely)
 | 
						|
		if (in_array($settings['disable_xmlrpc'], array('disable_all', 'disable_pingback'))) {
 | 
						|
			// Partially or Completely Options / Pingback will be disabled
 | 
						|
			$this->disableXmlRpcPingback();
 | 
						|
 | 
						|
			// Complete disable the service
 | 
						|
			if ($settings['disable_xmlrpc'] === 'disable_all') {
 | 
						|
				add_filter('xmlrpc_enabled', '__return_false');
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Called in OptimiseAssets/OptimizeCommon.php
 | 
						|
	 *
 | 
						|
	 * @param $htmlSource
 | 
						|
	 *
 | 
						|
	 * @return string|string[]|null
 | 
						|
	 */
 | 
						|
	public static function cleanPingbackLinkRel($htmlSource)
 | 
						|
	{
 | 
						|
		$pingBackUrl = get_bloginfo('pingback_url');
 | 
						|
 | 
						|
		$matchRegExps = array(
 | 
						|
			'#<link rel=("|\')pingback("|\') href=("|\')'.$pingBackUrl.'("|\')( /|)>#',
 | 
						|
			'#<link href=("|\')'.$pingBackUrl.'("|\') rel=("|\')pingback("|\')( /|)>#'
 | 
						|
		);
 | 
						|
 | 
						|
		foreach ($matchRegExps as $matchRegExp) {
 | 
						|
			$htmlSource = preg_replace($matchRegExp, '', $htmlSource);
 | 
						|
		}
 | 
						|
 | 
						|
		return $htmlSource;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function disableXmlRpcPingback()
 | 
						|
	{
 | 
						|
		// Disable Pingback method
 | 
						|
		add_filter('xmlrpc_methods', static function ($methods) {
 | 
						|
			unset($methods['pingback.ping'], $methods['pingback.extensions.getPingbacks']);
 | 
						|
			return $methods;
 | 
						|
		} );
 | 
						|
 | 
						|
		// Remove X-Pingback HTTP header
 | 
						|
		add_filter('wp_headers', static function ($headers) {
 | 
						|
			unset($headers['X-Pingback']);
 | 
						|
			return $headers;
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @param $htmlSource
 | 
						|
	 *
 | 
						|
	 * @return mixed
 | 
						|
	 */
 | 
						|
	public static function removeMetaGenerators($htmlSource)
 | 
						|
	{
 | 
						|
		$fetchMethod = 'dom'; // 'regex' or 'dom'
 | 
						|
 | 
						|
		if ( $fetchMethod === 'dom' && Misc::isDOMDocumentOn() && $htmlSource ) {
 | 
						|
			$domTag = OptimizeCommon::getDomLoadedTag($htmlSource, 'removeMetaGenerators');
 | 
						|
 | 
						|
			$metaTagsToStrip = array();
 | 
						|
 | 
						|
			foreach ( $domTag->getElementsByTagName( 'meta' ) as $tagObject ) {
 | 
						|
				$nameAttrValue = $tagObject->getAttribute( 'name' );
 | 
						|
 | 
						|
				if ( $nameAttrValue === 'generator' ) {
 | 
						|
					$outerTag = $outerTagRegExp = trim( Misc::getOuterHTML( $tagObject ) );
 | 
						|
 | 
						|
					// As DOMDocument doesn't retrieve the exact string, some alterations to the RegEx have to be made
 | 
						|
					// Leave no room for errors as all sort of characters can be within the "content" attribute
 | 
						|
					$last2Chars = substr( $outerTag, - 2 );
 | 
						|
 | 
						|
					if ( $last2Chars === '">' || $last2Chars === "'>" ) {
 | 
						|
						$tagWithoutLastChar = substr( $outerTag, 0, - 1 );
 | 
						|
						$outerTagRegExp     = preg_quote( $tagWithoutLastChar, '/' ) . '(.*?)>';
 | 
						|
					}
 | 
						|
 | 
						|
					$outerTagRegExp = str_replace(
 | 
						|
						array( '"', '<', '>' ),
 | 
						|
						array( '("|\'|)', '(<|<)', '(>|>)' ),
 | 
						|
						$outerTagRegExp
 | 
						|
					);
 | 
						|
 | 
						|
					if ( strpos( $outerTagRegExp, '<meta' ) !== false ) {
 | 
						|
						$outerTagRegExp = str_replace('#', '\#', $outerTagRegExp);
 | 
						|
						preg_match_all( '#' . $outerTagRegExp . '#si', $htmlSource, $matches );
 | 
						|
 | 
						|
						if ( isset( $matches[0][0] ) && ! empty( $matches[0][0] ) && strip_tags( $matches[0][0] ) === '' ) {
 | 
						|
							$metaTagsToStrip[$matches[0][0]] = '';
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			$htmlSource = strtr($htmlSource, $metaTagsToStrip);
 | 
						|
 | 
						|
			libxml_clear_errors();
 | 
						|
		}
 | 
						|
 | 
						|
		/* [wpacu_timing] */ Misc::scriptExecTimer( 'alter_html_source_for_remove_meta_generators', 'end' ); /* [/wpacu_timing] */
 | 
						|
		return $htmlSource;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @param $htmlSource
 | 
						|
	 * @param bool $ignoreExceptions
 | 
						|
	 * @param $for
 | 
						|
	 *
 | 
						|
	 * @return string|string[]
 | 
						|
	 */
 | 
						|
	public static function removeHtmlComments($htmlSource, $ignoreExceptions = false)
 | 
						|
	{
 | 
						|
		if ( strpos($htmlSource, '<!--') === false || ! Misc::isDOMDocumentOn() ) {
 | 
						|
			return $htmlSource;
 | 
						|
		}
 | 
						|
 | 
						|
		$domTag = OptimizeCommon::getDomLoadedTag($htmlSource, 'removeHtmlComments');
 | 
						|
 | 
						|
		if (! $domTag) {
 | 
						|
			return $htmlSource;
 | 
						|
		}
 | 
						|
 | 
						|
		$xpathComments = new \DOMXPath($domTag);
 | 
						|
		$comments = $xpathComments->query('//comment()');
 | 
						|
 | 
						|
		libxml_clear_errors();
 | 
						|
 | 
						|
		if ($comments === null) {
 | 
						|
			return $htmlSource;
 | 
						|
		}
 | 
						|
 | 
						|
		preg_match_all('#<!--(.*?)-->#s', $htmlSource, $matchesRegExpComments);
 | 
						|
 | 
						|
		// "comments" within tag attributes or script tags?
 | 
						|
		// e.g. <script>var type='<!-- A comment here -->';</script>
 | 
						|
		// e.g. <div data-info="This is just a <!-- comment --> text">Content here</div>
 | 
						|
		$commentsWithinQuotes = array();
 | 
						|
 | 
						|
		if (isset($matchesRegExpComments[1]) && count($matchesRegExpComments[1]) !== count($comments)) {
 | 
						|
			preg_match_all('#=(|\s+)([\'"])(|\s+)<!--(.*?)-->(|\s+)([\'"])#s', $htmlSource, $matchesCommentsWithinQuotes);
 | 
						|
 | 
						|
			if (isset($matchesCommentsWithinQuotes[0]) && ! empty($matchesCommentsWithinQuotes[0])) {
 | 
						|
				foreach ($matchesCommentsWithinQuotes[0] as $matchedDataOriginal) {
 | 
						|
					$matchedDataUpdated = str_replace(
 | 
						|
						array('', '<!--', '-->'),
 | 
						|
						array('--wpacu-space-del--', '--wpacu-start-comm--', '--wpacu-end-comm--'),
 | 
						|
						$matchedDataOriginal
 | 
						|
					);
 | 
						|
 | 
						|
					$htmlSource = str_replace($matchedDataOriginal, $matchedDataUpdated, $htmlSource);
 | 
						|
 | 
						|
					$commentsWithinQuotes[] = array(
 | 
						|
						'original' => $matchedDataOriginal,
 | 
						|
						'updated'  => $matchedDataUpdated
 | 
						|
					);
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		$stripCommentsList = array();
 | 
						|
 | 
						|
		foreach ($comments as $comment) {
 | 
						|
			$entireComment = '<!--' . $comment->nodeValue . '-->';
 | 
						|
 | 
						|
			// Do not strip MSIE conditional comments
 | 
						|
			if ( strpos( $entireComment, '<!--<![endif]-->' ) !== false ||
 | 
						|
			     preg_match( '#<!--\[if(.*?)]>(.*?)<!-->#si', $entireComment ) ||
 | 
						|
			     preg_match( '#<!--\[if(.*?)\[endif]-->#si', $entireComment ) ) {
 | 
						|
				continue;
 | 
						|
			}
 | 
						|
 | 
						|
			// Any exceptions set in "Strip HTML comments?" textarea?
 | 
						|
			// $ignoreExceptions has to be set to false (as it is by default)
 | 
						|
			if (! $ignoreExceptions && Main::instance()->settings['remove_html_comments_exceptions']) {
 | 
						|
				$removeHtmlCommentsExceptions = trim(Main::instance()->settings['remove_html_comments_exceptions']);
 | 
						|
 | 
						|
				if (strpos($removeHtmlCommentsExceptions, "\n") !== false) {
 | 
						|
					foreach (explode("\n", $removeHtmlCommentsExceptions) as $removeCommExceptionPattern) {
 | 
						|
						$removeCommExceptionPattern = trim($removeCommExceptionPattern);
 | 
						|
 | 
						|
						if (stripos($entireComment, $removeCommExceptionPattern) !== false) {
 | 
						|
							continue 2;
 | 
						|
						}
 | 
						|
					}
 | 
						|
				} elseif (stripos($entireComment, $removeHtmlCommentsExceptions) !== false) {
 | 
						|
					continue;
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			if (strlen($entireComment) < 200) {
 | 
						|
				$stripCommentsList[ $entireComment ] = '';
 | 
						|
			} else {
 | 
						|
				$htmlSource = str_replace($entireComment, '', $htmlSource);
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		if (! empty($stripCommentsList)) {
 | 
						|
			$htmlSource = strtr( $htmlSource, $stripCommentsList );
 | 
						|
		}
 | 
						|
 | 
						|
		if (! empty($commentsWithinQuotes)) {
 | 
						|
			foreach ($commentsWithinQuotes as $commentQuote) {
 | 
						|
				$htmlSource = str_replace($commentQuote['updated'], $commentQuote['original'], $htmlSource);
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		return $htmlSource;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @param $strContains
 | 
						|
	 * @param $htmlSource
 | 
						|
	 *
 | 
						|
	 * @return mixed
 | 
						|
	 */
 | 
						|
	public static function cleanLinkTagFromHtmlSource($strContains, $htmlSource)
 | 
						|
	{
 | 
						|
		if (! is_array($strContains)) {
 | 
						|
			$strContains = array($strContains);
 | 
						|
		}
 | 
						|
 | 
						|
		$strContains = array_map(function($value) {
 | 
						|
			if (strpos($value, 'data-wpacu-style-handle') !== false) {
 | 
						|
				return $value; // no need to use preg-quote
 | 
						|
			}
 | 
						|
 | 
						|
			return preg_quote($value, '/');
 | 
						|
		}, $strContains);
 | 
						|
 | 
						|
		preg_match_all(
 | 
						|
			'#<link[^>]*('.implode('|', $strContains).')[^>].*(>)#Usmi',
 | 
						|
			$htmlSource,
 | 
						|
			$matchesSourcesFromTags
 | 
						|
		);
 | 
						|
 | 
						|
		if (empty($matchesSourcesFromTags)) {
 | 
						|
			return $htmlSource;
 | 
						|
		}
 | 
						|
 | 
						|
		foreach ($matchesSourcesFromTags as $matchesFromTag) {
 | 
						|
			if (! (isset($matchesFromTag[0]) && $matchesFromTag[0])) {
 | 
						|
				continue;
 | 
						|
			}
 | 
						|
 | 
						|
			$linkTag = $matchesFromTag[0];
 | 
						|
 | 
						|
			if (stripos($linkTag, '<link') === 0 && substr($linkTag, -1) === '>' && strip_tags($linkTag) === '') {
 | 
						|
				$htmlSource = str_replace($linkTag, '', $htmlSource);
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		return $htmlSource;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @param $strContains
 | 
						|
	 * @param $htmlSource
 | 
						|
	 *
 | 
						|
	 * @return mixed
 | 
						|
	 */
 | 
						|
	public static function cleanScriptTagFromHtmlSource($strContains, $htmlSource)
 | 
						|
	{
 | 
						|
		if (! is_array($strContains)) {
 | 
						|
			$strContains = array($strContains);
 | 
						|
		}
 | 
						|
 | 
						|
		$strContains = array_map(function($value) {
 | 
						|
			if (strpos($value, 'data-wpacu-script-handle') !== false) {
 | 
						|
				return $value; // no need to use preg-quote
 | 
						|
			}
 | 
						|
 | 
						|
			return preg_quote($value, '/');
 | 
						|
		}, $strContains);
 | 
						|
 | 
						|
		preg_match_all(
 | 
						|
			'#<script[^>]*('.implode('|', $strContains).')[^>].*(>)#Usmi',
 | 
						|
			$htmlSource,
 | 
						|
			$matchesSourcesFromTags
 | 
						|
		);
 | 
						|
 | 
						|
		if (empty($matchesSourcesFromTags)) {
 | 
						|
			return $htmlSource;
 | 
						|
		}
 | 
						|
 | 
						|
		foreach ($matchesSourcesFromTags as $matchesFromTag) {
 | 
						|
			if (isset($matchesFromTag[0]) && $matchesFromTag[0] && strip_tags($matchesFromTag[0]) === '') {
 | 
						|
				$htmlSource = str_replace($matchesFromTag[0] . '</script>', '', $htmlSource);
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		return $htmlSource;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function doDisableEmojis()
 | 
						|
	{
 | 
						|
		// Emojis Actions and Filters
 | 
						|
		remove_action('admin_print_styles', 'print_emoji_styles');
 | 
						|
		remove_action('wp_head', 'print_emoji_detection_script', 7);
 | 
						|
		remove_action('admin_print_scripts', 'print_emoji_detection_script');
 | 
						|
		remove_action('wp_print_styles', 'print_emoji_styles');
 | 
						|
 | 
						|
		remove_filter('wp_mail', 'wp_staticize_emoji_for_email');
 | 
						|
		remove_filter('the_content_feed', 'wp_staticize_emoji');
 | 
						|
		remove_filter('comment_text_rss', 'wp_staticize_emoji');
 | 
						|
 | 
						|
		// TinyMCE Emojis
 | 
						|
		add_filter('tiny_mce_plugins', array($this, 'removeEmojisTinymce'));
 | 
						|
 | 
						|
		add_filter('emoji_svg_url', '__return_false');
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @param $plugins
 | 
						|
	 *
 | 
						|
	 * @return array
 | 
						|
	 */
 | 
						|
	public function removeEmojisTinymce($plugins)
 | 
						|
	{
 | 
						|
		if (is_array($plugins)) {
 | 
						|
			return array_diff($plugins, array('wpemoji'));
 | 
						|
		}
 | 
						|
 | 
						|
		return array();
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function doDisableOembed()
 | 
						|
	{
 | 
						|
		add_action('init', static function() {
 | 
						|
			// Remove the REST API endpoint.
 | 
						|
			remove_action('rest_api_init', 'wp_oembed_register_route');
 | 
						|
 | 
						|
			// Turn off oEmbed auto discovery.
 | 
						|
			add_filter('embed_oembed_discover', '__return_false');
 | 
						|
 | 
						|
			// Don't filter oEmbed results.
 | 
						|
			remove_filter('oembed_dataparse', 'wp_filter_oembed_result');
 | 
						|
 | 
						|
			// 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');
 | 
						|
 | 
						|
			add_filter('tiny_mce_plugins', static function ($plugins) {
 | 
						|
				return array_diff($plugins, array('wpembed'));
 | 
						|
			});
 | 
						|
 | 
						|
			// Remove all embeds rewrite rules.
 | 
						|
			add_filter('rewrite_rules_array', static function ($rules) {
 | 
						|
				if ( ! empty($rules) ) {
 | 
						|
					foreach ( $rules as $rule => $rewrite ) {
 | 
						|
						if ( is_string($rewrite) && false !== strpos( $rewrite, 'embed=true' ) ) {
 | 
						|
							unset( $rules[ $rule ] );
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
				return $rules;
 | 
						|
			});
 | 
						|
 | 
						|
			// Remove filter of the oEmbed result before any HTTP requests are made.
 | 
						|
			remove_filter('pre_oembed_result', 'wp_filter_pre_oembed_result');
 | 
						|
		}, 9999 );
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function doDisableRssFeed()
 | 
						|
	{
 | 
						|
		add_action('do_feed',               array($this, 'disabledRssFeedMsg'), 1);
 | 
						|
		add_action('do_feed_rdf',           array($this, 'disabledRssFeedMsg'), 1);
 | 
						|
		add_action('do_feed_rss',           array($this, 'disabledRssFeedMsg'), 1);
 | 
						|
		add_action('do_feed_rss2',          array($this, 'disabledRssFeedMsg'), 1);
 | 
						|
		add_action('do_feed_atom',          array($this, 'disabledRssFeedMsg'), 1);
 | 
						|
		add_action('do_feed_rss2_comments', array($this, 'disabledRssFeedMsg'), 1);
 | 
						|
		add_action('do_feed_atom_comments', array($this, 'disabledRssFeedMsg'), 1);
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function disabledRssFeedMsg()
 | 
						|
	{
 | 
						|
		$wpacuSettings = new Settings();
 | 
						|
		$settingsArray = $wpacuSettings->getAll();
 | 
						|
 | 
						|
		$feedDisableMsg = isset($settingsArray['disable_rss_feed_message']) ? $settingsArray['disable_rss_feed_message'] : '';
 | 
						|
 | 
						|
		wp_die( __($feedDisableMsg, 'wp-asset-clean-up') );
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public function cleanUpHtmlOutputForAssetsCall()
 | 
						|
	{
 | 
						|
		if (isset($_GET['wpacu_clean_load'])) {
 | 
						|
			// No Admin Bar
 | 
						|
			add_filter('show_admin_bar', '__return_false', PHP_INT_MAX);
 | 
						|
		}
 | 
						|
 | 
						|
		// No Autoptimize
 | 
						|
		if (! defined('AUTOPTIMIZE_NOBUFFER_OPTIMIZE')) {
 | 
						|
			define( 'AUTOPTIMIZE_NOBUFFER_OPTIMIZE', true );
 | 
						|
		}
 | 
						|
		add_filter('autoptimize_filter_noptimize', '__return_false');
 | 
						|
 | 
						|
		// Use less resources during CSS/JS fetching by preventing other plugins to interfere with the HTML output as it's completely unnecessary in this instance
 | 
						|
		if (Misc::isPluginActive('autoptimize/autoptimize.php')) {
 | 
						|
			foreach (array('autoptimize_html', 'autoptimize_css', 'autoptimize_js', 'autoptimize_cdn_url', 'autoptimize_optimize_logged') as $aoOption) {
 | 
						|
				add_filter('pre_option_'.$aoOption, static function($value) { return ''; });
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		// No Fast Velocity Minify
 | 
						|
		add_action('plugins_loaded', static function() {
 | 
						|
			remove_action( 'setup_theme', 'fastvelocity_process_frontend' );
 | 
						|
		}, PHP_INT_MAX);
 | 
						|
 | 
						|
		// No WP Rocket (Minify / Concatenate)
 | 
						|
		add_filter( 'get_rocket_option_minify_css',             '__return_false' );
 | 
						|
		add_filter( 'get_rocket_option_minify_concatenate_css', '__return_false' );
 | 
						|
 | 
						|
		add_filter( 'get_rocket_option_minify_js',              '__return_false' );
 | 
						|
		add_filter( 'get_rocket_option_minify_concatenate_js',  '__return_false' );
 | 
						|
 | 
						|
		// No W3 Total Cache: Minify
 | 
						|
		add_filter('w3tc_minify_enable', '__return_false');
 | 
						|
 | 
						|
		// [NO SG Optimiser]
 | 
						|
		self::filterSGOptions();
 | 
						|
 | 
						|
		// Emulate page builder param to view page with no SG Optimiser on request
 | 
						|
		// Extra params to be used in case 'SG Optimiser' is called before Asset CleanUp: 'fl_builder', 'vcv-action', 'et_fb', 'ct_builder', 'tve'
 | 
						|
		add_filter('sgo_pb_params', static function($pbParams) {
 | 
						|
			$pbParams[] = WPACU_LOAD_ASSETS_REQ_KEY; // fetching assets
 | 
						|
			$pbParams[] = 'wpacu_clean_load'; // loading the page unoptimized for debugging purposes
 | 
						|
			return $pbParams;
 | 
						|
		});
 | 
						|
 | 
						|
		// Fallback in case SG Optimizer is triggered BEFORE Asset CleanUp and the filter above will not work
 | 
						|
		add_filter('sgo_css_combine_exclude', array($this, 'allCssHandles'));
 | 
						|
		add_filter('sgo_css_minify_exclude',  array($this, 'allCssHandles'));
 | 
						|
		add_filter('sgo_js_minify_exclude',   array($this, 'allJsHandles'));
 | 
						|
		add_filter('sgo_js_async_exclude',    array($this, 'allJsHandles'));
 | 
						|
 | 
						|
		add_filter('sgo_html_minify_exclude_params', static function ($excludeParams) {
 | 
						|
			$excludeParams[] = WPACU_LOAD_ASSETS_REQ_KEY; // fetching assets
 | 
						|
			$excludeParams[] = 'wpacu_clean_load'; // loading the page unoptimized for debugging purposes
 | 
						|
			return $excludeParams;
 | 
						|
		});
 | 
						|
		// [/NO SG Optimiser]
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 *
 | 
						|
	 */
 | 
						|
	public static function filterSGOptions()
 | 
						|
	{
 | 
						|
		// SG Optimizer Plugin
 | 
						|
		$sgOptimizerMapping = array(
 | 
						|
			'autoflush'            => 'siteground_optimizer_autoflush_cache',
 | 
						|
			'dynamic-cache'        => 'siteground_optimizer_enable_cache',
 | 
						|
			'memcache'             => 'siteground_optimizer_enable_memcached',
 | 
						|
			'ssl-fix'              => 'siteground_optimizer_fix_insecure_content',
 | 
						|
			'html'                 => 'siteground_optimizer_optimize_html',
 | 
						|
			'js'                   => 'siteground_optimizer_optimize_javascript',
 | 
						|
			'js-async'             => 'siteground_optimizer_optimize_javascript_async',
 | 
						|
			'css'                  => 'siteground_optimizer_optimize_css',
 | 
						|
			'combine-css'          => 'siteground_optimizer_combine_css',
 | 
						|
			'querystring'          => 'siteground_optimizer_remove_query_strings',
 | 
						|
			'emojis'               => 'siteground_optimizer_disable_emojis',
 | 
						|
			'images'               => 'siteground_optimizer_optimize_images',
 | 
						|
			'lazyload_images'      => 'siteground_optimizer_lazyload_images',
 | 
						|
			'lazyload_gravatars'   => 'siteground_optimizer_lazyload_gravatars',
 | 
						|
			'lazyload_thumbnails'  => 'siteground_optimizer_lazyload_thumbnails',
 | 
						|
			'lazyload_responsive'  => 'siteground_optimizer_lazyload_responsive',
 | 
						|
			'lazyload_textwidgets' => 'siteground_optimizer_lazyload_textwidgets',
 | 
						|
			'ssl'                  => 'siteground_optimizer_ssl_enabled',
 | 
						|
			'gzip'                 => 'siteground_optimizer_enable_gzip_compression',
 | 
						|
			'browser-caching'      => 'siteground_optimizer_enable_browser_caching',
 | 
						|
		);
 | 
						|
 | 
						|
		foreach ($sgOptimizerMapping as $optionName) {
 | 
						|
			add_filter('pre_option_'.$optionName, '__return_false');
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @return array
 | 
						|
	 */
 | 
						|
	public function allCssHandles()
 | 
						|
	{
 | 
						|
		global $wp_styles;
 | 
						|
 | 
						|
		$allCssHandles = array();
 | 
						|
 | 
						|
		if (isset($wp_styles->registered) && ! empty($wp_styles->registered)) {
 | 
						|
			$allCssHandles = array_keys($wp_styles->registered);
 | 
						|
		}
 | 
						|
 | 
						|
		return $allCssHandles;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @return array
 | 
						|
	 */
 | 
						|
	public function allJsHandles()
 | 
						|
	{
 | 
						|
		global $wp_scripts;
 | 
						|
 | 
						|
		$allJsHandles = array();
 | 
						|
 | 
						|
		if (isset($wp_scripts->registered) && ! empty($wp_scripts->registered)) {
 | 
						|
			$allJsHandles = array_keys($wp_scripts->registered);
 | 
						|
		}
 | 
						|
 | 
						|
		return $allJsHandles;
 | 
						|
	}
 | 
						|
}
 |