Align default port number with Laplace.
[toast/stream2beamer.git] / laplace_client.py
index 1b88b7dec01e4965f7e1dc3ab3185b9d510d865c..6ec2bb83862d92316459f285144701abe7cd0ff7 100755 (executable)
@@ -34,7 +34,7 @@ class WebRTCClient:
 
     def send_sdp_offer(self, offer):
         text = offer.sdp.as_text()
-        log.info('Sending offer:\n%s' % text)
+        log.info(f'send_sdp_offer with {text}')
         msg = json.dumps({
             'SessionID': self.session_id,
             'Type': "gotAnswer",
@@ -48,15 +48,17 @@ class WebRTCClient:
         loop.close()
 
     def on_offer_created(self, promise, _, __):
+        log.info('on_offer_created')
         promise.wait()
         reply = promise.get_reply()
-        offer = reply['offer']
+        offer = reply.get_value('offer')
         promise = Gst.Promise.new()
         self.webrtc.emit('set-local-description', offer, promise)
         promise.interrupt()
         self.send_sdp_offer(offer)
 
     def on_negotiation_needed(self, element):
+        log.info('on_negotiation_needed')
         promise = Gst.Promise.new_with_change_func(self.on_offer_created, element, None)
         element.emit('create-offer', None, promise)
 
@@ -70,11 +72,13 @@ class WebRTCClient:
                 "sdpMLineIndex": mlineindex,
                 })
             })
+        log.info(f'send_ice_candidate_message with {icemsg}')
         loop = asyncio.new_event_loop()
         loop.run_until_complete(self.websocket.send(icemsg))
         loop.close()
 
     def on_incoming_decodebin_stream(self, _, pad):
+        log.info('on_incoming_decodebin_stream')
         if not pad.has_current_caps():
             log.info(pad, 'has no caps, ignoring')
             return
@@ -105,6 +109,7 @@ class WebRTCClient:
             resample.link(sink)
 
     def on_incoming_stream(self, _, pad):
+        log.info('on_incoming_stream')
         if pad.direction != Gst.PadDirection.SRC:
             return
         decodebin = Gst.ElementFactory.make('decodebin')
@@ -115,16 +120,19 @@ class WebRTCClient:
 
     def start_pipeline(self):
         self.webrtc = Gst.ElementFactory.make('webrtcbin', 'laplace')
-        self.webrtc.set_property("bundle-policy", 3)
+        self.webrtc.set_property("bundle-policy", 3)
         direction = GstWebRTC.WebRTCRTPTransceiverDirection.RECVONLY
-        caps = Gst.caps_from_string("application/x-rtp,media=video,encoding-name=VP8/9000,payload=96")
-        self.webrtc.emit('add-transceiver', direction, caps)
+        video_caps = Gst.caps_from_string("application/x-rtp,media=video,encoding-name=VP8/9000,payload=96")
+        audio_caps = Gst.caps_from_string("application/x-rtp,media=audio,encoding-name=OPUS,clock-rate=48000,payload=111")
+        self.webrtc.emit('add-transceiver', direction, video_caps)
+        self.webrtc.emit('add-transceiver', direction, audio_caps)
         self.pipe = Gst.Pipeline.new("pipeline")
         Gst.Bin.do_add_element(self.pipe, self.webrtc)
         self.webrtc.connect('on-negotiation-needed', self.on_negotiation_needed)
         self.webrtc.connect('on-ice-candidate', self.send_ice_candidate_message)
         self.webrtc.connect('pad-added', self.on_incoming_stream)
         self.pipe.set_state(Gst.State.PLAYING)
+        self.webrtc.emit('create-data-channel', 'laplace', None)
     
     def close_pipeline(self):
         self.pipe.set_state(Gst.State.NULL)
@@ -132,6 +140,7 @@ class WebRTCClient:
         self.webrtc = None
     
     def handle_sdp(self, sdp):
+        log.info(f'handle_sdp: {sdp}')
         res, sdpmsg = GstSdp.SDPMessage.new()
         GstSdp.sdp_message_parse_buffer(bytes(sdp.encode()), sdpmsg)
         answer = GstWebRTC.WebRTCSessionDescription.new(GstWebRTC.WebRTCSDPType.ANSWER, sdpmsg)
@@ -140,6 +149,7 @@ class WebRTCClient:
         promise.interrupt()
 
     def handle_ice(self, ice):
+        log.info(f'handle_ice: {ice}')
         candidate = ice['candidate']
         sdpmlineindex = ice['sdpMLineIndex']
         self.webrtc.emit('add-ice-candidate', sdpmlineindex, candidate)
@@ -183,7 +193,7 @@ def main():
     if not check_plugins():
         sys.exit(1)
     parser = argparse.ArgumentParser()
-    parser.add_argument('--uri', default='wss://localhost:2222/ws_connect?id=cug',
+    parser.add_argument('--uri', default='wss://localhost:1234/ws_connect?id=cug',
         help='Signalling server URI')
     args = parser.parse_args()
     c = WebRTCClient(args.uri)