rianfuro / laravel-teams-logging
Laravel handler for sending messages to Microsoft Teams using the Incoming Webhook connector
Requires
- php: ^7.1|^8.0
- ext-curl: *
- ext-json: *
- monolog/monolog: ^1.23|^2.0
README
Laravel handler for sending messages to Microsoft Teams using the Incoming Webhook connector.
Installation
Require this package with composer.
$ composer require rianfuro/laravel-teams-logging
Integration
Package tested and working with Laravel and Lumen framework (5.7+).
Laravel: After installation using composer finishes up, you'll have to add the following line to your config/app.php
:
RianFuro\LaravelTeamsLogging\LoggerServiceProvider::class
Lumen: For Lumen, you'll have to add the following line to your bootstrap/app.php
:
$app->register(RianFuro\LaravelTeamsLogging\LoggerServiceProvider::class);
Laravel: Then copy teams
config file from laravel-teams-logging to your config folder:
$ php artisan vendor:publish --provider="RianFuro\LaravelTeamsLogging\LoggerServiceProvider"
Lumen: For Lumen, you need to copy file manually to your config folder and enable it in bootstrap/app.php
:
$app->configure('teams');
Create a custom channel using laravel logging file or create new logging config file for lumen.
Add this configuration to config/logging.php
file
'teams' => [ 'driver' => 'custom', 'via' => \RianFuro\LaravelTeamsLogging\LoggerChannel::class, 'level' => 'debug', 'url' => env('INCOMING_WEBHOOK_URL'), 'style' => 'simple', // Available style is 'simple' and 'card', default is 'simple' ],
or simply add name to specify different project name for each connector.
'teams' => [ 'driver' => 'custom', 'via' => \RianFuro\LaravelTeamsLogging\LoggerChannel::class, 'level' => 'debug', 'url' => env('INCOMING_WEBHOOK_URL'), 'style' => 'simple', // Available style is 'simple' and 'card', default is 'simple' 'name' => 'Dummy Project' ],
There are 2 available styles for microsoft teams message, using simple and card. You can see card style in results style which is difference from simple style.
After added configs to your config/logging.php
file, add INCOMING_WEBHOOK_URL
variable to your .env
file with connector url from your microsoft teams connector. Please read microsoft teams document to find your connector url.
Usage
To send a simple error message to teams channel:
Log::channel('teams')->error('Error message');
Or you can include additional info to card message using log context.
Log::channel('teams')->error('Error message', [ [ 'name' => 'Assigned to', 'value' => 'Unassigned', ] ]);
When using simple style, the logging context will be ignored.
You can also add teams
to the default stack
channel so all errors are automatically send to the teams
channel.
'channels' => [ 'stack' => [ 'driver' => 'stack', 'channels' => ['single', 'teams'], ], ],
Results
Here are some results of notifications sent to microsoft teams channel using card style.
License
This package is available under the MIT license. See the LICENSE file for more info.