HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/shoetique/wp-content/plugins/googleanalytics/tools/class-ga-supportlogger.php
<?php
/**
 * Support Logger class.
 *
 * @package GoogleAnalytics
 */

/**
 * GA Support Logger class.
 */
class Ga_SupportLogger {
	const LOG_OPTION = 'googleanalytics_sherethis_error_log';

	/**
	 * Debug info.
	 *
	 * @var mixed Info.
	 */
	public static $debug_info;

	/**
	 * Debug help message.
	 *
	 * @var string Message.
	 */
	public static $debug_help_message;

	/**
	 * Constructor.
	 *
	 * @return void
	 */
	public function __construct() {
		add_action( 'st_support_show_button', array( $this, 'display_button' ) );
		add_action( 'st_support_save_error', array( $this, 'save_error' ) );
		$this->get_debug_body();
	}

	/**
	 * Displays a button to email the debugging info.
	 *
	 * @return void
	 */
	public function display_button() {
		printf(
			'<a href="%s" class="button button-secondary" target="_blank">Get Debugging Info</a>',
			esc_url( '' )
		);
	}


	/**
	 * Saves an error to the log.
	 *
	 * @param Exception $err Error to save.
	 * @return void
	 */
	public function save_error( Exception $err ) {
		$cur_log = get_option( self::LOG_OPTION, array() );

		if ( false === is_array( $cur_log ) ) {
			$cur_log = array();
		}

		// Creates the error object.
		$new_log = array(
			'message' => $err->getMessage(),
			'stack'   => $err->getTraceAsString(),
			'date'    => current_time( 'r' ),
		);

		if ( method_exists( $err, 'get_google_error_response' ) ) {
			$new_log['response'] = $err->get_google_error_response();
		}

		$cur_log[] = $new_log;

		// Cap the log at 20 entries for space purposes.
		if ( count( $cur_log ) > 20 ) {
			array_pop( $cur_log );
		}

		// Save.
		update_option( self::LOG_OPTION, $cur_log );
	}

	/**
	 * Get Current URL.
	 *
	 * @return string|void
	 */
	public static function get_current_url() {
		$request_uri = filter_input( INPUT_SERVER, 'REQUEST_URI', FILTER_UNSAFE_RAW );

		return sanitize_text_field( wp_unslash( $request_uri ) );
	}

	/**
	 * Get debug body.
	 *
	 * @return void
	 */
	public function get_debug_body() {
		$debug_error = $this->get_formatted_log();

		if ( 'None' === $debug_error ) {
			self::$debug_info = false;

			return;
		}

		$debug_message = $this->get_formatted_message();

		$debug_link = self::get_current_url();

		$let_debug_message = '<br> If you are still experiencing the issue after that click <a href="' . $debug_link . '&sdb=true" id="debug-message">here</a>';

		$sdb = filter_input( INPUT_GET, 'sdb', FILTER_UNSAFE_RAW );

		$debug_help_message = false === empty( $sdb ) ? false : $this->get_debug_help_message( $debug_message );

		if ( isset( $debug_help_message['message'] ) ) {
			$body  = $debug_help_message['message'];
			$body .= $debug_help_message['let-debug'] ? $let_debug_message : '';

			self::$debug_info = array(
				'message' => $body,
				'debug'   => $debug_help_message['let-debug'],
			);
		} else {
			$body  = 'Debug Info:' . PHP_EOL . PHP_EOL;
			$body .= implode( PHP_EOL, $this->get_debug_info() );
			$body .= PHP_EOL . PHP_EOL . 'Error Log:' . PHP_EOL . PHP_EOL;
			$body .= esc_html( $debug_error );

			self::$debug_info = $body;
		}
	}

