guidofaecke / laminas-airbrake
Airbrake (phpbrake) integration for Laminas
Requires
- php: ^7.4 || ^8.0
- airbrake/phpbrake: ^0.3
- laminas/laminas-component-installer: ^2.4.0 || ^3.0.0
- laminas/laminas-http: ^2.16
- laminas/laminas-mvc: ^3.3
- laminas/laminas-stdlib: ^3.13
- psr/container: ^1.1.2
Requires (Dev)
- doctrine/coding-standard: ^9.0
- laminas/laminas-coding-standard: ^2.3
- roave/security-advisories: dev-latest
- slevomat/coding-standard: ^7.2
- squizlabs/php_codesniffer: ^3.6
- vimeo/psalm: ^4.29
This package is auto-updated.
Last update: 2024-10-30 01:43:04 UTC
README
Airbrake (phpbrake) integration for Laminas.
Airbrake is a tool that captures and tracks your application's exceptions. This library connects your Laminas application to Airbrake, to make exception tracking possible. It is also possible to use Laminas Airbrake with different services that use the Airbrake protocol, like CodebaseHQ.
Installing
Use composer to install this module.
composer require guidofaecke/laminas-airbrake
After composer installation, make sure that the \guidofaecke\LaminasAirbrake module is added to the module configuration.
In most cases, the module configuration can be found in config/module.config.php
Connection configuration
It is required to correctly set the connection settings to connect to the Airbrake instance. These can be set in the
local Zend configuration (config/autoload/local.php
).
<?php return [ 'laminas_airbrake' => [ 'connection' => [ 'projectId' => YOUR_PROJECT_ID, 'projectKey' => YOUR_PROJECT_KEY, 'host' => YOUR_AIRBRAKE_HOST ] ] ];
Custom airbrake filters
Custom filters can be defined to add extra params to the airbrake notification, or to alter context information.
Writing a custom airbrake filter
Custom airbrake filters should be either functions requiring a notice array as paramater (as with https://github.com/airbrake/phpbrake), or a class implementing the FilterInterface (recommended).
For example:
<?php use guidofaecke\LaminasAirbrake\Filter\FilterInterface; class HelloWorldFilter implements FilterInterface { public function __invoke($notice) { $notice['params']['hello'] = 'world'; return $notice; } }
To make sure the filter is used by Laminas Airbrake, it should be added to the configuration.
<?php return [ 'laminas_airbrake' => [ // Your connections string etc. 'filters' => [ HelloWorldFilter::class ] ] ];
It is possible to use a factory for your Laminas Airbrake filters. To make use of this, simply add the filter to your service manager configuration.
Disabling airbrake for development environments
You might want to disable airbrake in the development environment. To do this, you can use the local zend configuration,
and set the log_errors
configuration option to false.
For example, file: config/autload/local.php
<?php return [ // Your connections string, filters etc. 'laminas_airbrake' => [ 'log_errors' => false ] ];
Via the laminas local configuration, it is also possible to use different connection settings or different filters for different environments.