-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathEnqueueMessageProcessor.php
91 lines (76 loc) · 2.49 KB
/
EnqueueMessageProcessor.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
<?php
/**
* This file is part of the prooph/psb-enqueue-producer.
* (c) 2017-2017 prooph software GmbH <[email protected]>
* (c) 2017-2017 Sascha-Oliver Prolic <[email protected]>
* (c) 2017-2017 Formapro <[email protected]>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Prooph\ServiceBus\Message\Enqueue;
use Enqueue\Consumption\Result;
use Enqueue\Util\JSON;
use Interop\Queue\PsrContext;
use Interop\Queue\PsrMessage;
use Interop\Queue\PsrProcessor;
use Prooph\Common\Messaging\Message;
use Prooph\ServiceBus\CommandBus;
use Prooph\ServiceBus\EventBus;
use Prooph\ServiceBus\QueryBus;
final class EnqueueMessageProcessor implements PsrProcessor
{
/**
* @var CommandBus
*/
private $commandBus;
/**
* @var EventBus
*/
private $eventBus;
/**
* @var QueryBus
*/
private $queryBus;
/**
* @var EnqueueSerializer
*/
private $serializer;
public function __construct(CommandBus $commandBus, EventBus $eventBus, QueryBus $queryBus, EnqueueSerializer $serializer)
{
$this->commandBus = $commandBus;
$this->eventBus = $eventBus;
$this->queryBus = $queryBus;
$this->serializer = $serializer;
}
/**
* {@inheritdoc}
*/
public function process(PsrMessage $psrMessage, PsrContext $psrContext): Result
{
$message = $this->serializer->unserialize($psrMessage->getBody());
switch ($message->messageType()) {
case Message::TYPE_COMMAND:
$this->commandBus->dispatch($message);
break;
case Message::TYPE_EVENT:
$this->eventBus->dispatch($message);
break;
case Message::TYPE_QUERY:
$promise = $this->queryBus->dispatch($message);
$body = null;
$promise->then(function ($value) use (&$body) {
$body = JSON::encode($value);
});
return Result::reply($psrContext->createMessage($body));
default:
return Result::reject(sprintf(
'The message type "%s" is invalid. The supported types are "%s"',
$message->messageType(),
implode('", "', [Message::TYPE_COMMAND, Message::TYPE_EVENT, Message::TYPE_QUERY])
));
}
return Result::ack();
}
}