ayaou / command-logger-bundle
This bundle logs all commands executed with console, along with their execution time and errors if applied.
Installs: 88
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 0
Open Issues: 4
Type:symfony-bundle
pkg:composer/ayaou/command-logger-bundle
Requires
- php: >=8.1
- doctrine/doctrine-bundle: ^2.7
- doctrine/orm: ^2|^3
- symfony/console: ^6.4|^7.0
- symfony/dependency-injection: ^6.4|^7.0
- symfony/event-dispatcher: ^6.4|^7.0
- symfony/uid: ^6.4|^7.0
- symfony/yaml: ^6.4|^7.0
Requires (Dev)
- friendsofphp/php-cs-fixer: *
- phpstan/phpstan-symfony: *
- phpunit/phpunit: ^10
- rector/rector: *
- roave/security-advisories: dev-latest
- symfony/framework-bundle: ^6.4|^7.0
- symfony/phpunit-bridge: ^6.4|^7.0
This package is auto-updated.
Last update: 2025-11-06 13:14:34 UTC
README
Overview
The Command Logger Bundle is a Symfony bundle that logs executed console commands. It provides insights into command execution, including arguments, execution time, exit codes, and errors.
Installation
Install the bundle via Composer:
composer require ayaou/command-logger-bundle
Register the bundle in config/bundles.php if not automatically added:
Ayaou\CommandLoggerBundle\AyaouCommandLoggerBundle::class => ['all' => true],
Configuration
Add the following configuration in config/packages/command_logger.yaml:
command_logger: enabled: true # Enable or disable logging (default: true) purge_threshold: 100 # Days after which old logs are deleted (e.g., 100 means logs older than 100 days are removed) commands: # List of commands to log if they are not annotated, we can also use wildcards (This can be useful for commands located in third-party bundles) - app:example-command - app:another-command - make:*
Usage
Enabling Logging on a Command
Use configuration commands array (if not using attributes) Or:
Use the CommandLogger attribute on any Symfony command to enable logging:
use Ayaou\CommandLoggerBundle\Attribute\CommandLogger; use Symfony\Component\Console\Attribute\AsCommand; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; #[AsCommand(name: 'app:example-command')] #[CommandLogger] class ExampleCommand extends Command { protected function execute(InputInterface $input, OutputInterface $output): int { $output->writeln('Executing example command...'); return Command::SUCCESS; } }
Entity Structure
The logs are stored in the command_log table with the following fields:
commandName– Name of the executed commandarguments– Command arguments in JSON formatstartTime– Execution start timeendTime– Execution end timeexitCode– Command exit codeerrorMessage– Error message if applicableexecutionToken– Unique identifier for execution tracking
Show Command Logs
The command-logger:show command displays logged command executions from the command_log table. It supports filtering, pagination, and viewing specific entries by ID.
bin/console command-logger:show [name] [--limit=LIMIT] [--code=CODE] [--id=ID] [--error] [--success]
Description
This command retrieves and displays command execution logs. By default, it shows the latest 10 entries, ordered by startTime in descending order, in a tabular format. You can filter by command name, exit code, or success/error status, and view a single entry by ID.
The command supports pagination, allowing you to press Enter to view more entries interactively.
Arguments
- name (optional): Filters logs by the command name (e.g., app:example-command).
Options
- --limit|-l (optional): Specifies the number of entries to show per page (default: 10).
- --code|-c (optional): Filters logs by a specific exit code (e.g., --code=0 for successful commands).
- --id (optional): Displays a single log entry by its ID (e.g., --id=123). When used, no other arguments or options are allowed.
- --error (optional): Filters logs to show only entries with non-zero exit codes (indicating errors). Cannot be used with --success or --code.
- --success (optional): Filters logs to show only entries with an exit code of 0 (indicating success). Cannot be used with --error or --code.
Purging Old Logs
The bundle includes an automatic mechanism to purge logs older than the configured purge_threshold. You can also manually trigger log cleanup using the following command:
bin/console command-logger:purge
By default, this uses the purge_threshold value from the configuration. To override it, specify a custom threshold (in days) with the --threshold or -t option:
bin/console command-logger:purge --threshold=30
For example, --threshold=30 removes logs older than 30 days
License
MIT License