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

Payload for should-refresh-conversations event from signaling server #12623

Open
Antreesy opened this issue Jul 1, 2024 · 1 comment
Open
Labels
1. to develop feature: signaling 📶 Internal and external signaling backends technical debt

Comments

@Antreesy
Copy link
Contributor

Antreesy commented Jul 1, 2024

A room signaling message with roomid: "" is sent by the signaling server when the current participant leaves a room (as a response to the message sent by the client, note that should-refresh-conversations is not directly triggered by _doLeaveRoom as seems to be implied from the second commit message, it is indirectly triggered). However, that message can be sent by the signaling server too to the active participants of a room if that room is deleted.

If the participant is a registered user the client will also receive a roomlist signaling message with type: "disinvite", which will cause a redirection to spreed/not-found. However, if the particiant is a guest no other signaling message will be received to notify the client about the current room being deleted.

Due to that, if should-refresh-conversations is not emitted when a room signaling message with roomid: "" is sent by the signaling server the UI is not immediately updated for guests when public conversations are deleted (although it will be updated at most after 30 seconds, but that smells like legacy code that might be cleaned at some point).

Similarly, if a video verification conversation is deleted by the moderator without even joining the conversation the UI for the guest will never reflect that the conversation is deleted. If the moderator joins the conversation and then leaves (which automatically deletes the conversation) it will, but only because when the moderator leaves a roomlist message with type: "update" will be sent, which will also cause the conversation to be fetched again (and as the conversation is automatically deleted it will no longer exist once the request reaches the server, so the UI will be properly updated on the response).

Would it be possible to emit should-refresh-conversations even when roomid: "" but ignore the event in those places in which an update is not needed in that case? Or maybe emit a different event when roomid: "" that could be explicitly listened to if needed?

Originally posted by @danxuliu in #12557 (review)

@Antreesy Antreesy added 1. to develop feature: signaling 📶 Internal and external signaling backends technical debt labels Jul 1, 2024
@Antreesy Antreesy added this to the 💙 Next Major (30) milestone Jul 1, 2024
@Antreesy
Copy link
Contributor Author

Antreesy commented Jul 1, 2024

Re-posting here:

We have 4 emiiters of emit('should-refresh-conversations' event in total (all in signaling.js), so I assume we can provide each emit with a meaningful payload to distinct it on frontend.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
1. to develop feature: signaling 📶 Internal and external signaling backends technical debt
Projects
None yet
Development

No branches or pull requests

3 participants