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
{
    /**
     * @var LoggerInterface
     */
    private $logger;

    /**
     * @var bool
     */
    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;
    }
}