Skip to content

Latest commit

 

History

History
107 lines (82 loc) · 2.82 KB

README.md

File metadata and controls

107 lines (82 loc) · 2.82 KB

envor/libstream

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

Installation

You can install the package via composer:

composer require envor/libstream

You can publish and run the migrations with:

php artisan vendor:publish --tag="libstream-migrations"
php artisan migrate

Usage

use Envor\Libstream\Command as LibCommand;
use App\Aggregates\Main;

#[HandledBy(Main::class)]
class Command extends LibCommand
{
    public static function createBusiness(
        string $uuid, 
        array $businessAttributes, 
        array $metaData = []
        ): self
    {
        return new self(new BusinessCreated(
            aggregateUuid: $uuid,
            businessAttributes: $businessAttributes,
            metaData: $metaData
        ));
    }
}
use Envor\Libstream\Dispatcher as LibDispatcher

class Dispatcher extends LibDispatcher
{
    public function createBusiness(
        string $uuid, 
        array $businessAttributes, 
        array $metaData = []
        ): self
    {
        $this->add(new Command(new BusinessCreated(
            aggregateUuid: $uuid,
            businessAttributes: $businessAttributes,
            metaData: $metaData
        )));

        return $this;
    }
}
    $uuid = (string) str()->ulid();
    $dispatcher = Dispatcher::new()->createBusiness(
      uuid: $uuid,
      businessAttributes: $validatedData,
      metaData: [
        'auth' => [
          'email' => Auth::user()->email,
        ],
      ]
    )->dispatch();

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.