A native CakePHP 5.x plugin for Airbrake error tracking and exception monitoring. Automatically captures and reports exceptions, PHP errors, and log messages to Airbrake using API v3. This plugin does not depend on the legacy phpairbrake SDK.
No external dependencies - uses CakePHP's built-in HTTP client.
- Native implementation using Airbrake API v3
- No phpairbrake SDK dependency
- Automatic exception and error tracking
- Seamless integration with CakePHP's error handling system
- Log engine for sending log messages to Airbrake
- Request context (URL, HTTP method, route, user agent, etc.)
- CakePHP route information (controller, action, prefix)
- User identification support (CakePHP Authentication plugin)
- Sensitive data filtering (passwords, tokens, etc.)
- Support for self-hosted Airbrake (Errbit)
- Environment-based configuration
- Zero external dependencies
- PHP 8.1 or higher
- CakePHP 5.x
- Airbrake account (or self-hosted Errbit)
Install the plugin using Composer:
composer require salines/cakephp-airbrakeIf your application previously used the phpairbrake SDK, you can remove it from composer.json and keep the same Airbrake credentials. This plugin provides its own notifier (CakeAirbrake\Notifier) and sends notices directly using CakePHP's HTTP client.
Add the plugin to your src/Application.php:
use CakeAirbrake\CakeAirbrakePlugin;
public function bootstrap(): void
{
parent::bootstrap();
$this->addPlugin(CakeAirbrakePlugin::class);
}Add the Airbrake configuration to your config/app.php:
'Airbrake' => [
'projectId' => env('AIRBRAKE_PROJECT_ID'),
'projectKey' => env('AIRBRAKE_PROJECT_KEY'),
'environment' => env('APP_ENV', 'production'),
'appVersion' => '1.0.0',
'host' => 'https://api.airbrake.io', // Change for self-hosted
'enabled' => true,
'rootDirectory' => ROOT,
'keysBlocklist' => [
'/password/i',
'/secret/i',
'/token/i',
'/authorization/i',
'/api_key/i',
],
],To automatically send all exceptions and errors to Airbrake, configure the error logger in config/app.php:
'Error' => [
'errorLevel' => E_ALL,
'exceptionRenderer' => \Cake\Error\Renderer\WebExceptionRenderer::class,
'skipLog' => [],
'log' => true,
'trace' => true,
'logger' => \CakeAirbrake\Error\AirbrakeErrorLogger::class,
],To send log messages to Airbrake, add the log engine configuration:
'Log' => [
'airbrake' => [
'className' => 'CakeAirbrake.Airbrake',
'levels' => ['warning', 'error', 'critical', 'alert', 'emergency'],
],
],The log engine automatically uses the global Airbrake configuration.
You can configure the plugin using environment variables:
AIRBRAKE_PROJECT_ID=123456
AIRBRAKE_PROJECT_KEY=your-project-key
AIRBRAKE_HOST=https://api.airbrake.io
AIRBRAKE_ENABLED=true
APP_ENV=productionOnce configured with the error logger, all uncaught exceptions and PHP errors will automatically be sent to Airbrake.
You can manually send exceptions to Airbrake:
use CakeAirbrake\Notifier;
use Cake\Core\Configure;
try {
// Your code
} catch (\Exception $e) {
$notifier = new Notifier(Configure::read('Airbrake'));
$notifier->notify($e);
}Send log messages to Airbrake:
use Cake\Log\Log;
Log::error('Something went wrong', ['scope' => 'airbrake']);
Log::critical('Database connection failed');
// With exception context
Log::error('Operation failed', [
'exception' => $e,
'user_id' => 123,
]);You can add custom context to your error reports using filters:
use CakeAirbrake\Notifier;
use Cake\Core\Configure;
$notifier = new Notifier(Configure::read('Airbrake'));
$notifier->addFilter(function ($notice) {
$notice['context']['customField'] = 'customValue';
$notice['params']['orderId'] = 12345;
return $notice;
});
$notifier->notify($exception);You can prevent certain notices from being sent by returning null from a filter:
$notifier->addFilter(function ($notice) {
// Don't send 404 errors
if (str_contains($notice['errors'][0]['type'], 'NotFoundException')) {
return null;
}
return $notice;
});You can set the severity level for notices:
$notifier = new Notifier(Configure::read('Airbrake'));
$notice = $notifier->buildNotice($exception);
$notice['context']['severity'] = 'critical'; // debug, info, notice, warning, error, critical
$notifier->sendNotice($notice);You can test delivery without a real Airbrake project by sending notices to a webhook.site URL.
- Create a new endpoint at https://webhook.site and copy the unique URL.
- Configure a custom notices URL:
'Airbrake' => [
'projectId' => 1,
'projectKey' => 'test-key',
'customNoticesUrl' => 'https://webhook.site/your-unique-id',
],- Trigger a test notice:
use CakeAirbrake\Notifier;
use Cake\Core\Configure;
$notifier = new Notifier(Configure::read('Airbrake'));
$notifier->notify(new \RuntimeException('Webhook test notice'));Open the webhook.site page to inspect the JSON payload.
| Option | Type | Default | Description |
|---|---|---|---|
projectId |
int | null | Your Airbrake project ID (required) |
projectKey |
string | null | Your Airbrake project key (required) |
environment |
string | 'production' | Environment name |
appVersion |
string | null | Application version |
host |
string | 'https://api.airbrake.io' | Airbrake API host |
enabled |
bool | true | Enable/disable Airbrake reporting |
keysBlocklist |
array | [...] | Regex patterns for sensitive keys to filter |
rootDirectory |
string | ROOT | Root directory for backtrace filtering |
httpClientOptions |
array | ['timeout' => 10] | Options for CakePHP HTTP Client |
To use with a self-hosted Airbrake server like Errbit:
'Airbrake' => [
'projectId' => 1,
'projectKey' => 'your-api-key',
'host' => 'https://your-errbit-server.com',
// ... other options
],The plugin automatically filters sensitive data based on the keysBlocklist configuration. By default, it filters keys matching:
/password/i/secret/i/token/i/authorization/i/api_key/i/apikey/i/access_token/i
You can add your own patterns:
'keysBlocklist' => [
'/password/i',
'/secret/i',
'/credit_card/i',
'/ssn/i',
'/cvv/i',
],You can disable Airbrake in development:
'Airbrake' => [
// ... other config
'enabled' => !Configure::read('debug'),
],Or using environment variables:
AIRBRAKE_ENABLED=falseThe plugin sends notices to Airbrake in the following structure (API v3):
{
"errors": [{
"type": "RuntimeException",
"message": "Something went wrong",
"backtrace": [...]
}],
"context": {
"notifier": {"name": "cakephp-airbrake", "version": "1.0.0"},
"environment": "production",
"hostname": "server-01",
"os": "Linux",
"language": "PHP 8.1.0",
"severity": "error",
"url": "https://example.com/users/123",
"httpMethod": "GET",
"route": "/Users/view",
"component": "Users",
"action": "view",
"user": {"id": 1, "name": "John", "email": "john@example.com"}
},
"environment": {...},
"params": {...},
"session": {...}
}Run the tests:
composer install
./vendor/bin/phpunitContributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.