engvanntha/request-trace

Request-aware class/function/variable logging for Laravel applications.

Maintainers

Package info

github.com/engvanntha/request-trace

pkg:composer/engvanntha/request-trace

Statistics

Installs: 1

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v1.0.0 2026-02-27 08:36 UTC

This package is auto-updated.

Last update: 2026-04-27 09:01:47 UTC


README

Reusable request-aware logging package for Laravel 5.8 through 12.

Installation

composer require engvanntha/request-trace

Features

  • Captures X-Request-Id from incoming HTTP requests (falls back to generated UUID).
  • Auto logs all client requests/responses with Class@method (no per-function calls).
  • Provides RequestTraceTrait for class/function/variable-aware logs.
  • Supports variable selection and sensitive-field masking.
  • Works in controllers, services, middleware, and other classes.

Trait usage

use Engvanntha\RequestTrace\Traits\RequestTraceTrait;

class ClassName
{
    use RequestTraceTrait;

    public function functionName(array $data)
    {
        $user = $this->queryUser($data);

        // Log one variable
        $this->traceLog('user', $user);

        // Log selected variables only
        $this->traceLogVars(compact('data', 'user'), array('user'));

        return $user;
    }
}

Generated message format:

<X-Request-Id>@<CurrentProjectName>@<ClassName>@<functionName>@<variableName>

Middleware

Register middleware:

\Engvanntha\RequestTrace\Middleware\CaptureRequestTrace::class

This middleware should run early in the HTTP stack.

With auto_log_requests=true, each request is logged automatically in format:

<X-Request-Id>@<CurrentProjectName>@<ClassName>@<functionName>@<request|response>

Use RequestTraceTrait only for additional deep logs inside selected services/functions.