mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-02-02 22:22:24 +00:00
webrtc/signalling: fix race condition in message ordering
Spawning one task per message to send out instead of sending them out sequentially from the one task used to poll the handler sometimes resulted in peers receiving ICE candidates before SDP offers, triggering hard to understand errors in the browser. Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/1254>
This commit is contained in:
parent
dfe2442c92
commit
0954af10c7
1 changed files with 14 additions and 7 deletions
|
@ -38,7 +38,7 @@ impl Server {
|
||||||
#[instrument(level = "debug", skip(factory))]
|
#[instrument(level = "debug", skip(factory))]
|
||||||
pub fn spawn<
|
pub fn spawn<
|
||||||
I: for<'a> Deserialize<'a>,
|
I: for<'a> Deserialize<'a>,
|
||||||
O: Serialize + std::fmt::Debug,
|
O: Serialize + std::fmt::Debug + Send + Sync,
|
||||||
Factory: FnOnce(Pin<Box<dyn Stream<Item = (String, Option<I>)> + Send>>) -> St,
|
Factory: FnOnce(Pin<Box<dyn Stream<Item = (String, Option<I>)> + Send>>) -> St,
|
||||||
St: Stream<Item = (String, O)>,
|
St: Stream<Item = (String, O)>,
|
||||||
>(
|
>(
|
||||||
|
@ -72,12 +72,19 @@ impl Server {
|
||||||
let _ = task::spawn(async move {
|
let _ = task::spawn(async move {
|
||||||
while let Some((peer_id, msg)) = handler.next().await {
|
while let Some((peer_id, msg)) = handler.next().await {
|
||||||
match serde_json::to_string(&msg) {
|
match serde_json::to_string(&msg) {
|
||||||
Ok(msg) => {
|
Ok(msg_str) => {
|
||||||
if let Some(peer) = state_clone.lock().unwrap().peers.get_mut(&peer_id) {
|
let sender = {
|
||||||
let mut sender = peer.sender.clone();
|
let mut state = state_clone.lock().unwrap();
|
||||||
task::spawn(async move {
|
if let Some(peer) = state.peers.get_mut(&peer_id) {
|
||||||
let _ = sender.send(msg).await;
|
Some(peer.sender.clone())
|
||||||
});
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if let Some(mut sender) = sender {
|
||||||
|
trace!("Sending {}", msg_str);
|
||||||
|
let _ = sender.send(msg_str).await;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
|
|
Loading…
Reference in a new issue