'New Relic', 'author' => 'W3 EDGE', 'description' => __( 'Legacy: New Relic is software analytics platform offering app performance management and mobile monitoring solutions.', 'w3-total-cache' ), 'author_uri' => 'https://www.w3-edge.com/', 'extension_uri' => 'https://www.w3-edge.com/', 'extension_id' => 'newrelic', 'settings_exists' => true, 'version' => '1.0', 'enabled' => true, 'requirements' => '', 'active_frontend_own_control' => true, 'path' => 'w3-total-cache/Extension_NewRelic_Plugin.php', ); return $extensions; } /** * Constructor for the New Relic extension. * Initializes the configuration for the New Relic plugin. * * @return void */ public function __construct() { $this->_config = Dispatcher::config(); } /** * Executes the necessary actions and filters for the New Relic extension. * * @return void */ public function run() { add_filter( 'w3tc_compatibility_test', array( $this, 'verify_compatibility' ) ); add_action( 'w3tc_config_save', array( $this, 'w3tc_config_save' ), 10, 1 ); add_filter( 'w3tc_admin_actions', array( $this, 'w3tc_admin_actions' ) ); add_filter( 'w3tc_admin_menu', array( $this, 'w3tc_admin_menu' ) ); add_filter( 'w3tc_extension_plugin_links_newrelic', array( $this, 'w3tc_extension_plugin_links' ) ); add_action( 'w3tc_settings_page-w3tc_monitoring', array( $this, 'w3tc_settings_page_w3tc_monitoring' ) ); add_action( 'admin_init_w3tc_general', array( '\W3TC\Extension_NewRelic_GeneralPage', 'admin_init_w3tc_general' ) ); add_action( 'w3tc_ajax', array( '\W3TC\Extension_NewRelic_Popup', 'w3tc_ajax' ) ); if ( Util_Admin::is_w3tc_admin_page() ) { add_action( 'admin_notices', array( $this, 'admin_notices' ) ); add_action( 'network_admin_notices', array( $this, 'admin_notices' ) ); } $v = $this->_config->get_string( array( 'newrelic', 'api_key' ) ); $new_relic_configured = ! empty( $v ); if ( $new_relic_configured ) { add_action( 'admin_init_w3tc_dashboard', array( '\W3TC\Extension_NewRelic_Widget', 'admin_init_w3tc_dashboard' ) ); add_action( 'w3tc_ajax', array( '\W3TC\Extension_NewRelic_Widget', 'w3tc_ajax' ) ); add_filter( 'w3tc_notes', array( $this, 'w3tc_notes' ) ); } } /** * Modifies the admin menu to include New Relic-related items if applicable. * * @param array $menu Existing admin menu items. * * @return array Modified admin menu with New Relic monitoring option. */ public function w3tc_admin_menu( $menu ) { $c = Dispatcher::config(); $monitoring_type = $c->get_string( array( 'newrelic', 'monitoring_type' ) ); if ( 'amp' === $monitoring_type ) { $menu['w3tc_monitoring'] = array( 'page_title' => __( 'Monitoring', 'w3-total-cache' ), 'menu_text' => __( 'Monitoring', 'w3-total-cache' ), 'visible_always' => false, 'order' => 1200, ); } return $menu; } /** * Adds custom actions for the New Relic extension. * * @param array $handlers Existing array of admin action handlers. * * @return array Modified array of action handlers with the New Relic handler added. */ public function w3tc_admin_actions( $handlers ) { $handlers['new_relic'] = 'Extension_NewRelic_AdminActions'; return $handlers; } /** * Adds custom plugin links for the New Relic extension. * * @param array $links Existing array of plugin links. * * @return array Modified array of plugin links with New Relic settings link added. */ public function w3tc_extension_plugin_links( $links ) { $links = array(); $links[] = '' . __( 'Settings', 'w3-total-cache' ) . ''; return $links; } /** * Displays the settings page for the New Relic extension. * * @return void */ public function w3tc_settings_page_w3tc_monitoring() { $v = new Extension_NewRelic_Page(); $v->render_content(); } /** * Displays admin notices related to New Relic configuration. * * @return void */ public function admin_notices() { $api_key = $this->_config->get_string( array( 'newrelic', 'api_key' ) ); if ( empty( $api_key ) ) { return; } $nerser = Dispatcher::component( 'Extension_NewRelic_Service' ); $verify_running_result = $nerser->verify_running(); $not_running = is_array( $verify_running_result ); if ( $not_running ) { $message = '

' . __( 'New Relic is not running correctly. ', 'w3-total-cache' ) . '' . 'more ' . '

' . __( 'The plugin has detected the following issues:. ', 'w3-total-cache' ); $message .= "\n"; $message .= '

' . sprintf( // Translators: 1 opening HTML link to General Settings page monitoring section, 2 closing HTML link. __( 'Please review the %1$ssettings%2$s.', 'w3-total-cache' ), '', '' ) . '

'; $message .= "

\n"; Util_Ui::error_box( $message ); } } /** * Adds custom notes to the W3 Total Cache dashboard related to New Relic. * * @param array $notes Existing array of notes to be displayed. * * @return array Modified array of notes with New Relic notifications added. */ public function w3tc_notes( $notes ) { $newrelic_notes = Dispatcher::component( 'Extension_NewRelic_AdminNotes' ); $notes = array_merge( $notes, $newrelic_notes->notifications( $this->_config ) ); return $notes; } /** * Verifies the compatibility of the New Relic extension with the current environment. * * @param array $verified_list List of verified components and their statuses. * * @return array Modified list of verified components with New Relic verification results added. */ public function verify_compatibility( $verified_list ) { $nerser = Dispatcher::component( 'Extension_NewRelic_Service' ); $nr_verified = $nerser->verify_compatibility(); $verified_list[] = 'New Relic'; foreach ( $nr_verified as $criteria => $result ) { $verified_list[] = sprintf( "$criteria: %s", $result ); } return $verified_list; } /** * Handles the saving of configuration settings for the New Relic extension. * * @param object $config Configuration object containing the settings to be saved. * * @return void */ public function w3tc_config_save( $config ) { // frontend activity. $api_key = $config->get_string( array( 'newrelic', 'api_key' ) ); $is_filled = ! empty( $api_key ); if ( $is_filled ) { $monitoring_type = $config->get_string( array( 'newrelic', 'monitoring_type' ) ); if ( 'browser' === $monitoring_type ) { $v = $config->get_string( array( 'newrelic', 'browser.application_id' ) ); $is_filled = ! empty( $v ); } else { $v = $config->get_string( array( 'newrelic', 'apm.application_name' ) ); $is_filled = ! empty( $v ); } } $config->set_extension_active_frontend( 'newrelic', $is_filled ); } }