Skip to content

Latest commit

 

History

History
179 lines (137 loc) · 5.63 KB

readme.md

File metadata and controls

179 lines (137 loc) · 5.63 KB

laravel-mysql-email-log

Save logs handled by Laravel in Mysql, and send mail when it is over specified level.

Travis composer version licence laravel version

Table of content

Install

composer:

composer require kaoken/laravel-mysql-email-log

or, add composer.json

  "require": {
    ...
    "kaoken/laravel-mysql-email-log":"^1.8.5"
  }

Setting

Add to config\app.php as follows:

    'providers' => [
        ...
        // Add
        Kaoken\LaravelMysqlEmailLog\LaravelMysqlEmailLogServiceProvider::class
    ],

Add to config\database.php as follows:

    'connections' => [
        ...
        'mysql' => [
            'driver' => 'mysql',
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'strict' => true,
            'engine' => null,
        ],
        // Add (Copy 'mysql' above)
        'mysql_log' => [
            'driver' => 'mysql',
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'strict' => true,
            'engine' => null,
        ],
        ...

Copy the above ['connections']['mysql'] and set the driver name to mysql_log. This is necessary to prevent the log from being lost due to rollback after writing the log when doing transaction processing (DB :: transaction, DB :: beginTransaction etc.) with the driver name mysql.

Add to config\logging.php as follows:

  • driver is a monolog.
  • handler is a Kaoken\LaravelMysqlEmailLog\LaravelMysqlEmailLogHandler::class.
  • model is a log model.
  • email sends a mail according to email_send_level if it is true. In case of false, do not send anything.
  • email_send_level specifies the log level and send from the specified log level or higher. Since the priority is low, DEBUGINFONOTICEWARNINGERRORCRITICALALERTEMERGENCY.Capital letters and lower case letters are not distinguished.
  • email_log should modify the class derived from Mailable as necessary. Send log mail.
  • email_send_limit should modify the class derived from Mailable as necessary. Send when e-mail transmission limit max_email_send_count is exceeded.
  • max_email_send_count, the log e-mail that can be transmitted in one day. A simple warning mail is sent when the number exceeds the number of transmissions. See email_send_level.
  • to is the destination of the mail.
    // Add
    'mysql_log' => [
        'driver' => 'monolog',
        'handler' => Kaoken\LaravelMysqlEmailLog\LaravelMysqlEmailLogHandler::class,
        'model' => Kaoken\LaravelMysqlEmailLog\Model\Log::class,
        'email' => true,
        'email_send_level' => 'ERROR',
        'email_log' => Kaoken\LaravelMysqlEmailLog\Mail\LogMailToAdmin::class,
        'email_send_limit' => Kaoken\LaravelMysqlEmailLog\Mail\SendLimitMailToAdmin::class,
        'max_email_send_count' => 64,
        'to' => 'hoge@hoge.com'
    ],

Modify .env to enable logging

Make corrections as follows

LOG_CHANNEL=mysql_log

Command

php artisan vendor:publish --tag=mysql-email-log

After execution, the following directories and files are added.

  • database
    • migrations
      • 2017_09_17_000001_create_logs_table.php
  • resources
    • views
      • vendor
        • mysql_email_log
          • log.blade.php
          • over_limit.blade.php

Migration

Migration file 2017_09_17_000001_create_logs_table.php should be modified as necessary.

php artisan migrate

E-Mail

In the configuration config\logging.php of the above setting, The Kaoken\LaravelMysqlEmailLog\Mail\ConfirmationMailToUser::class of email_log is used as the log mail of the target level or higher. The template uses views\vendor\mysql_email_log\log.blade.php. Change according to the specifications of the application.

The Kaoken\LaravelMysqlEmailLog\Mail\ConfirmationMailToUser::class of email_send_limit is used when the log above the target level reaches the send limit. The template uses views\vendor\mysql_email_log\over_limit.blade.php. Change according to the specifications of the application.

Event

See inside the vendor\laravel-mysql-email-log\src\Events directory!

BeforeWriteLogEvent

Called before writing the log.

License

MIT