Current File : /home/escuelai/www/wp-content/plugins/w3-total-cache/Extension_NewRelic_Api.php
<?php
/**
 * File: Extension_NewRelic_AdminNotes.php
 *
 * @package W3TC
 */

namespace W3TC;

/**
 * Class Extension_NewRelic_Api
 *
 * Interacts with the New Relic Connect API
 *
 * @link newrelic.github.com/newrelic_api/
 *
 * phpcs:disable PSR2.Classes.PropertyDeclaration.Underscore
 * phpcs:disable PSR2.Methods.MethodDeclaration.Underscore
 * phpcs:disable WordPress.PHP.NoSilencedErrors.Discouraged
 */
class Extension_NewRelic_Api {
	/**
	 * API Key
	 *
	 * @var string
	 */
	private $_api_key;

	/**
	 * New Relic API URL
	 *
	 * @var string
	 */
	private static $url = 'https://api.newrelic.com';

	/**
	 * Constructor to initialize the API key.
	 *
	 * @param string $api_key The API key to authenticate requests.
	 *
	 * @return void
	 */
	public function __construct( $api_key ) {
		$this->_api_key = $api_key;
	}

	/**
	 * Sends a GET request to the specified API endpoint.
	 *
	 * @param string $api_call_url The API URL to call.
	 * @param array  $query        Optional query parameters to include in the request.
	 *
	 * @return string The response body from the API.
	 *
	 * @throws \Exception If the API request fails or returns an error.
	 */
	private function _get( $api_call_url, $query = array() ) {
		$defaults = array(
			'headers' => 'x-api-key:' . $this->_api_key,
			'body'    => $query,
		);
		$url      = self::$url . $api_call_url;

		$response = wp_remote_get( $url, $defaults );

		if ( is_wp_error( $response ) ) {
			throw new \Exception( 'Could not get data' );
		} elseif ( 200 === $response['response']['code'] ) {
			$return = $response['body'];
		} else {
			switch ( $response['response']['code'] ) {
				case '403':
					$message = __( 'Invalid API key', 'w3-total-cache' );
					break;
				default:
					$message = $response['response']['message'];
			}

			throw new \Exception(
				\esc_html( $message ),
				\esc_html( $response['response']['code'] )
			);
		}
		return $return;
	}

	/**
	 * Sends a PUT request to the specified API endpoint.
	 *
	 * @param string $api_call_url The API URL to call.
	 * @param array  $params       The data to send in the PUT request.
	 *
	 * @return bool True if the request was successful.
	 *
	 * @throws \Exception If the API request fails or returns an error.
	 */
	private function _put( $api_call_url, $params ) {
		$defaults = array(
			'method'  => 'PUT',
			'headers' => 'x-api-key:' . $this->_api_key,
			'body'    => $params,
		);
		$url      = self::$url . $api_call_url;
		$response = wp_remote_request( $url, $defaults );

		if ( is_wp_error( $response ) ) {
			throw new \Exception( 'Could not put data' );
		} elseif ( 200 === $response['response']['code'] ) {
			$return = true;
		} else {
			throw new \Exception(
				\esc_html( $response['response']['message'] ),
				\esc_html( $response['response']['code'] )
			);
		}
		return $return;
	}

	/**
	 * Retrieves a list of browser applications from the API.
	 *
	 * @return array A list of browser applications.
	 *
	 * @throws \Exception If the API response is invalid or unexpected.
	 */
	public function get_browser_applications() {
		$response = $this->_get( '/v2/browser_applications.json' );
		$r        = @json_decode( $response, true );
		if ( ! $r ) {
			throw new \Exception( 'Received unexpected response' );
		}

		if ( ! isset( $r['browser_applications'] ) ) {
			return array();
		}

		return $r['browser_applications'];
	}

	/**
	 * Retrieves a specific browser application by its ID from the API.
	 *
	 * @param string $id The ID of the browser application to retrieve.
	 *
	 * @return array|null The browser application data, or null if not found.
	 *
	 * @throws \Exception If the API response is invalid or unexpected.
	 */
	public function get_browser_application( $id ) {
		$response = $this->_get( '/v2/browser_applications.json', array( 'filter[ids]' => $id ) );
		$r        = @json_decode( $response, true );
		if ( ! $r ) {
			throw new \Exception( 'Received unexpected response' );
		}

		if ( ! isset( $r['browser_applications'] ) || 1 !== count( $r['browser_applications'] ) ) {
			return null;
		}

		return $r['browser_applications'][0];
	}
}