Skip to content

Use domain events with doctrine, compatible with Symfony & Api Platform ☀️

License

Notifications You must be signed in to change notification settings

swagindustries/doctrine-domain-events

Repository files navigation

Domain component

Build Status Latest Stable Version License

This library is design to help you to build your application with a Domain Design Development approach.

It is well integrated with:

  • Symfony >= 5.5 (for >=4.4 compatibility, install the version 2.2 of Doctrine domain events)
  • ApiPlatform >= 2.1
  • Doctrine >= 2.5
  • PHP >= 7.4

But you can use it with any PHP project.

Here are some slides that explain how we get there.

Features

Domain Events:

Drawbacks

This library is build to allow you to use Doctrine models as Domain model. This has some cost: you can't instantiate domain model by hand anymore. This means that you need a factory for any of the usage of your domain model.

This component provides the implementation for Symfony serializer and Doctrine. For your own needs you should use the class (service if you use the bundle) Biig\Component\Domain\Model\Instantiator\Instantiator.

Installation

composer require swag-industries/doctrine-domain-events

Basic usage

class YourModel extends DomainModel
{
    public const CREATION = 'creation';
    public function __construct()
    {
        $this->dispatch(new DomainEvent($this), self::CREATION);
    }
}
class DomainRule implements DomainRuleInterface
{
    public function on()
    {
        return YourModel::CREATION;
    }
    
    public function execute(DomainEvent $event)
    {
        // Do Something on your model creation
    }
}

As your model needs a dispatcher you need to call the setDispatcher() method any time you create a new instance of your model. To avoid doing this manually you can use the Instantiator that the library provides.

It doesn't use the constructor to add the dispatcher because in PHP you can create objects without the constructor. For instance, that's what Doctrine does.

use Biig\Component\Domain\Model\Instantiator\Instantiator;
use Doctrine\ORM\EntityManager;

class SomeController
{
    public function index(Instantiator $instantiator, EntityManager $entityManager)
    {
        $model = $instantiator->instantiate(YourModel::class);
        $entityManager->persist($model);
        $entityManager->flush();
    }
}

Integration to Symfony

Use the bundle :

<?php
// config/bundles.php

return [
    // ...
    Biig\Component\Domain\Integration\Symfony\DomainBundle::class => ['all' => true],
];

Learn more about Symfony Integration

Versions

Version Status Documentation Symfony Version PHP Version Misc
1.x Unmaintained v1 >= 3.3 && <5 >= 7.1
2.x Maintained v2 >= 4.3 >= 7.4
3.x Latest [v3][v3-doc] >= 6.4 >= 8.1 See UPGRADE guide