phauthentic / domain-events-symfony-bundle
Domain Events for Symfony
Installs: 25
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
pkg:composer/phauthentic/domain-events-symfony-bundle
Requires
- php: >=8.2
- doctrine/doctrine-bundle: ^2.0.0
- doctrine/orm: ^3.0
- ramsey/uuid-doctrine: ^1.5
- symfony/event-dispatcher: ^6.4 || ^7.0
- symfony/framework-bundle: ^6.4 || ^7.0
- symfony/messenger: ^6.4 || ^7.0
- symfony/property-access: ^6.4 || ^7.0
- symfony/serializer: ^6.4 || ^7.0
Requires (Dev)
- dg/bypass-finals: ^1.8
- phpmd/phpmd: ^2.15
- phpstan/phpstan: ^2.0
- phpunit/phpunit: ^11.5.0
- roave/security-advisories: dev-latest
- squizlabs/php_codesniffer: ^3.11
This package is auto-updated.
Last update: 2025-12-29 01:05:31 UTC
README
This bundle deals with the dispatching of domain events and the implementation of the outbox pattern, which is optional.
The outbox pattern is a way to ensure reliable message publishing with a dedicated “Outbox” table within your transactional boundary. It is suited to scenarios needing atomic writes to business data and events. It is simple to implement using existing relational databases.
This library follows the KISS principle and tries to keep things as simple and easy to understand as possible. Being framework agnostic was never a design goal, nor being super generic.
Features
- Domain events dispatching
- (Optional) Outbox pattern implementation
Installation
composer require phauthentic/domain-events-symfony-bundle
Wire the services in your config/services.yaml:
services: Phauthentic\Symfony\DomainEvents\Domain\ReflectionAggregateExtractor: Phauthentic\Symfony\DomainEvents\Domain\AggregateExtractorInterface: '@Phauthentic\Symfony\DomainEvents\Domain\ReflectionAggregateExtractor' Phauthentic\Symfony\DomainEvents\Doctrine\DomainEventEmitter: tags: - { name: 'doctrine.event_listener', event: 'postPersist', priority: 1 }
Usage
Add the #[AggregateRoot] attribute to your aggregate root classes that should emit domain events. By default the AggregateRoot attribute will look for an id and domainEvents property in your aggregate root classes. You can customize this by passing the property names as arguments to the attribute.
Optional: Use the EventRecorderTrait in your aggregate root classes to record domain events if you want to stick to the defaults. The trait implements the domainEvents property and adds a method recordThat(object $event).
Minimum default example
#[AggregateRoot] class Cart { use EventRecorderTrait; string $id; public function itemAdded(Item $item) { $this->items[] = $item; $this->recordThat(new ItemAdded($item)); } }
Domain Events, the Outbox Pattern and Event Sourcing
The bundle is intentionally not implementing event sourcing, because it adds another level of often not needed complexity. If you struggle to understand this design decision you are probably not a candidate for event sourcing in any case.
The Outbox Pattern
- Ensures reliable message publishing with a dedicated “Outbox” table within your transactional boundary.
- Suited to scenarios needing atomic writes to business data and events.
- Simple to implement using existing relational databases.
Event Store / Event Sourcing
- Stores every event as the system’s ultimate source of truth.
- Suited to event-sourced architectures, allowing system state to be rebuilt from event history.
- Provides full auditability and traceability but is more complex.
Event Sourcing Alternatives
License
This bundle is under the MIT license.
Copyright Florian Krämer