Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Subscribing with the last replay id makes the app receive the older events #36

Open
mahesh2080 opened this issue Nov 23, 2021 · 2 comments
Labels
help wanted Extra attention is needed

Comments

@mahesh2080
Copy link

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).

_bayeuxClient.GetChannel('/topic').Subscribe(new Listener(_platformEventsMessage, channelInfo));

@kdcllc kdcllc added the help wanted Extra attention is needed label Nov 30, 2021
@alexjoedt
Copy link

alexjoedt commented Jul 27, 2023

Any updates here?
I have the same behavior.

EDIT:

This helped: #22 (comment)

@CNBoland
Copy link

CNBoland commented Feb 1, 2024

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.

services.AddResilientStreamingClient();
services.Remove(new ServiceDescriptor(typeof(IStreamingClient), typeof(ResilientStreamingClient), ServiceLifetime.Singleton));
services.AddScoped<IStreamingClient, ResilientStreamingClient>();

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

4 participants