laravel 5.2 custom log file for different tasks

后端 未结 10 1034
再見小時候
再見小時候 2021-01-30 00:36

Can we create a custom log file for different purposes in laravel 5.2 like for order related log entries that should be in order.log and for payment related stuff the entry shou

10条回答
  •  -上瘾入骨i
    2021-01-30 00:55

    Based on the ShQ answer, a shorter and simpler logger helper that allows you to log to a custom file on the fly. You can also add your custom handler and set the file path.

    App\Helper

    
     */
    
    namespace App\Helpers;
    
    use Monolog\Logger;
    use Monolog\Handler\HandlerInterface;
    use Monolog\Handler\StreamHandler;
    
    /**
     * Class LogToChannels
     *
     * @package App\Helpers
     */
    class LogToChannels
    {
        /**
         * The LogToChannels channels.
         *
         * @var Logger[]
         */
        protected $channels = [];
    
        /**
         * LogToChannels constructor.
         */
        public function __construct()
        {
        }
    
        /**
         * @param string $channel The channel to log the record in
         * @param int    $level   The error level
         * @param string $message The error message
         * @param array  $context Optional context arguments
         *
         * @return bool Whether the record has been processed
         */
        public function log(string $channel, int $level, string $message, array $context = []): bool
        {
            // Add the logger if it doesn't exist
            if (!isset($this->channels[$channel])) {
                $handler = new StreamHandler(
                    storage_path() . DIRECTORY_SEPARATOR . 'logs' . DIRECTORY_SEPARATOR . $channel . '.log'
                );
    
                $this->addChannel($channel, $handler);
            }
    
            // LogToChannels the record
            return $this->channels[$channel]->{Logger::getLevelName($level)}($message, $context);
        }
    
        /**
         * Add a channel to log in
         *
         * @param string           $channelName The channel name
         * @param HandlerInterface $handler     The channel handler
         * @param string|null      $path        The path of the channel file, DEFAULT storage_path()/logs
         *
         * @throws \Exception When the channel already exists
         */
        public function addChannel(string $channelName, HandlerInterface $handler, string $path = null)
        {
            if (isset($this->channels[$channelName])) {
                throw new \Exception('This channel already exists');
            }
    
            $this->channels[$channelName] = new Logger($channelName);
            $this->channels[$channelName]->pushHandler(
                new $handler(
                    $path === null ?
                        storage_path() . DIRECTORY_SEPARATOR . 'logs' . DIRECTORY_SEPARATOR . $channelName . '.log' :
                        $path . DIRECTORY_SEPARATOR . $channelName . '.log'
                )
            );
        }
    
        /**
         * Adds a log record at the DEBUG level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function debug(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::DEBUG, $message, $context);
        }
    
        /**
         * Adds a log record at the INFO level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function info(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::INFO, $message, $context);
        }
    
        /**
         * Adds a log record at the NOTICE level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function notice(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::NOTICE, $message, $context);
        }
    
        /**
         * Adds a log record at the WARNING level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function warn(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::WARNING, $message, $context);
        }
    
        /**
         * Adds a log record at the WARNING level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function warning(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::WARNING, $message, $context);
        }
    
        /**
         * Adds a log record at the ERROR level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function err(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::ERROR, $message, $context);
        }
    
        /**
         * Adds a log record at the ERROR level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function error(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::ERROR, $message, $context);
        }
    
        /**
         * Adds a log record at the CRITICAL level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function crit(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::CRITICAL, $message, $context);
        }
    
        /**
         * Adds a log record at the CRITICAL level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return Boolean Whether the record has been processed
         */
        public function critical(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::CRITICAL, $message, $context);
        }
    
        /**
         * Adds a log record at the ALERT level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function alert(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::ALERT, $message, $context);
        }
    
        /**
         * Adds a log record at the EMERGENCY level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function emerg(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::EMERGENCY, $message, $context);
        }
    
        /**
         * Adds a log record at the EMERGENCY level.
         *
         * @param  string $channel The channel name
         * @param  string $message The log message
         * @param  array  $context The log context
         *
         * @return bool Whether the record has been processed
         */
        public function emergency(string $channel, string $message, array $context = []): bool
        {
            return $this->log($channel, Logger::EMERGENCY, $message, $context);
        }
    }
    

    App\Providers\AppServiceProvider.php (add to register function)

    //Facade to Object binding
    $this->app->bind('LogToChannels', 'App\Helpers\LogToChannels');
    

    config\app.php (add to aliases)

    // Custom Alias Class
    'Log' => App\Contracts\Facades\LogToChannels::class
    

    Then anywhere in your app you can call

    Log::info('logger_name', 'Log message');
    Log::error('other_logger_name', 'Log message', $someContext);
    

    You can even customize your logger output by calling

    Log::addChannel('channel_name', $customHandler);
    

    And it will be accessible when you will call its name anywhere in your app.

提交回复
热议问题