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",
loop.close()
def on_offer_created(self, promise, _, __):
+ log.info('on_offer_created')
promise.wait()
reply = promise.get_reply()
offer = reply['offer']
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)
"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
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')
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)
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)