222 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			222 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| namespace W3TC;
 | |
| 
 | |
| 
 | |
| 
 | |
| class Extension_NewRelic_Plugin {
 | |
| 
 | |
| 	/**
 | |
| 	 * New Relic reject reason
 | |
| 	 *
 | |
| 	 * @var string
 | |
| 	 */
 | |
| 	var $newrelic_reject_reason = '';
 | |
| 
 | |
| 	/**
 | |
| 	 * Config
 | |
| 	 */
 | |
| 	private $_config = null;
 | |
| 
 | |
| 	function __construct() {
 | |
| 		$this->_config = Dispatcher::config();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Runs plugin
 | |
| 	 */
 | |
| 	function run() {
 | |
| 		add_filter( 'w3tc_config_default_values', array(
 | |
| 				$this, 'w3tc_config_default_values' ) );
 | |
| 
 | |
| 		$config = Dispatcher::config();
 | |
| 		// remainder only when extension is frontend-active
 | |
| 		if ( !$config->is_extension_active_frontend( 'newrelic' ) )
 | |
| 			return;
 | |
| 
 | |
| 		if ( $this->_config->get_string( array( 'newrelic', 'monitoring_type' ) ) == 'browser' ) {
 | |
| 			Util_Bus::add_ob_callback( 'newrelic', array(
 | |
| 					$this, 'ob_callback_browser' ) );
 | |
| 		} else {
 | |
| 			require_once W3TC_LIB_NEWRELIC_DIR . '/NewRelicWrapper.php';
 | |
| 
 | |
| 			$this->set_appname();
 | |
| 
 | |
| 			if ( defined( 'DOING_CRON' ) && DOING_CRON )
 | |
| 				$this->background_task();
 | |
| 
 | |
| 			Util_Bus::add_ob_callback( 'newrelic', array(
 | |
| 					$this, 'ob_callback_apm' ) );
 | |
| 		}
 | |
| 
 | |
| 		add_filter( 'w3tc_footer_comment', array(
 | |
| 				$this,
 | |
| 				'w3tc_footer_comment'
 | |
| 			) );
 | |
| 	}
 | |
| 
 | |
| 	public function w3tc_config_default_values( $default_values ) {
 | |
| 		$default_values['newrelic'] = array(
 | |
| 			'monitoring_type' => 'apm',
 | |
| 			'accept.logged_roles' => true,
 | |
| 			'accept.roles' => array( 'contributor' ),
 | |
| 			'use_php_function' => true,
 | |
| 			'cache_time' => 5,
 | |
| 			'include_rum' => true
 | |
| 		);
 | |
| 
 | |
| 		return $default_values;
 | |
| 	}
 | |
| 
 | |
| 	function ob_callback_browser( $buffer ) {
 | |
| 		$core = Dispatcher::component( 'Extension_NewRelic_Core' );
 | |
| 		$app = $core->get_effective_browser_application();
 | |
| 		if ( isset( $app['loader_script'] ) && $this->_can_add_tracker_script( $buffer ) ) {
 | |
| 			$buffer = preg_replace( '~<head(\s+[^>]*)*>~Ui',
 | |
| 				'\\0' . $app['loader_script'], $buffer, 1 );
 | |
| 		}
 | |
| 
 | |
| 		$buffer = str_replace('{w3tc_newrelic_reject_reason}',
 | |
| 			( $this->newrelic_reject_reason != '' ? sprintf( ' (%s)', $this->newrelic_reject_reason )
 | |
| 				: '' ),
 | |
| 			$buffer );
 | |
| 
 | |
| 		return $buffer;
 | |
| 	}
 | |
| 
 | |
| 	function ob_callback_apm( $buffer ) {
 | |
| 		if ( !$this->_can_add_tracker_script( $buffer ) ) {
 | |
| 			$this->disable_auto_rum();
 | |
| 		} else {
 | |
| 			if ( $this->_config->get_boolean( array( 'newrelic', 'include_rum' ) ) ) {
 | |
| 				$buffer = preg_replace( '~<head(\s+[^>]*)*>~Ui', '\\0' . \NewRelicWrapper::get_browser_timing_header(), $buffer, 1 );
 | |
| 				$buffer = preg_replace( '~<\\/body>~', \NewRelicWrapper::get_browser_timing_footer() . '\\0', $buffer, 1 );
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		$buffer = str_replace('{w3tc_newrelic_reject_reason}',
 | |
| 			( $this->newrelic_reject_reason != '' ? sprintf( ' (%s)', $this->newrelic_reject_reason )
 | |
| 				: '' ),
 | |
| 			$buffer );
 | |
| 
 | |
| 		return $buffer;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Mark current transaction as an background job in New Relic.
 | |
| 	 */
 | |
| 	function background_task() {
 | |
| 		\NewRelicWrapper::mark_as_background_job();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Disable auto rum for current transaction.
 | |
| 	 */
 | |
| 	function disable_auto_rum() {
 | |
| 		\NewRelicWrapper::disable_auto_rum();
 | |
| 	}
 | |
| 
 | |
| 	function _can_add_tracker_script( $buffer ) {
 | |
| 		//
 | |
| 		$v = '';
 | |
| 		if ( preg_match('~^\s*<\?xml[^>]*>\s*<xsl:stylesheet~', $buffer, $v ) ) {
 | |
| 			$this->newrelic_reject_reason = __( 'XSL not tracked', 'w3-total-cache' );
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 		$reject_reason = apply_filters( 'w3tc_newrelic_should_disable_auto_rum', null );
 | |
| 		if ( !empty( $reject_reason ) ) {
 | |
| 			$this->newrelic_reject_reason =
 | |
| 				__( 'rejected by filter: ', 'w3-total-cache' ) . $reject_reason;
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Disable for AJAX so its not messed up
 | |
| 		 */
 | |
| 		if ( defined( 'DOING_AJAX' ) && DOING_AJAX ) {
 | |
| 			$this->newrelic_reject_reason = __( 'DOING_AJAX constant is defined', 'w3-total-cache' );
 | |
| 
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Check for DONOTAUTORUM constant
 | |
| 		 */
 | |
| 		if ( defined( 'DONOTAUTORUM' ) && DONOTAUTORUM ) {
 | |
| 			$this->newrelic_reject_reason = __( 'DONOTAUTORUM constant is defined', 'w3-total-cache' );
 | |
| 
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 		/**
 | |
| 		 * Check logged users roles
 | |
| 		 */
 | |
| 		if ( $this->_config->get_boolean( array( 'newrelic', 'accept.logged_roles' ) ) &&
 | |
| 			$this->_check_logged_in_role_not_allowed() ) {
 | |
| 			$this->newrelic_reject_reason = __( 'logged in role is rejected',
 | |
| 				'w3-total-cache' );
 | |
| 
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 		return true;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Check if logged in user role is allowed to use New Relic Auto RUM
 | |
| 	 *
 | |
| 	 * @return boolean
 | |
| 	 */
 | |
| 	private function _check_logged_in_role_not_allowed() {
 | |
| 		$current_user = wp_get_current_user();
 | |
| 
 | |
| 		if ( !is_user_logged_in() )
 | |
| 			return false;
 | |
| 
 | |
| 		$roles = $this->_config->get_array( array( 'newrelic', 'accept.roles' ) );
 | |
| 
 | |
| 		if ( empty( $roles ) || empty( $current_user->roles ) ||
 | |
| 			!is_array( $current_user->roles ) )
 | |
| 			return true;
 | |
| 
 | |
| 		foreach ( $current_user->roles as $role ) {
 | |
| 			if ( in_array( $role, $roles ) )
 | |
| 				return false;
 | |
| 		}
 | |
| 
 | |
| 		return true;
 | |
| 	}
 | |
| 
 | |
| 	public function set_appname() {
 | |
| 		static $appname_set;
 | |
| 		if ( !$appname_set && ( $this->_config->get_boolean( array( 'newrelic', 'use_php_function' ) ) || Util_Environment::is_wpmu() ) ) {
 | |
| 			$appname_set = true;
 | |
| 			$service = Dispatcher::component( 'Extension_NewRelic_Service' );
 | |
| 			$appname = $service->get_effective_appname();
 | |
| 
 | |
| 			$enable_xmit = $this->_config->get_boolean( array( 'newrelic', 'enable_xmit' ) );
 | |
| 			\NewRelicWrapper::set_appname( $appname, '', $enable_xmit );
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	public function w3tc_footer_comment( $strings ) {
 | |
| 		$strings[] = sprintf(
 | |
| 			__( "Application Monitoring using New Relic%s", 'w3-total-cache' ),
 | |
| 			'{w3tc_newrelic_reject_reason}' );
 | |
| 
 | |
| 		return $strings;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| $p = new Extension_NewRelic_Plugin();
 | |
| $p->run();
 | |
| 
 | |
| if ( is_admin() ) {
 | |
| 	$p = new Extension_NewRelic_Plugin_Admin();
 | |
| 	$p->run();
 | |
| }
 |