A PHP class to save/log/mail errors/notifications from your app or from /var/log/
as they appear.
Using git
$ git clone https://github.com/samayo/autolog.git
Using composer
$ composer require samayo/autolog
To quickly email a user activity log
require __DIR__ . "/src/Logger.php";
$log = new Autolog\Logger(["email" => "[email protected]"]);
if($comment){
$log->log("$user just commented \n $comment", $log::INFO, $log::EMAIL);
}
The $log->log()
method accepts 4 arguments, but only the first $msg
is required.
/**
* $msg (required) the actual content to send/log
* $type (optional) the message type: error, info, notification..
* $handler (optional) where to send it (db, email, file log)
* $verbosity (optional) log as simple or verbose info
*/
log($msg, $type, $handler, $verbosity);
Available log types, handlers, and verbosity
$type::INFO; // for simple tasks
$type::ERROR; // for errors ex: 404 ..
$type::ALERT; // for fatal errors or suspicious activity
$handler::EMAIL; // send to email
$handler::FILE; // write to file
$handler::DATABASE; // insert to database
$handler::SMS; // send to sms (not yet implemented)
$verbosity::SIMPLE; // send simplified log
$verbosity::VERBOSE; // send every log information
// the below will log an error, in verbose format and mail it
$log = new Autolog\Logger(["email" => "[email protected]"]);
$log->log($msg, $log::ERROR, $log::EMAIL, $log::VERBOSE);
By passing only the first arg: $log->log($msg)
the log will tread as ERROR
, EMAIL
, VERBOSE
$log = new Autolog\Logger;
$log["email"] = "[email protected]"; // add email
// or add your email list this:
$log = new Autolog\Logger(["email" => "[email protected]"]);
// then log it!
if($something){
$log->log("something"); // email 'something'
}
To log to a file, you need to pass a writable file to error.log
$log = new Autolog\Logger(["error.log" => __DIR__ . "/mylogs.txt"]);
$log->log("ERROR: $error", $log::INFO, $log::FILE); // don't forget $log::FILE
To store your logs in a database, create a db with these schema
--- database name can be anything, but table and columns should be as seen below
CREATE DATABASE IF NOT EXISTS autolog;
USE autolog;
CREATE TABLE `logs` (
`id` INT NOT NULL AUTO_INCREMENT,
`time` DATETIME DEFAULT NULL,
`subject` VARCHAR(255) DEFAULT NULL,
`level` VARCHAR(50) DEFAULT NULL,
`message` TEXT,
PRIMARY KEY (id)
) ENGINE=INNODB DEFAULT CHARSET=utf8mb4
Then log your info/error after calling the pdo()
PDO object
$log = new Autolog\Logger;
$log->pdo(new \PDO(
// your pdo host, db, pass here
));
$log->log("simple log", $log::ERROR, $log::DATABASE);
You can even quickly chain methods as:
(new \Autolog\Logger)
->pdo(new PDO(/**/))->log("user: $user modified his/her profile", $log::INFO, $log::DATABASE);
To log all your exceptions/errors use example below:
$logger = Autolog\Logger(["email" => "[email protected]"]);
// mail all thrown exceptions
set_exception_handler(function($e) use($logger){
$logger->log($e, $log::ERROR, $log::EMAIL);
});
// mail all errors
set_error_handler(function($no, $str, $file, $line) use ($logger){
$logger->log("Your site has error: $str in file $file at line $line", $log::ERROR, $log::EMAIL);
})
To automatically detect log file changes and log messages, use watch()
method.
// always watch new errors that appear in (nginx, php) log files
$log->watch(true);
To watch new logs and get notified, place the watch()
method in it's own file like: log_mailer.php
// log_mailer.php
require __DIR__ . "/src/Logger.php";
(new Autolog\Logger([
"nginx.log" => "/var/log/nginx/error.log",
"php-fpm.log" => "/var/log/php-fpm/error.log",
"mariadb.log" => "/var/log/mariadb/mariadb.log",
"access.log" => "access.txt",
"email" => "[email protected]"
]))->watch(true);
Now, you can set a cronjob that executes the above script every min/hour then you'll get a new mail everytime a new error is logged in /var/log/...
It is important give the access.log
a file where the last time like: nginx.log is accessed.
This is because to detect new error, you must store the timestamp of the last time we check nginx.log
So, if the mtime for nginx file is not the same as we have stored, it means a new log is found ~