| Server IP : 172.67.159.124 / Your IP : 216.73.217.175 Web Server : nginx/1.26.1 System : Linux HE9229 3.10.0-1160.el7.x86_64 #1 SMP Mon Oct 19 16:18:59 UTC 2020 x86_64 User : www ( 1000) PHP Version : 8.0.26 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,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_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /www/wwwroot/pinoygo_com_ph/wp-content/plugins/elementor/modules/atomic-widgets/logger/ |
Upload File : |
<?php
namespace Elementor\Modules\AtomicWidgets\Logger;
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* Simple logger for Atomic Widgets that writes to wp-content/debug.log (if WP_DEBUG_LOG enabled
* and WP_DEBUG_DISPLAY disabled) or optionally to Elementor's DB logger.
* Never displays errors on screen.
*/
class Logger {
public static function info( string $message, array $context = [], bool $use_elementor_logger = false ): void {
self::log_message( $message, $context, $use_elementor_logger, 'info' );
}
public static function warning( string $message, array $context = [], bool $use_elementor_logger = false ): void {
self::log_message( $message, $context, $use_elementor_logger, 'warning' );
}
public static function error( string $message, array $context = [], bool $use_elementor_logger = false ): void {
self::log_message( $message, $context, $use_elementor_logger, 'error' );
}
private static function log_message( string $message, array $context, bool $use_elementor_logger, string $level ): void {
if ( $use_elementor_logger ) {
self::log_to_elementor_db( $message, $context, $level );
return;
}
self::log_to_wp_debug_file( $message, $context, $level );
}
private static function log_to_wp_debug_file( string $message, array $context, string $level ): void {
if ( ! self::should_log_to_file() ) {
return;
}
$formatted_message = self::format_message( $message, $context, $level );
error_log( $formatted_message );
}
private static function log_to_elementor_db( string $message, array $context, string $level ): void {
if ( ! isset( \Elementor\Plugin::$instance->logger ) ) {
return;
}
try {
$logger = \Elementor\Plugin::$instance->logger;
switch ( $level ) {
case 'error':
$logger->error( $message, $context );
break;
case 'warning':
$logger->warning( $message, $context );
break;
default:
$logger->info( $message, $context );
break;
}
} catch ( \Exception $e ) { // phpcs:ignore Generic.CodeAnalysis.EmptyStatement.DetectedCatch -- Logger must not throw exceptions
}
}
private static function should_log_to_file(): bool {
$debug_log_enabled = defined( 'WP_DEBUG_LOG' ) && WP_DEBUG_LOG;
$debug_display_disabled = ! defined( 'WP_DEBUG_DISPLAY' ) || ! WP_DEBUG_DISPLAY;
return $debug_log_enabled && $debug_display_disabled;
}
private static function format_message( string $message, array $context, string $level ): string {
$level_prefix = strtoupper( $level );
$formatted = "[Elementor Atomic Widgets] [{$level_prefix}] " . $message;
if ( ! empty( $context ) ) {
$context_json = wp_json_encode( $context, JSON_UNESCAPED_SLASHES );
if ( false !== $context_json ) {
$formatted .= ' | Context: ' . $context_json;
}
}
return $formatted;
}
}