markhilton / monolog-mysql
Laravel 8 MySQL driver for Monolog
Installs: 114 071
Dependents: 0
Suggesters: 0
Security: 0
Stars: 41
Watchers: 3
Forks: 19
Open Issues: 7
Requires
- php: >=5.5.9
This package is not auto-updated.
Last update: 2024-12-20 23:40:31 UTC
README
This package will log errors into MySQL database instead storage/log/laravel.log file.
Installation
composer require markhilton/monolog-mysql
Open up config/app.php
and find the providers
key.
'providers' => array( // ... Logger\Laravel\Provider\MonologMysqlHandlerServiceProvider::class, );
Publish config using Laravel Artisan CLI.
php artisan vendor:publish
Migrate tables - you may want to configure enviornment beforehand.
php artisan migrate
Application Integration
In your application config/logging.php
add:
use Logger\Monolog\Handler\MysqlHandler; // ... 'channels' => [ // ... 'mysql' => [ 'driver' => 'monolog', 'handler' => MysqlHandler::class, 'level' => 'debug', ], ];
Application Integration (Laravel >= 5.6)
In your application config/logging.php
add:
<?php // [...] 'channels' => [ 'stack' => [ 'driver' => 'stack', 'channels' => ['mysql'], ], // [...] 'mysql' => [ 'driver' => 'custom', 'via' => App\Logging\CreateMySQLLogger::class, ], ],
In your application app/Logging/CreateMySQLLogger.php
add:
<?php namespace App\Logging; use Exception; use Monolog\Logger; use Logger\Monolog\Handler\MysqlHandler; class CreateMySQLLogger { /** * Create a custom Monolog instance. * * @param array $config * @return Logger * @throws Exception */ public function __invoke(array $config) { $channel = $config['name'] ?? env('APP_ENV'); $monolog = new Logger($channel); $monolog->pushHandler(new MysqlHandler()); return $monolog; } }
Environment configuration
If you wish to change default table name to write the log into or database connection use following definitions in your .env file
DB_LOG_TABLE=logs DB_LOG_CONNECTION=mysql
Credits
Based on:
- [Pedro Fornaza] (https://github.com/pedrofornaza/monolog-mysql)