| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240 | <?phpnamespace Yansongda\Supports;use Exception;use Monolog\Formatter\FormatterInterface;use Monolog\Formatter\LineFormatter;use Monolog\Handler\AbstractHandler;use Monolog\Handler\RotatingFileHandler;use Monolog\Handler\StreamHandler;use Monolog\Logger as BaseLogger;use Psr\Log\LoggerInterface;/** * @method void emergency($message, array $context = array()) * @method void alert($message, array $context = array()) * @method void critical($message, array $context = array()) * @method void error($message, array $context = array()) * @method void warning($message, array $context = array()) * @method void notice($message, array $context = array()) * @method void info($message, array $context = array()) * @method void debug($message, array $context = array()) * @method void log($message, array $context = array()) */class Logger{    /**     * Logger instance.     *     * @var LoggerInterface     */    protected $logger;    /**     * formatter.     *     * @var \Monolog\Formatter\FormatterInterface     */    protected $formatter;    /**     * handler.     *     * @var AbstractHandler     */    protected $handler;    /**     * config.     *     * @var array     */    protected $config = [        'file' => null,        'identify' => 'yansongda.supports',        'level' => BaseLogger::DEBUG,        'type' => 'daily',        'max_files' => 30,    ];    /**     * Forward call.     *     * @author yansongda <me@yansongda.cn>     *     * @param string $method     * @param array  $args     *     * @throws Exception     */    public function __call($method, $args): void    {        call_user_func_array([$this->getLogger(), $method], $args);    }    /**     * Set logger.     *     * @author yansongda <me@yansongda.cn>     */    public function setLogger(LoggerInterface $logger): Logger    {        $this->logger = $logger;        return $this;    }    /**     * Return the logger instance.     *     * @author yansongda <me@yansongda.cn>     *     * @throws Exception     */    public function getLogger(): LoggerInterface    {        if (is_null($this->logger)) {            $this->logger = $this->createLogger();        }        return $this->logger;    }    /**     * Make a default log instance.     *     * @author yansongda <me@yansongda.cn>     *     * @throws Exception     */    public function createLogger(): BaseLogger    {        $handler = $this->getHandler();        $handler->setFormatter($this->getFormatter());        $logger = new BaseLogger($this->config['identify']);        $logger->pushHandler($handler);        return $logger;    }    /**     * setFormatter.     *     * @author yansongda <me@yansongda.cn>     *     * @return $this     */    public function setFormatter(FormatterInterface $formatter): self    {        $this->formatter = $formatter;        return $this;    }    /**     * getFormatter.     *     * @author yansongda <me@yansongda.cn>     */    public function getFormatter(): FormatterInterface    {        if (is_null($this->formatter)) {            $this->formatter = $this->createFormatter();        }        return $this->formatter;    }    /**     * createFormatter.     *     * @author yansongda <me@yansongda.cn>     */    public function createFormatter(): LineFormatter    {        return new LineFormatter(            "%datetime% > %channel%.%level_name% > %message% %context% %extra%\n\n",            null,            false,            true        );    }    /**     * setHandler.     *     * @author yansongda <me@yansongda.cn>     *     * @return $this     */    public function setHandler(AbstractHandler $handler): self    {        $this->handler = $handler;        return $this;    }    /**     * getHandler.     *     * @author yansongda <me@yansongda.cn>     *     * @throws \Exception     */    public function getHandler(): AbstractHandler    {        if (is_null($this->handler)) {            $this->handler = $this->createHandler();        }        return $this->handler;    }    /**     * createHandler.     *     * @author yansongda <me@yansongda.cn>     *     * @throws \Exception     *     * @return \Monolog\Handler\RotatingFileHandler|\Monolog\Handler\StreamHandler     */    public function createHandler(): AbstractHandler    {        $file = $this->config['file'] ?? sys_get_temp_dir().'/logs/'.$this->config['identify'].'.log';        if ('single' === $this->config['type']) {            return new StreamHandler($file, $this->config['level']);        }        return new RotatingFileHandler($file, $this->config['max_files'], $this->config['level']);    }    /**     * setConfig.     *     * @author yansongda <me@yansongda.cn>     *     * @return $this     */    public function setConfig(array $config): self    {        $this->config = array_merge($this->config, $config);        return $this;    }    /**     * getConfig.     *     * @author yansongda <me@yansongda.cn>     */    public function getConfig(): array    {        return $this->config;    }}
 |