befuturein / laravel-log-enhancer
A lightweight Laravel package that enriches your logs with structured request, user, and application context.
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/befuturein/laravel-log-enhancer
Requires
- php: ^8.1
- illuminate/contracts: ^10.0|^11.0
- illuminate/http: ^10.0|^11.0
- illuminate/support: ^10.0|^11.0
Requires (Dev)
- laravel/pint: ^1.0
- orchestra/testbench: ^8.0|^9.0
- phpunit/phpunit: ^10.0
README
A lightweight, framework-friendly Laravel package that enriches your logs with structured context such as request data, authenticated user information, correlation IDs, and application metadata.
This package is designed to be:
- Non-intrusive – opt-in via configuration and logging taps.
- Framework-friendly – built for Laravel 10+ and 11.
- Production-ready – focuses on predictable, structured context and safe redaction.
Features
- Adds a correlation ID to every HTTP request (header or generated).
- Provides a
ContextResolverthat builds a consistent context array. - Optional Laravel logging tap (
ContextTap) to push context into Monolog records. - Simple
LogEnhancerfacade helper for manually merging context into log calls. - Configurable redaction for sensitive keys (e.g.
password,token). - Minimal dependencies, focused only on request and authentication context.
Installation
Install the package via Composer:
composer require befuturein/laravel-log-enhancer
The package uses Laravel's automatic package discovery. No manual registration is required.
Configuration
Publish the configuration file:
php artisan vendor:publish --provider="BeFuture\LogEnhancer\LogEnhancerServiceProvider" --tag="log-enhancer-config"
This will create a config/log-enhancer.php file. The default options look like this (simplified):
return [ 'enabled' => true, 'correlation' => [ 'header' => 'X-Correlation-Id', ], 'context' => [ 'include_request' => true, 'include_user' => true, 'include_app' => true, ], 'redact' => [ 'keys' => ['password', 'password_confirmation', 'token'], 'mask' => '***', ], ];
Adjust these options according to your security and observability requirements.
HTTP Middleware
The package ships with a middleware that ensures each request has a correlation ID.
Register the middleware in your HTTP kernel (or route group):
use BeFuture\LogEnhancer\Middleware\InjectLogContext; protected $middleware = [ // ... InjectLogContext::class, ];
Or in a specific group:
protected $middlewareGroups = [ 'web' => [ // ... \BeFuture\LogEnhancer\Middleware\InjectLogContext::class, ], ];
Logging Tap (Automatic Context Injection)
To automatically inject context into a specific log channel, register the tap class in your config/logging.php:
'channels' => [ 'stack' => [ 'driver' => 'stack', 'channels' => ['single'], 'tap' => [ \BeFuture\LogEnhancer\Logging\ContextTap::class, ], ], ],
The ContextTap will push a Monolog processor that merges the resolved context into the extra payload of each log record.
Manual Usage via Facade
You can also manually merge context into your logs using the LogEnhancer facade:
use Illuminate\Support\Facades\Log; use BeFuture\LogEnhancer\Facades\LogEnhancer; Log::info('User updated profile', LogEnhancer::context([ 'custom_note' => 'profile_update', ]));
The context() method will merge:
- Request metadata (method, path, IP, user agent, correlation ID).
- Authenticated user data (ID, type, and optionally email/name if available).
- Application metadata (environment, app name).
Any keys configured in the redact.keys setting will be masked.
Testing
The package includes a basic test suite powered by orchestra/testbench.
Run tests with:
composer test
or directly via PHPUnit:
./vendor/bin/phpunit
Coding Style
This repository ships with a Laravel Pint configuration:
./vendor/bin/pint
CI / GitHub Actions
A sample GitHub Actions workflow is provided under .github/workflows/tests.yml. It runs:
- Installation with Composer.
- Static analysis via
php -l(syntax check). - PHPUnit test suite.
- Laravel Pint for code style.
You can adjust or extend this workflow based on your project needs.
License
This package is open-sourced software licensed under the MIT license.