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:
<?php
namespace SAREhub\Client\Amqp;
use Psr\Log\LoggerAwareInterface;
use Psr\Log\LoggerInterface;
use Psr\Log\NullLogger;
use SAREhub\Client\Amqp\AmqpMessageHeaders as AMH;
use SAREhub\Client\Message\Exchange;
use SAREhub\Client\Message\Message;
class BasicAmqpProcessConfirmStrategy implements AmqpProcessConfirmStrategy, LoggerAwareInterface
{
private $logger;
private $requeueOnReject = true;
public function __construct()
{
$this->logger = new NullLogger();
}
public function confirm(AmqpChannelWrapper $channel, Message $originalIn, Exchange $exchange)
{
$consumer = $channel->getConsumer($originalIn->getHeader(AMH::CONSUMER_TAG));
if ($consumer->getOptions()->isAutoAckMode()) {
return;
}
$context = ["orginalIn" => $originalIn, "exchange" => $exchange];
if ($exchange->isFailed()) {
$this->logger->debug('processed message failed', $context);
$channel->reject($originalIn, $this->isRequeueOnReject());
} else {
$this->logger->debug('processed message success', $context);
$channel->ack($originalIn);
}
}
public function isRequeueOnReject(): bool
{
return $this->requeueOnReject;
}
public function setRejectRequeue(bool $requeue): BasicAmqpProcessConfirmStrategy
{
$this->requeueOnReject = $requeue;
return $this;
}
public function setLogger(LoggerInterface $logger)
{
$this->logger = $logger;
}
}