PSR-3 logging pipeline with 20+ handlers, 7 formatters, 6 enrichers, and fluent builder API

Maintainers

Package info

github.com/jardisAdapter/logger

pkg:composer/jardisadapter/logger

Statistics

Installs: 98

Dependents: 1

Suggesters: 0

Stars: 0

Open Issues: 0

v1.0.0 2026-03-18 07:43 UTC

This package is auto-updated.

Last update: 2026-03-31 08:24:15 UTC


README

Build Status License: PolyForm Shield PHP Version PHPStan Level PSR-12 PSR-3 Coverage

Part of the Jardis Business Platform — Enterprise-grade PHP components for Domain-Driven Design

PSR-3 logging pipeline with 20+ handlers, 7 formatters, and 6 enrichers. Configure everything through a fluent LoggerBuilder — the resulting Logger is immutable after construction. Smart handlers for production: LogFingersCrossed buffers until an error occurs, LogSampling reduces noise at high volume, LogConditional routes by content. One LoggerBuilder context per bounded context keeps logs cleanly separated.

Features

  • 20+ Handlers — File, Console, Slack, Teams, Redis, Kafka, RabbitMQ, Loki, Database, Email, Webhook, Syslog, and more
  • Smart HandlersLogFingersCrossed (buffer-on-error), LogSampling (volume reduction), LogConditional (rule-based routing)
  • Fluent BuilderLoggerBuilder chains handler registration; getLogger() returns an immutable Logger
  • Auto-EnrichmentLogDateTime, LogUuid, LogMemoryUsage, LogMemoryPeak, LogClientIp, LogWebRequest added per handler
  • 7 FormattersLogJsonFormat, LogLineFormat, LogHumanFormat, LogSlackFormat, LogTeamsFormat, LogLokiFormat, LogBrowserConsoleFormat
  • Named Handlers — Retrieve any handler at runtime via $logger->getHandler('name')
  • Error Resilience — One failing handler never stops the others; optional error callback via setErrorHandler()
  • Context Separation — Each LoggerBuilder instance scopes its handlers to a named bounded context

Installation

composer require jardisadapter/logger

Quick Start

use JardisAdapter\Logger\LoggerBuilder;
use Psr\Log\LogLevel;

// Console + file in two lines
$logger = (new LoggerBuilder('OrderService'))
    ->addConsole(LogLevel::DEBUG)
    ->addFile(LogLevel::INFO, '/var/log/orders.log')
    ->getLogger();

$logger->info('Order created', ['order_id' => 4711]);
$logger->error('Payment failed', ['order_id' => 4711, 'reason' => 'Card declined']);

Advanced Usage

use JardisAdapter\Logger\LoggerBuilder;
use JardisAdapter\Logger\Handler\LogFile;
use Psr\Log\LogLevel;

// Production setup: file baseline + Slack alerts + FingersCrossed buffer + Sampling
$fileHandler = new LogFile(LogLevel::DEBUG, '/var/log/app.log');

$logger = (new LoggerBuilder('PaymentService'))
    // Always write DEBUG and above to file
    ->addHandler($fileHandler)

    // Alert on Slack for CRITICAL and above
    ->addSlack(
        logLevel: LogLevel::CRITICAL,
        webhookUrl: 'https://hooks.slack.com/services/...',
        name: 'slack-alerts'
    )

    // Buffer all messages; flush everything to file only when ERROR is triggered
    ->addFingersCrossed(
        wrappedHandler: $fileHandler,
        activationLevel: LogLevel::ERROR,
        bufferSize: 200,
        name: 'fingers-crossed'
    )

    // Reduce INFO noise to 10 % under load
    ->addSampling(
        wrappedHandler: $fileHandler,
        strategy: 'rate',
        config: ['rate' => 10],
        name: 'sampler'
    )

    ->getLogger();

$logger->info('Checkout started', ['session' => 'abc123']);
$logger->error('Stripe timeout', ['attempt' => 3]);

// Retrieve a named handler at runtime
$slackHandler = $logger->getHandler('slack-alerts');

Documentation

Full documentation, guides, and API reference:

docs.jardis.io/adapter/logger

License

This package is licensed under the PolyForm Shield License 1.0.0. Free for all use except building competing frameworks or developer tooling.

Jardis · Documentation · Headgent