use crate::webrtcsink::{Signallable, WebRTCSink}; use gst::glib; use gst::subclass::prelude::ObjectSubclassExt; mod imp; glib::wrapper! { pub struct Signaller(ObjectSubclass); } unsafe impl Send for Signaller {} unsafe impl Sync for Signaller {} impl Signallable for Signaller { fn start(&mut self, element: &WebRTCSink) -> Result<(), anyhow::Error> { let signaller = imp::Signaller::from_instance(self); signaller.start(element); Ok(()) } fn handle_sdp( &mut self, element: &WebRTCSink, peer_id: &str, sdp: &gst_webrtc::WebRTCSessionDescription, ) -> Result<(), anyhow::Error> { let signaller = imp::Signaller::from_instance(self); signaller.handle_sdp(element, peer_id, sdp); Ok(()) } fn handle_ice( &mut self, element: &WebRTCSink, peer_id: &str, candidate: &str, sdp_mline_index: Option, sdp_mid: Option, ) -> Result<(), anyhow::Error> { let signaller = imp::Signaller::from_instance(self); signaller.handle_ice(element, peer_id, candidate, sdp_mline_index, sdp_mid); Ok(()) } fn stop(&mut self, element: &WebRTCSink) { let signaller = imp::Signaller::from_instance(self); signaller.stop(element); } fn consumer_removed(&mut self, element: &WebRTCSink, peer_id: &str) { let signaller = imp::Signaller::from_instance(self); signaller.consumer_removed(element, peer_id); } } impl Signaller { pub fn new() -> Self { glib::Object::new(&[]).unwrap() } }