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

v1.0.0 2025-11-29 11:09 UTC

This package is auto-updated.

Last update: 2025-11-29 11:45:11 UTC


README

Latest Version on Packagist Total Downloads GitHub Tests License

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 ContextResolver that builds a consistent context array.
  • Optional Laravel logging tap (ContextTap) to push context into Monolog records.
  • Simple LogEnhancer facade 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.