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\Stamp;
|
|
|
|
|
|
|
|
use Symfony\Component\Messenger\Envelope;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Marker stamp for messages that can be ack/nack'ed.
|
|
|
|
*/
|
|
|
|
final class AckStamp implements NonSendableStampInterface
|
|
|
|
{
|
|
|
|
private $ack;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param \Closure(Envelope, \Throwable|null) $ack
|
|
|
|
*/
|
|
|
|
public function __construct(\Closure $ack)
|
|
|
|
{
|
|
|
|
$this->ack = $ack;
|
|
|
|
}
|
|
|
|
|
2024-05-17 20:26:01 +02:00
|
|
|
public function ack(Envelope $envelope, ?\Throwable $e = null): void
|
2023-05-12 15:06:01 +02:00
|
|
|
{
|
|
|
|
($this->ack)($envelope, $e);
|
|
|
|
}
|
|
|
|
}
|