Fix: Prevent message duplication
This commit is contained in:
@ -39,25 +39,19 @@ final class NsqSender implements SenderInterface
|
|||||||
$delayStamp = $envelope->last(DelayStamp::class);
|
$delayStamp = $envelope->last(DelayStamp::class);
|
||||||
$delay = null !== $delayStamp ? $delayStamp->getDelay() : 0;
|
$delay = null !== $delayStamp ? $delayStamp->getDelay() : 0;
|
||||||
|
|
||||||
$promise = null;
|
if (null === $envelope->last(NsqReceivedStamp::class)) {
|
||||||
|
$encodedMessage = $this->serializer->encode($envelope);
|
||||||
|
$encodedMessage = json_encode($encodedMessage, JSON_THROW_ON_ERROR | JSON_UNESCAPED_UNICODE);
|
||||||
|
|
||||||
if (null !== $envelope->last(NsqReceivedStamp::class)) {
|
wait($producer->publish($this->topic, $encodedMessage, $delay));
|
||||||
|
} else {
|
||||||
$message = NsqReceivedStamp::getMessageFromEnvelope($envelope);
|
$message = NsqReceivedStamp::getMessageFromEnvelope($envelope);
|
||||||
|
|
||||||
if (!$message->isProcessed()) {
|
if (!$message->isProcessed()) {
|
||||||
$promise = $message->requeue($delay);
|
wait($message->requeue($delay));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (null === $promise) {
|
|
||||||
$encodedMessage = $this->serializer->encode($envelope->withoutAll(NsqReceivedStamp::class));
|
|
||||||
$encodedMessage = json_encode($encodedMessage, JSON_THROW_ON_ERROR | JSON_UNESCAPED_UNICODE);
|
|
||||||
|
|
||||||
$promise = $producer->publish($this->topic, $encodedMessage, $delay);
|
|
||||||
}
|
|
||||||
|
|
||||||
wait($promise);
|
|
||||||
|
|
||||||
return $envelope;
|
return $envelope;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user