feat: enforce jetstream ack and redelivery semantics
This commit is contained in:
24
src/NATS.Server/JetStream/Consumers/AckProcessor.cs
Normal file
24
src/NATS.Server/JetStream/Consumers/AckProcessor.cs
Normal file
@@ -0,0 +1,24 @@
|
||||
namespace NATS.Server.JetStream.Consumers;
|
||||
|
||||
public sealed class AckProcessor
|
||||
{
|
||||
private readonly Dictionary<ulong, DateTime> _pending = new();
|
||||
|
||||
public void Register(ulong sequence, int ackWaitMs)
|
||||
{
|
||||
_pending[sequence] = DateTime.UtcNow.AddMilliseconds(Math.Max(ackWaitMs, 1));
|
||||
}
|
||||
|
||||
public ulong? NextExpired()
|
||||
{
|
||||
foreach (var (seq, deadline) in _pending)
|
||||
{
|
||||
if (DateTime.UtcNow >= deadline)
|
||||
return seq;
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public bool HasPending => _pending.Count > 0;
|
||||
}
|
||||
Reference in New Issue
Block a user