承接 phauthentic/domain-events-symfony-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

phauthentic/domain-events-symfony-bundle

Composer 安装命令:

composer require phauthentic/domain-events-symfony-bundle

包简介

Domain Events for Symfony

README 文档

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

统计信息

  • 总下载量: 34
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-29