dremecker/bfw-logger

This package is abandoned and no longer maintained. The author suggests using the aetiom/bfw-logger package instead.

Advanced log module for BFW framework

1.0.1 2016-03-05 00:00 UTC

This package is not auto-updated.

Last update: 2022-02-01 13:05:21 UTC


README

#BFW Logger Advanced log module for BFW framework

BFW Logger manage your log records by sending its into log files and allow you to rotate, compress and flush your logs (all fully configurable). This module implements the PSR-3 interface and default classes, so you can use PSR-3 log levels and PSR-3 logger interface methods.

##Before installing

You must have installed BFW framework before using this log module. You can find more information about BFW here : https://github.com/bulton-fr/bfw

##Installation

We recommand using composer for installing "BFW Logger". You can get composer by executing this command line :

$ curl -sS https://getcomposer.org/installer | php

Create (or open) the "composer.json" file at the root of your project and add :

{
    "require": {
        "dremecker/bfw-advanced-log": "@stable"
    }
}

Then launch module installation by executing:

$ php composer.phar install

And launch BFW module loading :

$ sh ./vendor/bin/bfw_loadModules

##Configuring BFW Logger

After a successfull install, you will find in "/configs/bfw-advanced-log" two files that will help you to configure BFW Logger.

  • "configs.php" is used to configure options for the logger and the log handlers.
  • "channels" allow you to create an array of channels with : channel names as key (in string), and channel log handler options as value (in \BFWLog\logOptions).

This files are commented and full of multiple examples, so we will not go further for the moment.

##Using BFW Logger

The logger instance is initialised for each page request. You can access it with:

<?php


$log

Before sending message to the logger, you must set a channel. For doing so:

<?php

$log->setChannel('ChannelName');

Because BFW Logger implements PSR-3 standarts, you can call PSR-3 logger interface methods just like this:

<?php

$log->setChannel('ChannelName');

$log->warning('Warning Message');
$log->error('Error Message !');

PSR-3 log() method is also available (see PSR-3 standarts for more informations):

<?php

$log->setChannel('ChannelName');

$log->log($PSR3_LogLevel, 'Message', $context);

You can also call BFW Logger archiveLogFiles() method for processing log files archiving. We recommend you to call this method into a crontab php script for avoiding latency due to compression (if you have enabled it), and huge file rotation. This method purpose is to offer you a way to replace logrotate, in a very light and simple form, if you cannot access it on your actual hosting service.

As you may have notice, you always have to set channel before using it. It's a bit different with archiveLogFiles() method. If you have not preset channels in configuration file, you will have to set ALL CHANNELS USED IN YOUR PROJECT that you want to archive before calling archiveLogFiles() method just like this:

<?php

$log->setChannel('ChannelName-1');
$log->setChannel('ChannelName-2');

$log->archiveLogFiles();

If all your channels have been setup into configuration file, you can just call archiveLogFiles() method without anything else:

<?php

$log->archiveLogFiles();