Skip to content

Latest commit

 

History

History
46 lines (37 loc) · 1.37 KB

README.md

File metadata and controls

46 lines (37 loc) · 1.37 KB

PHP Elastic APM for Laravel & Lumen

Laravel package of the https://github.com/philkra/elastic-apm-php-agent library, automatically handling transactions and errors/exceptions. If using Illuminate\Support\Facades\Auth the user Id added to the context. Tested with Laravel 5.6.* and the philkra/elastic-apm-php-agent version 6.2.*.

Install

composer require philkra/elastic-apm-laravel

Middleware

Laravel

Register as (e.g.) global middleware to be called with every request. https://laravel.com/docs/5.6/middleware#global-middleware

Register the middleware in app/Http/Kernel.php

protected $middleware = [
    // ... more middleware
    \PhilKra\Middleware\Elastic\ApmAgent::class,
];

Lumen

In bootstrap/app.php register PhilKra\Middleware\Elastic\ApmAgent::class as middleware:

$app->middleware([
    PhilKra\Middleware\Elastic\ApmAgent::class
]);

Error/Exception Handling

Laravel

Replace the default exception handler with overloading APM handler. The APM class is extending Laravel's "default" exception handler app/Exceptions/Handler. In bootstrap/app.php remove the default handler App\Exceptions\Handler::class with PhilKra\Exceptions\Elastic\ApmAgent::class.

$app->singleton(
    Illuminate\Contracts\Debug\ExceptionHandler::class,
    PhilKra\Exceptions\Elastic\ApmAgent::class
);

Lumen

not tested yet.