From 83702dac0f251ae7556d97e510b936a1c836e284 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Michael=20S=C3=B8rensen?= Date: Fri, 23 Dec 2016 11:36:49 +0100 Subject: [PATCH] First commit --- README.md | 2 + composer.json | 27 +++++++ remove-monsterinsights-tracking.php | 109 ++++++++++++++++++++++++++++ 3 files changed, 138 insertions(+) create mode 100644 README.md create mode 100644 composer.json create mode 100644 remove-monsterinsights-tracking.php diff --git a/README.md b/README.md new file mode 100644 index 0000000..8b1e05c --- /dev/null +++ b/README.md @@ -0,0 +1,2 @@ +# wp-remove-tracking +Remove some tracking from monster insights wordpress plugin diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..0e394ec --- /dev/null +++ b/composer.json @@ -0,0 +1,27 @@ +{ + "name": "benjaminmedia/wp-remove-tracking", + "description": "Remove some tracking from MonsterInsights", + "type": "wordpress-plugin", + "keywords": ["wordpress", "plugin"], + "homepage": "https://github.com/BenjaminMedia/wp-remove-tracking", + "repositories":[ + { + "type": "composer", + "url": "http://wpackagist.org" + } + ], + "authors": [ + { + "name": "Bonnier Publications", + "email": "interactive@bonnier.dk", + "homepage": "http://bonnierpublications.com" + } + ], + "support": { + "issues": "https://github.com/BenjaminMedia/wp-remove-tracking/issues", + "source": "https://github.com/BenjaminMedia/wp-remove-tracking" + }, + "require": { + "php": ">=5.6" + } +} diff --git a/remove-monsterinsights-tracking.php b/remove-monsterinsights-tracking.php new file mode 100644 index 0000000..f0efd4b --- /dev/null +++ b/remove-monsterinsights-tracking.php @@ -0,0 +1,109 @@ +callbacks ) ) { + $callbacks = &$wp_filter[ $tag ]->callbacks; + } else { + $callbacks = &$wp_filter[ $tag ]; + } + // Exit if there aren't any callbacks for specified priority + if ( ! isset( $callbacks[ $priority ] ) || empty( $callbacks[ $priority ] ) ) return FALSE; + // Loop through each filter for the specified priority, looking for our class & method + foreach( (array) $callbacks[ $priority ] as $filter_id => $filter ) { + // Filter should always be an array - array( $this, 'method' ), if not goto next + if ( ! isset( $filter[ 'function' ] ) || ! is_array( $filter[ 'function' ] ) ) continue; + // If first value in array is not an object, it can't be a class + if ( ! is_object( $filter[ 'function' ][ 0 ] ) ) continue; + // Method doesn't match the one we're looking for, goto next + if ( $filter[ 'function' ][ 1 ] !== $method_name ) continue; + // Method matched, now let's check the Class + if ( get_class( $filter[ 'function' ][ 0 ] ) === $class_name ) { + // Now let's remove it from the array + unset( $callbacks[ $priority ][ $filter_id ] ); + // and if it was the only filter in that priority, unset that priority + if ( empty( $callbacks[ $priority ] ) ) unset( $callbacks[ $priority ] ); + // and if the only filter for that tag, set the tag to an empty array + if ( empty( $callbacks ) ) $callbacks = array(); + // If using WordPress older than 4.7 + if ( ! is_object( $wp_filter[ $tag ] ) ) { + // Remove this filter from merged_filters, which specifies if filters have been sorted + unset( $GLOBALS[ 'merged_filters' ][ $tag ] ); + } + return TRUE; + } + } + return FALSE; +} +/** + * Remove Class Action Without Access to Class Object + * + * In order to use the core WordPress remove_action() on an action added with the callback + * to a class, you either have to have access to that class object, or it has to be a call + * to a static method. This method allows you to remove actions with a callback to a class + * you don't have access to. + * + * Works with WordPress 1.2 - 4.7+ + * + * @param string $tag Action to remove + * @param string $class_name Class name for the action's callback + * @param string $method_name Method name for the action's callback + * @param int $priority Priority of the action (default 10) + * + * @return bool Whether the function is removed. + */ +function remove_class_action( $tag, $class_name = '', $method_name = '', $priority = 10 ) { + remove_class_filter( $tag, $class_name, $method_name, $priority ); +}