jlaso / simple-logger
A simple logger for your PHP apps
Requires
- php: >=5.4
- symfony/yaml: *
Requires (Dev)
- mockery/mockery: 0.9.1
- phpunit/phpunit: ~4.0
- symfony/console: 2.4.1
This package is auto-updated.
Last update: 2024-12-15 11:34:18 UTC
README
simple-logger
A simple logger system
Installation
You need only to require this package in your project composer require jlaso/simple-logger
Configuration (optional)
In order to let know the library where can put its database file and other things related with setup you can copy the distribution file config-simple-logger.yml.dist
in the root of your project with the config-simple-logger.yml
This file contains:
# vendor/jlaso/simple-logger/config-simple-logger.yml.dist
logger:
path: "%project_dir%/cache/logger-%date%.log"
levels: error,info,debug
date_format: "Y-m-d"
Commands
In order to check log file you can use src/console log:filter [--with=word1,word2,...] [--levels=error,info] [--date-from="2016-01-01 00:00:00"]
Running the example
Go to terminal and start the demo example php demo.php
<?php
error_reporting(E_ALL & !E_WARNING);
require_once __DIR__.'/vendor/autoload.php';
use JLaso\SimpleLogger\PlainFileLogger as Logger;
$start = microtime(true);
Logger::info("This is only the start of the program");
Logger::debug(array(
'title' => 'This is the title',
'data' => 'more data',
));
$a = 1234/ $b;
set_error_handler('error_handler');
function error_handler($e)
{
Logger::error($e);
}
Logger::info('Just finishing the execution of the program in '.intval((microtime(true)-$start)*1000).' msec !');
Implementing the filter command in your app
You can see an example of how to do that (https://github.com/jlaso/simple-stats-demo/tree/master/app)[https://github.com/jlaso/simple-stats-demo/tree/master/app]
<?php
namespace App\Command;
use JLaso\SimpleLogger\Command\FilterCommand;
class FilterLogCommand extends FilterCommand
{
}
add it to app/console
#!/usr/bin/env php
<?php
namespace JLaso\SimpleStats;
require_once __DIR__ . '/../vendor/autoload.php';
use App\Command\FilterLogCommand; <======
use App\Command\PostDeployCommand;
use Symfony\Component\Console\Application;
$application = new Application();
$application->addCommands(
array(
new PostDeployCommand(),
new FilterLogCommand(), <======
)
);
$application->run();