From cd660f2638532a0f5248123cf2edf001cbd52114 Mon Sep 17 00:00:00 2001 From: yngrtc Date: Sun, 24 Mar 2024 09:58:19 -0700 Subject: [PATCH] impl RTCHandler for demuxer --- rtc/src/handlers/demuxer.rs | 72 +++++++++++++------------------------ rtc/src/handlers/mod.rs | 2 +- 2 files changed, 26 insertions(+), 48 deletions(-) diff --git a/rtc/src/handlers/demuxer.rs b/rtc/src/handlers/demuxer.rs index 71fc392..4283a89 100644 --- a/rtc/src/handlers/demuxer.rs +++ b/rtc/src/handlers/demuxer.rs @@ -1,5 +1,5 @@ use crate::handlers::RTCHandler; -use crate::messages::{DTLSMessageEvent, RTCMessageEvent, RTPMessageEvent, STUNMessageEvent}; +use crate::messages::{DTLSMessage, RTCMessage, RTPMessage, STUNMessage}; use log::{debug, error}; use shared::Transmit; @@ -39,76 +39,54 @@ fn match_srtp(b: &[u8]) -> bool { /// DemuxerHandler implements demuxing of STUN/DTLS/RTP/RTCP Protocol packets #[derive(Default)] -pub struct DemuxerHandler { - next: Option>, -} +pub struct Demuxer; -impl DemuxerHandler { +impl Demuxer { pub fn new() -> Self { - DemuxerHandler::default() + Demuxer } } -impl RTCHandler for DemuxerHandler { - fn chain(mut self: Box, next: Box) -> Box { - self.next = Some(next); - self - } - - fn next(&mut self) -> Option<&mut Box> { - self.next.as_mut() - } - - fn handle_transmit(&mut self, msg: Transmit) { - if let RTCMessageEvent::Raw(message) = msg.message { +impl RTCHandler for Demuxer { + fn handle_transmit(&mut self, msg: Transmit) -> Vec> { + if let RTCMessage::Raw(message) = msg.message { if message.is_empty() { error!("drop invalid packet due to zero length"); - return; - } - - let next_msg = if match_dtls(&message) { - Transmit { + vec![] + } else if match_dtls(&message) { + vec![Transmit { now: msg.now, transport: msg.transport, - message: RTCMessageEvent::Dtls(DTLSMessageEvent::Raw(message)), - } + message: RTCMessage::Dtls(DTLSMessage::Raw(message)), + }] } else if match_srtp(&message) { - Transmit { + vec![Transmit { now: msg.now, transport: msg.transport, - message: RTCMessageEvent::Rtp(RTPMessageEvent::Raw(message)), - } + message: RTCMessage::Rtp(RTPMessage::Raw(message)), + }] } else { - Transmit { + vec![Transmit { now: msg.now, transport: msg.transport, - message: RTCMessageEvent::Stun(STUNMessageEvent::Raw(message)), - } - }; - - if let Some(next) = self.next() { - next.handle_transmit(next_msg); + message: RTCMessage::Stun(STUNMessage::Raw(message)), + }] } } else { debug!("drop non-RAW packet {:?}", msg.message); + vec![] } } - fn poll_transmit(&mut self) -> Option> { - let transmit = if let Some(next) = self.next() { - next.poll_transmit() - } else { - None - }; - - if let Some(msg) = transmit { + fn poll_transmit(&mut self, msg: Option>) -> Option> { + if let Some(msg) = msg { match msg.message { - RTCMessageEvent::Stun(STUNMessageEvent::Raw(message)) - | RTCMessageEvent::Dtls(DTLSMessageEvent::Raw(message)) - | RTCMessageEvent::Rtp(RTPMessageEvent::Raw(message)) => Some(Transmit { + RTCMessage::Stun(STUNMessage::Raw(message)) + | RTCMessage::Dtls(DTLSMessage::Raw(message)) + | RTCMessage::Rtp(RTPMessage::Raw(message)) => Some(Transmit { now: msg.now, transport: msg.transport, - message: RTCMessageEvent::Raw(message), + message: RTCMessage::Raw(message), }), _ => { debug!("drop non-RAW packet {:?}", msg.message); diff --git a/rtc/src/handlers/mod.rs b/rtc/src/handlers/mod.rs index c930bdb..3f78e9a 100644 --- a/rtc/src/handlers/mod.rs +++ b/rtc/src/handlers/mod.rs @@ -3,7 +3,7 @@ use shared::error::Error; use shared::Transmit; use std::time::Instant; -//pub mod demuxer; +pub mod demuxer; pub mod dtls; //pub mod stun;