Maatify Slim Logger is a lightweight, PSR-7 compatible, Slim-friendly structured logger for PHP applications. It is part of the modular Maatify ecosystem.
- ✅ PSR-7 request-aware logging (integrates with Slim Framework)
- ✅ Uses
LogLevelEnum(PHP 8.1+) - ✅ Logs to file in JSON format
- ✅ File names include log level (
_response_error_...) - ✅ Static access with
Logger::recordStatic() - ✅ Automatically creates secure log directories
- ✅ Works with Slim or pure PHP
- ✅ GitHub Actions CI ready
composer require maatify/slim-logger- Logger:
Maatify\SlimLogger\Log\Logger - Enum:
Maatify\SlimLogger\Log\LogLevelEnum - Path Helper:
Maatify\SlimLogger\Store\File\Path
maatify-slim-logger/
├── src/
│ └── Log/
│ ├── Logger.php
│ └── LogLevelEnum.php
│ └── Store/
│ └── File/
│ └── Path.php
use Maatify\SlimLogger\Log\Logger;
use Maatify\SlimLogger\Log\LogLevelEnum;
use Maatify\SlimLogger\Store\File\Path;
$logger = new Logger(new Path(__DIR__));
$logger->record('User login', null, 'user/actions', LogLevelEnum::Info);$app->post('/action', function ($request, $response) use ($logger) {
$logger->record('User posted action.', $request, 'user/submit', LogLevelEnum::Debug);
return $response;
});try {
throw new \Exception('Oops');
} catch (\Throwable $e) {
$logger->record($e, null, 'errors/runtime', LogLevelEnum::Error);
}Log from anywhere — no need to instantiate:
use Maatify\SlimLogger\Log\Logger;
use Maatify\SlimLogger\Log\LogLevelEnum;
Logger::recordStatic('Static log entry.', null, 'system/status', LogLevelEnum::Info);try {
throw new \Exception("Static exception!");
} catch (\Throwable $e) {
Logger::recordStatic($e, null, 'errors/fatal', LogLevelEnum::Error);
}In PHPUnit or setup environments, use:
$testLogger = new Logger(new Path(__DIR__ . '/logs'));
Logger::setInstance($testLogger);Then recordStatic() will use that injected instance and path.
/logs/24/04/18/user/actions_response_info_20250418AM.log
| Option | Default | Description |
|---|---|---|
Path |
project root | Base path for log files |
Extension |
.log |
File extension for log files |
composer testTests run automatically on push via:
.github/workflows/run-tests.yml
MIT License © 2025 Maatify.dev
- GitHub: github.com/maatify/slim-logger