54 lines
1.4 KiB
PHP
54 lines
1.4 KiB
PHP
<?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\Handler\HandlerDescriptor;
|
|
|
|
/**
|
|
* Stamp identifying a message handled by the `HandleMessageMiddleware` middleware
|
|
* and storing the handler returned value.
|
|
*
|
|
* This is used by synchronous command buses expecting a return value and the retry logic
|
|
* to only execute handlers that didn't succeed.
|
|
*
|
|
* @see \Symfony\Component\Messenger\Middleware\HandleMessageMiddleware
|
|
* @see \Symfony\Component\Messenger\HandleTrait
|
|
*
|
|
* @author Maxime Steinhausser <maxime.steinhausser@gmail.com>
|
|
*/
|
|
final class HandledStamp implements StampInterface
|
|
{
|
|
private mixed $result;
|
|
private string $handlerName;
|
|
|
|
public function __construct(mixed $result, string $handlerName)
|
|
{
|
|
$this->result = $result;
|
|
$this->handlerName = $handlerName;
|
|
}
|
|
|
|
public static function fromDescriptor(HandlerDescriptor $handler, mixed $result): self
|
|
{
|
|
return new self($result, $handler->getName());
|
|
}
|
|
|
|
public function getResult(): mixed
|
|
{
|
|
return $this->result;
|
|
}
|
|
|
|
public function getHandlerName(): string
|
|
{
|
|
return $this->handlerName;
|
|
}
|
|
}
|