HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
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,
Upload Files
File: /var/www/html/ielts-store/wp-content/plugins/automatewoo/includes/Logger.php
<?php
// phpcs:ignoreFile

namespace AutomateWoo;

defined( 'ABSPATH' ) || exit;

/**
 * Class Logger
 * @since 4.3.0
 */
class Logger {

	/** @var \WC_Logger */
	protected static $wc_logger;

	/** @var string */
	protected static $handle_prefix = 'automatewoo-';


	/**
	 * @return \WC_Logger
	 */
	protected static function get_wc_logger() {
		if ( empty( self::$wc_logger ) ) {
			self::$wc_logger = wc_get_logger();
		}
		return self::$wc_logger;
	}


	/**
	 * Add a log entry.
	 *
	 * @param string $level emergency|alert|critical|error|warning|notice|info|debug
	 * @param string $handle
	 * @param string $message
	 */
	protected static function log( $level, $handle, $message ) {
		$handle = self::$handle_prefix . $handle;

		self::get_wc_logger()->log( $level, $message, [
			'source' => $handle
		]);
	}


	/**
	 * Adds an emergency level message.
	 *
	 * System is unusable.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function emergency( $handle, $message ) {
		self::log( 'emergency', $handle, $message );
	}


	/**
	 * Adds an alert level message.
	 *
	 * Action must be taken immediately.
	 * Example: Entire website down, database unavailable, etc.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function alert( $handle, $message ) {
		self::log( 'alert', $handle, $message );
	}


	/**
	 * Adds a critical level message.
	 *
	 * Critical conditions.
	 * Example: Application component unavailable, unexpected exception.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function critical( $handle, $message ) {
		self::log( 'critical', $handle, $message );
	}


	/**
	 * Adds an error level message.
	 *
	 * Runtime errors that do not require immediate action but should typically be logged
	 * and monitored.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function error( $handle, $message ) {
		self::log( 'error', $handle, $message );
	}


	/**
	 * Adds a warning level message.
	 *
	 * Exceptional occurrences that are not errors.
	 *
	 * Example: Use of deprecated APIs, poor use of an API, undesirable things that are not
	 * necessarily wrong.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function warning( $handle, $message ) {
		self::log( 'warning', $handle, $message );
	}


	/**
	 * Adds a notice level message.
	 *
	 * Normal but significant events.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function notice( $handle, $message ) {
		self::log( 'notice', $handle, $message );
	}


	/**
	 * Adds a info level message.
	 *
	 * Interesting events.
	 * Example: User logs in, SQL logs.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function info( $handle, $message ) {
		self::log( 'info', $handle, $message );
	}


	/**
	 * Adds a debug level message.
	 *
	 * Detailed debug information.
	 *
	 * @param string $handle
	 * @param string $message
	 */
	public static function debug( $handle, $message ) {
		self::log( 'debug', $handle, $message );
	}


}