HEX
Server: nginx/1.18.0
System: Linux iZj6c1ieg2jrpk1z5tzi19Z 6.3.9-1.el7.elrepo.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Jun 21 22:18:40 EDT 2023 x86_64
User: www (1001)
PHP: 8.2.4
Disabled: 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
Upload Files
File: /www/wwwroot/www.cytocare.cn/wp-content/plugins/wc-china-checkout/includes/logger/class-xh-log.php
<?php
if (! defined('ABSPATH'))
    exit(); // Exit if accessed directly

require_once 'class-xh-log-file-handler.php';

/**
 * Logger
 *
 * Record some abnormal or errors.
 *
 * @since 1.0.0
 * @author ranj
 */
class WC_Sinic_Log
{
    private $handler = null;
    private $level = 0;
    private static $instance = null;

    private function __construct(){}
    /**
     * Get instance.
     *
     * @since  1.0.0
     * @return WC_Sinic_Log
     */
    public static function instance($handler = null, $level = 0)
    {
        if (! self::$instance instanceof self) {
            self::$instance = new self();
            self::$instance->__setHandle($handler);
            self::$instance->__setLevel($level);
        }
        return self::$instance;
    }
    
    /**
     * Set log handler.
     *
     * @since  1.0.0
     * @param WC_Sinic_Log_File_Handler $handler
     */
    private function __setHandle($handler)
    {
        $this->handler = $handler;
    }

    /**
     * Set log level.
     *
     * @since  1.0.0
     * @param int $level
     */
    private function __setLevel($level)
    {
        $this->level = $level;
    }
    
    /**
     * Rebuild error msg.
     *
     * @since  1.0.0
     * @param string|Exception $msg
     */
    private static function rebuild_err_msg($msg){
        if(!$msg){
            return '';
        }
        
        if($msg instanceof Exception){
            return "errcode:{$msg->getCode()},errmsg:{$msg->getMessage()}";
        }
        
        if($msg instanceof WP_Error){
            return "errcode:{$msg->get_error_code()},errmsg:{$msg->get_error_message()}";
        }
        
        if($msg instanceof WC_Sinic_Error){
            return "errcode:{$msg->errcode},errmsg:{$msg->errmsg}";
        }
        
        if(is_string($msg)){
            return $msg;
        }
        
        return json_encode($msg);
    }
    
    /**
     * Get level source.
     *
     * @since  1.0.0
     * @param string|Exception $msg
     */
    private function get_leval_source($level)
    {
        switch ($level) {
            case 1:
                return 'debug';
                break;
            case 2:
                return 'info';
                break;
            case 4:
                return 'warn';
                break;
            case 8:
                return 'error';
                break;
            default:
        }
    }
    
    /**
     * Debug.
     *
     * @since  1.0.0
     * @param string|Exception $msg
     */
    public static function debug($msg)
    {
        if (! self::$instance) {
            return;
        }
        
        self::$instance->write(1, self::rebuild_err_msg($msg));
    }
    
    /**
     * Warn.
     *
     * @since  1.0.0
     * @param string|Exception $msg
     */
    public static function warn($msg)
    {
        if (! self::$instance) {
            return;
        }
        self::$instance->write(4, self::rebuild_err_msg($msg));
    }

    /**
     * Error.
     *
     * @since  1.0.0
     * @param string|Exception $msg
     */
    public static function error($msg)
    {
        if (! self::$instance) {
            return;
        }
        
        $debugInfo = debug_backtrace();
        $stack = "[";
        foreach ($debugInfo as $key => $val) {
            if (array_key_exists("file", $val)) {
                $stack .= ",file:" . $val["file"];
            }
            if (array_key_exists("line", $val)) {
                $stack .= ",line:" . $val["line"];
            }
            if (array_key_exists("function", $val)) {
                $stack .= ",function:" . $val["function"];
            }
        }
        $stack .= "]";
        self::$instance->write(8, $stack ."\n". self::rebuild_err_msg($msg));
    }

    /**
     * Info.
     *
     * @since  1.0.0
     * @param string|Exception|WC_Sinic_Error|WP_Error $msg
     */
    public static function info($msg)
    {
        if (! self::$instance) {
            return;
        }
        self::$instance->write(2, self::rebuild_err_msg($msg));
    }

    /**
     * Write logs by handler.
     *
     * @since  1.0.0
     * @param string|Exception $msg
     */
    protected function write($level, $msg)
    {
        if($level>$this->level){
             $msg = '[' . date_i18n('Y-m-d H:i:s') . '][' . $this->get_leval_source($level) . '] ' . $msg . "\n";
             $this->handler->write($msg);
        }
    }
}