从聚合根发布事件

由 repositories 管理的实体是聚合根。在领域驱动设计(Domain-Driven Design)的应用中,这些聚合根通常会发布领域事件。Spring Data 提供了一个名为 @DomainEvents 的注解,你可以用在聚合根的方法上,以尽可能方便地进行事件发布,如下例所示。

从聚合根暴露领域事件
class AnAggregateRoot {

    @DomainEvents (1)
    Collection<Object> domainEvents() {
        // … return events you want to get published here
    }

    @AfterDomainEventPublication (2)
    void callbackMethod() {
       // … potentially clean up domain events list
    }
}
1 使用 @DomainEvents 的方法可以返回单个事件实例或事件集合。它不能接受任何参数。
2 所有事件发布后,我们有一个带有 @AfterDomainEventPublication 注解的方法。你可以用它来清除待发布的事件列表(以及其他用途)。

每次调用以下 Spring Data repository 方法时,都会调用这些方法:

  • save(…), saveAll(…)

  • delete(…), deleteAll(…), deleteAllInBatch(…), deleteInBatch(…)

请注意,这些方法接受聚合根实例作为参数。这就是为什么 deleteById(…) 方法明显缺失的原因,因为实现可能会选择发出一个查询来删除实例,这样我们就无法首先访问聚合实例。