Current File : /home/escuelai/www/wp-content/plugins/w3-total-cache/Extension_NewRelic_Plugin_Admin.php |
<?php
/**
* File: Extension_NewRelic_Plugin_Admin.php
*
* @package W3TC
*/
namespace W3TC;
/**
* Class Extension_NewRelic_Plugin_Admin
*
* phpcs:disable PSR2.Classes.PropertyDeclaration.Underscore
* phpcs:disable Generic.CodeAnalysis.UnusedFunctionParameter
*/
class Extension_NewRelic_Plugin_Admin {
/**
* Config
*
* @var Config
*/
private $_config;
/**
* Retrieves the list of available extensions and adds New Relic to the list.
*
* @param array $extensions List of existing extensions.
* @param array $config Configuration data.
*
* @return array Updated list of extensions.
*/
public static function w3tc_extensions( $extensions, $config ) {
$extensions['newrelic'] = array(
'name' => '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[] = '<a class="edit" href="' . esc_attr( Util_Ui::admin_url( 'admin.php?page=w3tc_general#monitoring' ) ) .
'">' . __( 'Settings' ) . '</a>';
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 = '<p>' .
__( 'New Relic is not running correctly. ', 'w3-total-cache' ) .
'<a href="#" class="w3tc_link_more {for_class: \'w3tc_nr_admin_notice\'}">' .
'more</a> ' .
'<div class="w3tc_none w3tc_nr_admin_notice">' .
__( 'The plugin has detected the following issues:. ', 'w3-total-cache' );
$message .= "<ul class=\"w3-bullet-list\">\n";
foreach ( $verify_running_result as $cause ) {
$message .= "<li>$cause</li>";
}
$message .= "</ul>\n";
$message .= '<p>' . 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'
),
'<a href="' . network_admin_url( 'admin.php?page=w3tc_general#monitoring' ) . '">',
'</a>'
) . '</p>';
$message .= "</div></p>\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[] = '<strong>New Relic</strong>';
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 );
}
}