jidaikobo / log
A simple logging class with error and exception handling. adheres to PSR-1, PSR-12 and PSR-3.
Requires
- php: >=7.4
- psr/log: ^1.0 || ^2.0 || ^3.0 || ^4.0
Requires (Dev)
- phpcompatibility/php-compatibility: ^9.3
- phpstan/phpstan: ^2.0
- squizlabs/php_codesniffer: ^3.11
README
jidaikobo/log
jidaikobo/log
is a simple and flexible logging utility that adheres to the PSR-3 (Logger Interface) standard. It provides both instance-based and static methods for logging, making it easy to integrate into any PHP project.
This package was developed to simplify logging in small-scale projects, such as those using the Slim Framework. It also fulfills the need to log arrays efficiently, which can be crucial for debugging.
Features
- PSR-3 compliant: Supports all standard logging levels.
- Instance-based design: Fully compatible with dependency injection and modern PHP practices.
- Static wrapper: Offers convenient static methods for quick and simple logging.
- Log file rotation: Automatically rotates log files when they reach a specified size.
- Error and exception handling: Integrates with PHP error and exception handling mechanisms.
Installation
Install the package via Composer:
composer require jidaikobo/log
Usage
Basic Initialization
Initialize the logger with a custom log file path and maximum file size (optional):
use Jidaikobo\Log; Log::init('/path/to/log.log', 5 * 1024 * 1024); // 5MB max file size
If Log::init() is not explicitly called, the logger will use default settings.
Logging Messages
Log messages at various levels using static methods:
Log::info('This is an informational message.'); Log::warning('This is a warning message.'); Log::error('An error occurred.'); Log::debug('Debugging details.');
To output an array:
Log::write(['foo', 'bar', 'baz']);
Error and Exception Handling
Register the logger to handle PHP errors and uncaught exceptions:
Log::getInstance()->registerHandlers();
Requirements
- PHP >= 7.4
License
This project is licensed under the MIT License, see the LICENSE file for details