Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vasekpurchart/console-errors-bundle
Logging of exceptions and error codes for Symfony Console.
https://github.com/vasekpurchart/console-errors-bundle
Last synced: 3 months ago
JSON representation
Logging of exceptions and error codes for Symfony Console.
- Host: GitHub
- URL: https://github.com/vasekpurchart/console-errors-bundle
- Owner: VasekPurchart
- License: other
- Created: 2015-05-19T10:06:23.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-06-12T05:00:25.000Z (over 1 year ago)
- Last Synced: 2024-09-20T11:17:38.769Z (4 months ago)
- Language: PHP
- Size: 137 KB
- Stars: 4
- Watchers: 2
- Forks: 2
- Open Issues: 5
-
Metadata Files:
- Readme: readme.md
- License: license.md
Awesome Lists containing this project
README
Console Errors Bundle
=====================**Logging of exceptions and error codes for [Symfony Console](http://symfony.com/doc/current/components/console/introduction.html).**
This bundle ensures all uncaught exceptions and errors are logged in the same way as exceptions from controllers.
It also logs all command executions which ended with non-zero exit code.
Here is an example showing an exception, error and non-zero exit code:
![Error reports from Console](docs/console-errors.png)And these are corresponding log entries:
```
[2015-05-19 12:41:19] app.ERROR: Exception: Hello Exception! (uncaught exception) at /home/vasek/dev/projects/console-errors-bundle/framework-standard-edition/src/AppBundle/Console/HelloCommand.php line 23 while running console command `hello:world` {"exception":"[object] (Exception(code: 0): Hello Exception! at /home/vasek/dev/projects/console-errors-bundle/framework-standard-edition/src/AppBundle/Console/HelloCommand.php:23)"} []
[2015-05-19 12:41:58] app.ERROR: Symfony\Component\Debug\Exception\ContextErrorException: Notice: Undefined variable: foo (uncaught exception) at /home/vasek/dev/projects/console-errors-bundle/framework-standard-edition/src/AppBundle/Console/HelloCommand.php line 23 while running console command `hello:world` {"exception":"[object] (Symfony\\Component\\Debug\\Exception\\ContextErrorException(code: 0): Notice: Undefined variable: foo at /home/vasek/dev/projects/console-errors-bundle/framework-standard-edition/src/AppBundle/Console/HelloCommand.php:23)"} []
[2015-05-19 12:42:13] app.ERROR: Command `hello:world` exited with status code 123 [] []
```Configuration
-------------Configuration structure with listed default values:
```yaml
# config/packages/console_errors.yml
console_errors:
exceptions:
# Enable logging for exceptions.
enabled: true
# Log level with which exceptions should be logged (accepts string or integer values).
log_level: error
# Priority with which the listener will be registered.
listener_priority: 0exit_code:
# Enable logging for non-zero exit codes.
enabled: true
# Log level with which exit codes should be logged (accepts string or integer values).
log_level: error
# Priority with which the listener will be registered.
listener_priority: 0
```Symfony by default always converts errors to PHP exceptions. Warnings and notices are converted by default only in development environment. If you want to configure your application to always convert warnings and notices to exceptions use the `debug.error_handler.throw_at` parameter (see [PHP manual](http://php.net/manual/en/errorfunc.constants.php) for other available values):
```yaml
# config/packages/framework.yml
parameters:
debug.error_handler.throw_at: -1
```You can also override services used internally, for example if you use a non standard logger, you can provide custom instance with an [alias](http://symfony.com/doc/current/components/dependency_injection/advanced.html#aliasing):
```yaml
services:
my_logger:
class: 'Monolog\Logger'
arguments:
- 'my_channel'vasek_purchart.console_errors.console.logger: '@my_logger'
```Installation
------------Install package [`vasek-purchart/console-errors-bundle`](https://packagist.org/packages/vasek-purchart/console-errors-bundle) with [Composer](https://getcomposer.org/):
```bash
composer require vasek-purchart/console-errors-bundle
```Register the bundle in your application:
```php
// config/bundles.php
return [
// ...
VasekPurchart\ConsoleErrorsBundle\ConsoleErrorsBundle::class => ['all' => true],
];
```