Sends monolog notifications through the gitter.im api to a targeted gitter chat room.
With composer:
composer require "nackjicholson/monolog-gitter-im=1.x"
or in composer.json
:
"require": {
"nackjicholson/monolog-gitter-im": "1.x"
}
// Default level is Logger::CRITICAL
$gitterHandler = new GitterImHandler('apiToken', 'roomId');
$logger = new Logger('gitterIm.example');
$logger->pushHandler($gitterHandler);
$logger->debug('debug will not go', ['ctx' => 'minutia']);
$logger->critical('A gitter.im critical monolog', ['ctx' => 'investigate']);
$logger->alert('A gitter.im alert monolog', ['ctx' => 'take action']);
$logger->emergency('A gitter.im emergency monolog', ['ctx' => 'boom!']);
This example will make separate requests to gitter api making one message for each of the monolog calls that are
>= Logger::CRITICAL
.
Wrapping the GitterImHandler
with monolog's built in BufferHandler
makes it possible for you
to only make one buffered message per execution of your program. All logs which are to be sent to Gitter are
buffered and then when the program exits, they are all sent to the chat room as one batched message.
Setup is straight-forward:
$gitterHandler = new GitterImHandler('apiToken', 'roomId');
$bufferHandler = new BufferHandler($gitterHandler);
$logger = new Logger('gitterIm.buffered.example');
$logger->pushHandler($bufferHandler);
Author:
Will Vaughn
@nackjicholsonn
github:nackjicholson