itmedia/domain-events

Domain events implementation

v1.0.1 2021-09-10 15:52 UTC

This package is auto-updated.

Last update: 2025-01-10 23:20:09 UTC


README

Domain Events Implementation

Install

composer require itmedia/domain-events

How to use

DomainEvent:

<?php

use Itmedia\DomainEvents\Event\DomainEvent;

class AccountRegistrationEvent implements DomainEvent
{
    /**
     * @var Account
     */
    private $account;


    public function __construct(Account $account)
    {
        $this->account = $account;
    }


    public function getName():string
    {
        return 'account_register';
    }

    // ...

}

Entity implement interface DomainEventPublisher :

<?php

use Itmedia\DomainEvents\Publisher\DomainEventPublisher;
use Itmedia\DomainEvents\Publisher\DomainEventPublisherTrait;

class Account implements DomainEventPublisher
{
    use DomainEventPublisherTrait; // Helper trait

    public static function register($email)
    {
        $account = new self();

        //...

        $account->pushEvent(new AccountRegistrationEvent($account));
        
        // Checked single event
        $account->pushSingleEvent(new MyEvent($account));
        $account->pushSingleEvent(new MyEvent($account));

        return $account;
    }


}

Use Doctrine ORM and Symfony events

Translation domain-event to symfony events on Doctrine postFlush() action:

# services.yml

services:

    # Translate domain event to symfony events
    Itmedia\DomainEvents\Bridge\SymfonyDomainEventTranslatorDispatcher:
        arguments: ['@event_dispatcher', '@logger', '%kernel.debug%']


    # Handle domain-events
    Itmedia\DomainEvents\Bridge\DoctrineDomainEventsHandler:
        arguments: ['@Itmedia\DomainEvents\Bridge\SymfonyDomainEventTranslatorDispatcher']
        tags:
            - { name: doctrine.event_listener, event: postFlush }
            - { name: doctrine.event_listener, event: preFlush }