2023-05-12 15:06:01 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of the Symfony package.
|
|
|
|
*
|
|
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Symfony\Component\Messenger\Handler;
|
|
|
|
|
|
|
|
use Symfony\Component\Messenger\Exception\LogicException;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @author Nicolas Grekas <p@tchwork.com>
|
|
|
|
*/
|
|
|
|
class Acknowledger
|
|
|
|
{
|
|
|
|
private $handlerClass;
|
|
|
|
private $ack;
|
|
|
|
private $error = null;
|
|
|
|
private $result = null;
|
|
|
|
|
|
|
|
/**
|
2024-05-17 20:26:01 +02:00
|
|
|
* @param \Closure(\Throwable|null, mixed):void|null $ack
|
2023-05-12 15:06:01 +02:00
|
|
|
*/
|
2024-05-17 20:26:01 +02:00
|
|
|
public function __construct(string $handlerClass, ?\Closure $ack = null)
|
2023-05-12 15:06:01 +02:00
|
|
|
{
|
|
|
|
$this->handlerClass = $handlerClass;
|
|
|
|
$this->ack = $ack ?? static function () {};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param mixed $result
|
|
|
|
*/
|
|
|
|
public function ack($result = null): void
|
|
|
|
{
|
|
|
|
$this->doAck(null, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function nack(\Throwable $error): void
|
|
|
|
{
|
|
|
|
$this->doAck($error);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getError(): ?\Throwable
|
|
|
|
{
|
|
|
|
return $this->error;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function getResult()
|
|
|
|
{
|
|
|
|
return $this->result;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function isAcknowledged(): bool
|
|
|
|
{
|
|
|
|
return null === $this->ack;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function __destruct()
|
|
|
|
{
|
|
|
|
if ($this->ack instanceof \Closure) {
|
|
|
|
throw new LogicException(sprintf('The acknowledger was not called by the "%s" batch handler.', $this->handlerClass));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-05-17 20:26:01 +02:00
|
|
|
private function doAck(?\Throwable $e = null, $result = null): void
|
2023-05-12 15:06:01 +02:00
|
|
|
{
|
|
|
|
if (!$ack = $this->ack) {
|
|
|
|
throw new LogicException(sprintf('The acknowledger cannot be called twice by the "%s" batch handler.', $this->handlerClass));
|
|
|
|
}
|
|
|
|
$this->ack = null;
|
|
|
|
$this->error = $e;
|
|
|
|
$this->result = $result;
|
|
|
|
$ack($e, $result);
|
|
|
|
}
|
|
|
|
}
|