You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The following issue occurs when a session is closed after 3 hours of inactivity. We are subscribing with the last replay id but the app receives older (already received) events.
code in main()
bayeuxClient.AddExtension(new ReplayExtension());
ClientSessionChannelListener clientSessionChannel = new ClientSessionChannelListener();
bayeuxClient.GetChannel(ChannelFields.META_HANDSHAKE).AddListener(clientSessionChannel);
code in ClientSessionChannelListener
public class ClientSessionChannelListener : IMessageListener
{
public void OnMessage(IClientSessionChannel channel, IMessage message)
{
long lastProcessedReplayId = GetLastProcessedReplayId();
_bayeuxClient.GetChannel('/topic', lastProcessedReplayId).Subscribe(new Listener(_platformEventsMessage, channelInfo));
}
}
If we do not pass the last id, the app does not receive the already processed events (the issue does not occur).
IServiceCollection.AddResilientStreamingClient() registers ResilientStreamingClient as a singleton. Something's not being reset that's causing older events to be received. As a workaround, I'm removing the singleton and adding again as scoped.
The following issue occurs when a session is closed after 3 hours of inactivity. We are subscribing with the last replay id but the app receives older (already received) events.
code in main()
code in ClientSessionChannelListener
If we do not pass the last id, the app does not receive the already processed events (the issue does not occur).
_bayeuxClient.GetChannel('/topic').Subscribe(new Listener(_platformEventsMessage, channelInfo));
The text was updated successfully, but these errors were encountered: