From 84112d96103073578820e045bb0017a25488ab93 Mon Sep 17 00:00:00 2001 From: Fabio Alessandrelli Date: Wed, 15 Dec 2021 10:58:48 +0100 Subject: [PATCH] [Net] Fix WebRTC returning packets from peers too early. Due to the async nature of WebRTC implementations, the multiplayer peer could end up having queued packets from a given connection before it is able to emit the "peer_added" signal. This commit ensures that packets from peers which are not notified yet are skipped by `get_packet` and `get_available_packet_count`. --- modules/webrtc/webrtc_multiplayer_peer.cpp | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/modules/webrtc/webrtc_multiplayer_peer.cpp b/modules/webrtc/webrtc_multiplayer_peer.cpp index 133bd71ddb6..20fe63bf7d7 100644 --- a/modules/webrtc/webrtc_multiplayer_peer.cpp +++ b/modules/webrtc/webrtc_multiplayer_peer.cpp @@ -146,6 +146,10 @@ void WebRTCMultiplayerPeer::_find_next_peer() { } // After last. while (E) { + if (!E->get()->connected) { + E = E->next(); + continue; + } for (const Ref &F : E->get()->channels) { if (F->get_available_packet_count()) { next_packet_peer = E->key(); @@ -157,6 +161,10 @@ void WebRTCMultiplayerPeer::_find_next_peer() { E = peer_map.front(); // Before last while (E) { + if (!E->get()->connected) { + E = E->next(); + continue; + } for (const Ref &F : E->get()->channels) { if (F->get_available_packet_count()) { next_packet_peer = E->key(); @@ -378,6 +386,9 @@ int WebRTCMultiplayerPeer::get_available_packet_count() const { } int size = 0; for (const KeyValue> &E : peer_map) { + if (!E.value->connected) { + continue; + } for (const Ref &F : E.value->channels) { size += F->get_available_packet_count(); }