pbweb / audit-bundle
PB Web Media Audit Bundle for Symfony
Installs: 6 631
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 4
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=8.1
- ext-json: *
- psr/log: ^1.0|^2.0|^3.0
- symfony/config: ^5.4|^6.0
- symfony/dependency-injection: ^5.4|^6.0
- symfony/event-dispatcher: ^5.4|^6.0
- symfony/http-kernel: ^5.4|^6.0
- symfony/yaml: ^5.4|^6.0
Requires (Dev)
- doctrine/orm: ^2.9|^3.0
- mockery/mockery: ^1.6
- phpunit/phpunit: ^9.5
- symfony/framework-bundle: ^5.4|^6.0
- symfony/monolog-bundle: ^3.8
- symfony/security-bundle: ^5.4|^6.0
Suggests
- doctrine/orm: For writing the audit log to the database
- symfony/security: For if you use the default event appenders
README
Provides an easily extendible Symfony Bundle to create an audit log.
Installation
Install the audit-bundle using composer:
composer require pbweb/audit-bundle
Usage
To insert an entry in the audit logger, create an AuditEvent
and give it to the AuditLog
$event = new \Pbweb\AuditBundle\Event\AuditEvent('test'); $log = $container->get('pbweb_audit.audit_log'); $log->log($event);
You can also create your own events (which we recommend), as long as they implement the AuditEventInterface
.
Flow
Events enter the audit logger which will then trigger the following events (in order) with the provided AuditEventInterface
event as an argument:
Pbweb\AuditBundle\Event\AppendAuditEvent
- The class name of
$event
Pbweb\AuditBundle\Event\LogAuditEvent
That way you can hook into generic flow moments or only respond to specific events.
The Audit Bundle uses the Symfony event system so all the normal shenanigans (like listener priorities, stopping propagation, etc) work when handling these events.
Event appenders
Events aren't usually complete by themselves, you probably want to append some data related to the event like the user that triggered it or the ip of the client.
To do this listen to the Pbweb\AuditBundle\Event\AppendAuditEvent
event (either through a listener
or subscriber).
It will receive all AuditEventInterface
events that go into the audit log.
Default event appenders
The Audit Bundle comes packaged with a few event appenders that will be loaded by default, see the configuration section below on how to disable that.
If you use these appenders, you need to add symfony/security
to your project.
Loggers
Eventually the audit log entries need to go somewhere, either the database, a PSR logger or whatever you can think of.
The Audit Bundle comes packaged with a PSR logger and Doctrine logger (see below).
You can also implement your own logger by listening to the Pbweb\AuditBundle\Event\LogAuditEvent
event.
It will receive all AuditEventInterface
events that go into the audit log.
PSR logger
By default the Audit Bundle loads the PsrLogger
, which will use the @logger
service to log events to your default log.
Look at the configuration section below on how to disable this behaviour.
Doctrine logger
For small(ish) audit logs you could use the database as a data store.
The Audit Bundle comes with an AbstractDoctrineLogger
.
The only thing you need to do is create a service that implements the convertToEntity
method and give it the tag kernel.event_subscriber
.
Configuration
You can optionally configure the audit bundle in your app/config.yml
file
pbweb_audit: load_default_event_loggers: true # loads the loggers defined in Pbweb/AuditBundle/Resources/config/default/loggers.yml load_default_event_appenders: true # loads the event appenders in Pbweb/AuditBundle/Resources/config/default/appenders.yml
Copyright
© PB Web Media