-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathMessageHandler.php
More file actions
60 lines (51 loc) · 1.65 KB
/
MessageHandler.php
File metadata and controls
60 lines (51 loc) · 1.65 KB
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
<?php
declare(strict_types=1);
namespace Queue\App\Message;
use Dot\DependencyInjection\Attribute\Inject;
use Dot\Log\Logger;
use Symfony\Component\Messenger\MessageBusInterface;
use Throwable;
class MessageHandler
{
#[Inject(
MessageBusInterface::class,
'dot-log.queue-log',
'config',
)]
public function __construct(
protected MessageBusInterface $bus,
protected Logger $logger,
protected array $config,
) {
}
/**
* @throws Throwable
*/
public function __invoke(Message $message): void
{
$payload = $message->getPayload();
try {
if ($payload['foo'] === 'control') {
//user control message to log successfully processed message
$this->logger->info($payload['foo'] . ' processed successfully');
} elseif ($payload['foo'] === 'retry') {
//user retry message to test retry functionality
throw new \RuntimeException("Intentional failure for testing retries");
}
} catch (\Throwable $e) {
$retryCount = $payload['retry_count'] ?? 0;
if ($retryCount === 0) {
$this->logger->error(
"Message '{$payload['foo']}' failed because: " . $e->getMessage()
);
} else {
$this->logger->error(
"Message '{$payload['foo']}' failed because: " . $e->getMessage() . " Retry {$retryCount}"
);
}
$payload['retry_count'] = $retryCount + 1;
$message->setPayload($payload);
throw $e;
}
}
}