	/**
	 * Get debug help message.
	 *
	 * @param string $error Error string.
	 *
	 * @return array Array with message and let-debug boolean.
	 */
	public function get_debug_help_message( $error ) {

		switch ( $error ) {
			case 'invalid_grant':
				return array(
					'message'   => 'Hi! It looks like you submitted the wrong authentication grant. Please try again by re-authenticating.',
					'let-debug' => true,
				);
			case 'SSL certificate problem: unable to get local issuer certificate (60)':
				return array(
					'message'   => 'Hi! Please check your site\'s SSL certificate. A functioning SSL certificate is required',
					'let-debug' => false,
				);
			case 'SSL certificate problem: unable to get local issuer certificate':
				return array(
					'message'   => 'Hi! Please check your site\'s SSL certificate. A functioning SSL certificate is required',
					'let-debug' => false,
				);
			case 'User does not have any Google Analytics account.':
				return array(
					'message'   => 'Hi! Looks like we’re not able to find a Google Analytics account. Please double check to make sure the Google account you used to authenticate with has a working Google Analytics account setup.',
					'let-debug' => false,
				);
			case 'SSL certificate problem: certificate has expired (60)':
				return array(
					'message'   => 'Hi! Please check your site\'s SSL certificate. A functioning SSL certificate is required',
					'let-debug' => false,
				);
			case 'SSL certificate problem, verify that the CA cert is OK':
				return array(
					'message'   => 'Hi! Please check your site\'s SSL certificate. A functioning SSL certificate is required',
					'let-debug' => false,
				);
		}

		return array(
			'message'   => 'Hi! It appears something went wrong. We apologize for the inconvenience! Please try to re-authenticate your Google account and verify your site has a proper SSL certficiate.',
			'let-debug' => true,
		);
	}

	/**
	 * Gets an array of debugging information about the current system.
	 *
	 * @return array
	 */
	private function get_debug_info() {
		$theme   = wp_get_theme();
		$plugins = wp_get_active_and_valid_plugins();

		$server_software = filter_input( INPUT_SERVER, 'SERVER_SOFTWARE', FILTER_SANITIZE_STRING );
		$http_user_agent = filter_input( INPUT_SERVER, 'HTTP_USER_AGENT', FILTER_SANITIZE_STRING );

		$data      = array(
			'Plugin Version'               => GOOGLEANALYTICS_VERSION,
			'WordPress Version'            => get_bloginfo( 'version' ),
			'PHP Version'                  => phpversion(),
			'CURL Version'                 => $this->get_curl_version(),
			'Site URL'                     => get_bloginfo( 'wpurl' ),
			'Theme Name'                   => $theme->get( 'Name' ),
			'Theme URL'                    => $theme->get( 'ThemeURI' ),
			'Theme Version'                => $theme->get( 'Version' ),
			'Active Plugins'               => implode( ', ', $plugins ),
			'Operating System'             => $this->get_operating_system(),
			'Web Server'                   => $server_software,
			'Current Time'                 => current_time( 'r' ),
			'Browser'                      => false === empty( $http_user_agent ) ? $http_user_agent : '',
			'Excluded roles'               => get_option( 'googleanalytics_exclude_roles' ),
			'Manually Tracking ID enabled' => get_option( 'googleanalytics_web_property_id_manually' ),
			'Manually typed Tracking ID'   => get_option( 'googleanalytics_web_property_id_manually_value' ),
			'Tracking ID'                  => get_option( 'googleanalytics_web_property_id' ),
		);
		$formatted = array();
		foreach ( $data as $text => $value ) {
			/* translators: %s refers to the value of the message. */
			$formatted[] = esc_html__(
				$text . sprintf( ': %s', $value ) // phpcs:ignore
			);
		}

		return $formatted;
	}

	/**
	 * Gets CURL version
	 *
	 * @return string
	 */
	private function get_curl_version() {
		$curl_version = curl_version();
		return ! empty( $curl_version['version'] ) ? $curl_version['version'] : '';
	}

	/**
	 * Gets operating system
	 *
	 * @return string
	 */
	private function get_operating_system() {
		if ( function_exists( 'ini_get' ) ) {
			$disabled = explode( ',', ini_get( 'disable_functions' ) );
			return false === in_array( 'php_uname', $disabled, true ) ? php_uname() : PHP_OS;
		}
		return PHP_OS;
	}

	/**
	 * Gets a string of formatted error log entries.
	 *
	 * @return string
	 */
	private function get_formatted_log() {
		$log = get_option( self::LOG_OPTION );
		if ( ! $log ) {
			return 'None';
		}

		$text = '';
		foreach ( $log as $error ) {
			foreach ( $error as $key => $value ) {
				$text .= ucwords( $key ) . ': ' . $value . "\n";
			}
		}

		return $text;
	}

	/**
	 * Gets a string of formatted of just the message
	 *
	 * @return string
	 */
	private function get_formatted_message() {
		$log = get_option( self::LOG_OPTION );
		if ( ! $log ) {
			return 'None';
		}

		return isset( $log[0]['message'] ) ? $log[0]['message'] : '';
	}

}

new Ga_SupportLogger();