namespace ImageOptimization\Classes;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
public const LEVEL_ERROR = 'error';
public const LEVEL_WARN = 'warn';
public const LEVEL_INFO = 'info';
public const LEVEL_DEBUG = 'debug';
public const LOG_LEVEL_PRIORITY = [
public static function log( string $log_level, $message ): void {
defined( 'IMAGE_OPTIMIZATION_MINIMUM_LOG_LEVEL' ) &&
self::LOG_LEVEL_PRIORITY[ $log_level ] < (int) IMAGE_OPTIMIZATION_MINIMUM_LOG_LEVEL
$backtrace = debug_backtrace(); // phpcs:ignore WordPress.PHP.DevelopmentFunctions.error_log_debug_backtrace
$class = $backtrace[1]['class'] ?? null;
$type = $backtrace[1]['type'] ?? null;
$function = $backtrace[1]['function'];
$message = '[Image Optimizer]: ' . $log_level . ' in ' . "$class$type$function()" . ': ' . $message;
$message = '[Image Optimizer]: ' . $log_level . ' in ' . "$function()" . ': ' . $message;
error_log( $message ); // phpcs:ignore WordPress.PHP.DevelopmentFunctions.error_log_error_log
public static function debug( $message ): void {
self::log( self::LEVEL_DEBUG, $message );
public static function info( $message ): void {
self::log( self::LEVEL_INFO, $message );
public static function warn( $message ): void {
self::log( self::LEVEL_WARN, $message );
public static function error( $message ): void {
self::log( self::LEVEL_ERROR, $message );