Part of Jardis — the Domain-Driven Design platform for PHP. You model your domain; Jardis generates the production-ready hexagonal code (DTOs, Command/Query handlers, repositories, persistence). This package is part of the open-source foundation that generated code runs on.
A PSR-3 logger for PHP with a pipeline of 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.
- 20+ Handlers — File, Console, Slack, Teams, Redis, Kafka, RabbitMQ, Loki, Database, Email, Webhook, Syslog, and more
- Smart Handlers —
LogFingersCrossed(buffer-on-error),LogSampling(volume reduction),LogConditional(rule-based routing) - Fluent Builder —
LoggerBuilderchains handler registration;getLogger()returns an immutableLogger - Auto-Enrichment —
LogDateTime,LogUuid,LogMemoryUsage,LogMemoryPeak,LogClientIp,LogWebRequestadded per handler - 7 Formatters —
LogJsonFormat,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
LoggerBuilderinstance scopes its handlers to a named bounded context
composer require jardisadapter/loggeruse 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']);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');Full documentation, guides, and API reference:
docs.jardis.io/en/adapter/logger
This package is licensed under the MIT License.
Jardis · Documentation · Headgent
Dieses Package liefert einen Skill für Claude Code, Cursor, Continue und Aider mit. Installation im Konsumentenprojekt:
composer require --dev jardis/dev-skillsMehr Details: https://docs.jardis.io/en/skills