Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/TheoKouzelis/laravel-airbrake
Laravel service provider for Airbrake https://github.com/airbrake/phpbrake
https://github.com/TheoKouzelis/laravel-airbrake
airbrake airbrake-notifier laravel laravel-airbrake php
Last synced: 2 months ago
JSON representation
Laravel service provider for Airbrake https://github.com/airbrake/phpbrake
- Host: GitHub
- URL: https://github.com/TheoKouzelis/laravel-airbrake
- Owner: TheoKouzelis
- License: mit
- Created: 2016-03-12T22:10:12.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-08-14T14:19:56.000Z (over 1 year ago)
- Last Synced: 2024-10-20T10:09:03.033Z (3 months ago)
- Topics: airbrake, airbrake-notifier, laravel, laravel-airbrake, php
- Language: PHP
- Size: 24.4 KB
- Stars: 25
- Watchers: 3
- Forks: 24
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - TheoKouzelis/laravel-airbrake - Laravel service provider for Airbrake https://github.com/airbrake/phpbrake (PHP)
README
# Laravel Airbrake
This is a Laravel service provider for the latest Airbrake PHP package https://github.com/airbrake/phpbrake
The service provider will configure an instance of Airbrake\Notifier with an ID, key and environment name.
## Install
Require this package via composer.
```
composer require kouz/laravel-airbrake
```
For Laravel >=5.5 the package will be discoverd. For Laravel <=5.4 add package to list of service providers in config/app.php
```
[
Kouz\LaravelAirbrake\ServiceProvider::class,
],
```
Publish and fill out the config/airbrake.php file with your ID and key.
```
php artisan vendor:publish --provider="Kouz\LaravelAirbrake\ServiceProvider"
```## Config
The variables projectId and projectKey are required. Leave the rest empty to use Airbrake's default values.
```
'projectId' => '',
'projectKey' => '',
'environment' => env('APP_ENV', 'production'),//leave the following options empty to use defaults
'host' => null, #airbrake api host e.g.: 'api.airbrake.io' or 'http://errbit.example.com
'appVersion' => null,
'revision' => null, #git revision
'rootDirectory' => null,
'keysBlacklist' => null, #list of keys containing sensitive information that must be filtered out
'httpClient' => null, #http client implementing GuzzleHttp\ClientInterface
```## Basic Usage
### >=5.6 Custom Channel
Add the custom "airbrake" channel (outlined below) to config/logging.php. Then add the "airbrake" channel to the stack channel.
```
//config/logging.php'channels' => [
'stack' => [
'driver' => 'stack',
'channels' => ['single', 'airbrake'],
],'airbrake' => [
'driver' => 'custom',
'via' => Kouz\LaravelAirbrake\AirbrakeLogger::class,
'level' => 'error',
],
]
```### Exception Handler
To notify airbrake through the laravel exception handler as shown in the following code snippet. Inject or make a new instance
of a Airbrake\Notifier object then pass a exception to the notify function.```
//app/Exceptions/Handler.php/**
* Report or log an exception.
*
* This is a great spot to send exceptions to Sentry, Bugsnag, etc.
*
* @param \Exception $exception
* @return void
*/
public function report(Exception $exception)
{
if ($this->shouldReport($exception) && App::environment(['production', 'staging'])) {
$airbrakeNotifier = \App::make('Airbrake\Notifier');
$airbrakeNotifier->notify($exception);
}parent::report($exception);
}
```### <=5.5 Custom Monolog Configuration
To configure it as a Monolog handler you will have to create a custom configuration in bootstrap/app.php. This callback function is called
before the service providers are loaded. So it is necessary to directly use our AirbrakeHandler class instead of the provider.```
//bootstrap/app.php$app->configureMonologUsing(function($monolog) use ($app) {
$airbrakeNotifier = (new Kouz\LaravelAirbrake\AirbrakeHandler($app))->handle();
$monologHandler = new Airbrake\MonologHandler($airbrakeNotifier, Monolog\Logger::ERROR);
$monolog->pushHandler($monologHandler);
});
```