$60 GRAYBYTE WORDPRESS FILE MANAGER $48

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 104.21.43.35 | ADMIN IP 216.73.216.180
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : mail

/home/bravrvjk/cepurhuye.rw/wp-content/plugins/elementor/modules/atomic-widgets/logger/

HOME
Current File : /home/bravrvjk/cepurhuye.rw/wp-content/plugins/elementor/modules/atomic-widgets/logger//logger.php
<?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;
	}
}


Current_dir [ WRITEABLE ] Document_root [ NOT WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
4 Apr 2026 1.57 AM
bravrvjk / bravrvjk
0755
logger.php
2.744 KB
2 Feb 2026 2.52 PM
bravrvjk / bravrvjk
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF