webrtc: janus: handle 'hangup' messages from Janus

Fix error about this message not being handled:

{
   "janus": "hangup",
   "session_id": 4758817463851315,
   "sender": 4126342934227009,
   "reason": "Close PC"
}

Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/1508>
This commit is contained in:
Guillaume Desmottes 2024-03-08 15:54:29 +01:00 committed by Sebastian Dröge
parent be055f6dfa
commit a502dba6d5

View file

@ -161,6 +161,13 @@ struct InnerError {
reason: String, reason: String,
} }
#[derive(Serialize, Deserialize, Debug)]
struct InnerHangup {
session_id: JanusId,
sender: JanusId,
reason: String,
}
#[derive(Serialize, Deserialize, Debug)] #[derive(Serialize, Deserialize, Debug)]
struct RoomJoined { struct RoomJoined {
room: JanusId, room: JanusId,
@ -218,20 +225,15 @@ struct EventMsg {
// IncomingMessage // IncomingMessage
#[derive(Serialize, Deserialize, Debug)] #[derive(Serialize, Deserialize, Debug)]
#[serde(tag = "janus")] #[serde(tag = "janus", rename_all = "lowercase")]
enum JsonReply { enum JsonReply {
#[serde(rename = "ack")]
Ack, Ack,
#[serde(rename = "success")]
Success(SuccessMsg), Success(SuccessMsg),
#[serde(rename = "event")]
Event(EventMsg), Event(EventMsg),
#[serde(rename = "webrtcup")]
WebRTCUp, WebRTCUp,
#[serde(rename = "media")]
Media, Media,
#[serde(rename = "error")]
Error(InnerError), Error(InnerError),
HangUp(InnerHangup),
} }
#[derive(Default)] #[derive(Default)]
@ -477,6 +479,7 @@ impl Signaller {
JsonReply::Error(error) => { JsonReply::Error(error) => {
self.raise_error(format!("code: {}, reason: {}", error.code, error.reason)) self.raise_error(format!("code: {}, reason: {}", error.code, error.reason))
} }
JsonReply::HangUp(hangup) => self.raise_error(format!("hangup: {}", hangup.reason)),
// ignore for now // ignore for now
JsonReply::Ack | JsonReply::Media => {} JsonReply::Ack | JsonReply::Media => {}
} }