guidofaecke/laminas-airbrake

Airbrake (phpbrake) integration for Laminas

0.2.5 2022-12-03 21:34 UTC

This package is auto-updated.

Last update: 2024-03-01 00:14:43 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.