| 1 | <?php |
||
| 12 | class DelayService |
||
| 13 | { |
||
| 14 | /** |
||
| 15 | * @var DelayStrategyResolver |
||
| 16 | */ |
||
| 17 | protected $strategyService; |
||
| 18 | |||
| 19 | /** |
||
| 20 | * @var LoggerInterface |
||
| 21 | */ |
||
| 22 | private $logger; |
||
| 23 | |||
| 24 | 2 | public function __construct(DelayStrategyResolver $strategyService, LoggerInterface $logger) |
|
| 29 | |||
| 30 | 2 | public function delayQueue(QueueEntityInterface $queue): QueueEntityInterface |
|
| 31 | { |
||
| 32 | try { |
||
| 33 | 2 | $strategy = $this->strategyService->getStrategy($queue->getName()); |
|
| 34 | 1 | } catch (UnknownStrategyKeyException $exception) { |
|
| 35 | 1 | $this->logger->warning( |
|
| 36 | 1 | $exception->getMessage(), [ |
|
| 37 | 1 | 'queue_name' => $queue->getName(), |
|
| 38 | ] |
||
| 39 | ); |
||
| 40 | 1 | $strategy = $this->strategyService->getDefaultStrategy(); |
|
| 41 | } |
||
| 42 | |||
| 43 | 2 | $iteration = $queue->getAttempts() ?? 1; |
|
| 44 | 2 | $newDelayInterval = $strategy->generateInterval($iteration); |
|
| 45 | 2 | $delayUntil = $this->getStartDateTime()->add($newDelayInterval); |
|
| 46 | |||
| 47 | 2 | $queue->setWaiting($delayUntil); |
|
| 48 | |||
| 49 | 2 | return $queue; |
|
| 50 | } |
||
| 51 | |||
| 52 | protected function getStartDateTime(): DateTime |
||
| 56 | } |
||
| 57 |