react-command-bus/examples/local.php

50 lines
1.6 KiB
PHP

<?php
require_once __DIR__."/../vendor/autoload.php";
use NoccyLabs\React\CommandBus\CommandBus;
use NoccyLabs\React\CommandBus\CommandRegistry;
use NoccyLabs\React\CommandBus\Context;
use React\EventLoop\Loop;
use React\Promise\Promise;
$commands = new CommandRegistry();
// Register some function to call. The name here is "hello", and it will
// receive a Context holding the call context. Any passed data will be
// available as properties on the Context object.
$commands->register("hello", function (Context $context) {
// You don't have to, but you should return a promise from your
// commands.
return new Promise(function (callable $resolve) use ($context) {
Loop::addTimer(1, function () use ($context, $resolve) {
$resolve("Hello, {$context->name}");
});
});
});
// Note how the arguments can be unwrapped. You can still add Context as
// an argument to get the full context. Values will be cast to match the
// type, so keep this in mind when feeding strings like 'false' into a
// boolean argument. It is also a good idea to make the arguments nullable.
$commands->register("hello2", function (?string $name, ?string $phrase, ?string $missing) {
// Just returning the value works just fine!
return "Greetings, {$name}. {$phrase} to you too!";
});
// Create the bus
$bus = new CommandBus($commands);
// And execute some commands!
$bus->execute('hello', ['name'=>'Bob'])
->then(function ($result) {
var_dump($result);
}
);
$bus->execute('hello2', ['name'=>'Bob','phrase'=>'Good day'])
->then(function ($result) {
var_dump($result);
}
);