Beispiel #1
0
    def start(self):
        sem = threading.Event()

        self.streamingPlugin = StreamingPlugin()
        self.session = Session('ws://127.0.0.1:8188',
                               secret='d5faa25fe8e3438d826efb1cd3369a50')

        @self.session.on_plugin_attached.connect
        def receive_data(sender, **kw):
            #wait until Janus plugin is not attached
            sem.set()

        #CONNECTION
        #self.session.cxn_cls
        #
        #SIGNALS
        #
        # Signal fired when `Connection` has been established.
        #	on_opened = blinker.Signal()
        #self.session.cxn_cls.on_opened.connect(self.connection_on_opened)

        #
        # Signal fired when `Connection` has been closed.
        #	on_closed = blinker.Signal()
        #self.session.cxn_cls.on_closed.connect(self.connection_on_closed)

        #
        # Signal fired when `Connection` receives a message
        #	on_message = blinker.Signal()
        self.session.cxn_cls.on_message.connect(self.connection_on_message)

        ##

        #SESSION
        #self.session
        #
        #SIGNALS
        #
        # Signal fired when `Session` has been connected.
        #	on_connected = blinker.Signal()
        #self.session.on_connected.connect(self.session_on_connected)

        #
        # Signal fired when `Session` has been disconnected.
        #	on_disconnected = blinker.Signal()
        #self.session.on_disconnected.connect(self.session_on_disconnected)

        #
        # Signal fired when a `Session` level message is received.
        #	on_message = blinker.Signal()
        #self.session.on_message.connect(self.session_on_message)

        #
        # Signal fired when a `Session` `Plugin` been attached.
        #	on_plugin_attached = blinker.Signal()
        #self.session.on_plugin_attached.connect(self.session_on_plugin_attached)

        #
        # Signal fired when a `Session` `Plugin` been detached.
        #	on_plugin_detached = blinker.Signal()
        #self.session.on_plugin_detached.connect(self.session_on_plugin_detached)

        ##

        #PLUGIN
        #self.streamingPlugin
        #
        #SIGNALS
        #
        # Signal fired when a `Plugin` is attached to a `Session`.
        #	on_attached = blinker.Signal()
        #self.streamingPlugin.on_attached.connect(self.streamingPlugin_on_attached)

        #
        # Signal fired when a `Plugin` is attached to a `Session`.
        #	on_detached = blinker.Signal()
        #self.streamingPlugin.on_detached.connect(self.streamingPlugin_on_detached)

        #
        # Signal fired when a `Plugin` receives a message.
        #	on_message = blinker.Signal()
        #self.streamingPlugin.on_message.connect(self.streamingPlugin_on_message)
        #

        # Signal fired when webrtc for a `Plugin` has been setup.
        #	on_webrtcup = blinker.Signal()
        #self.streamingPlugin.on_webrtcup.connect(self.streamingPlugin_on_webrtcup)

        #
        # Signal fired when webrtc session for a `Plugin` has been torn down.
        #	on_hangup = blinker.Signal()
        #self.streamingPlugin.on_hangup.connect(self.streamingPlugin_on_hangup)

        ##

        self.session.register_plugin(self.streamingPlugin)
        try:
            self.session.connect()
        except Exception as e:
            if e.errno == 111:
                #Connection refused
                self._logger.warn('Janus was unavailable. Restarting...')
                if self._parent.restartJanus():
                    self._logger.info('Janus succesfully restarted')
                    self.session.connect()
                else:
                    self._logger.error('Janus could not be restarted')
                    return None

        self.sessionKa = KeepAlive(self.session)
        self.sessionKa.daemon = True
        self.sessionKa.start()

        waitingState = sem.wait(5)
        sem.clear()

        if waitingState:
            return self.session.id

        else:
            self._logger.error(
                "Error initializing Janus: session can not be started")
            return None
Beispiel #2
0
class ConnectionPeer(object):
    def __init__(self, clientId, parent):
        self._logger = logging.getLogger(__name__ + ':ConnectionPeer')
        self.session = None
        self.clientId = clientId
        self.sessionKa = None
        self.id = None
        self.streamingPlugin = None
        self._parent = parent

    #CONNECTION
    #def connection_on_opened(self,connection):
    #	logging.info('CONNECTION ON OPENED')

    #def connection_on_closed(self, connection, **kw):
    #	self._logger.warn('Lost connection with Janus')

    def connection_on_message(self, connection, message):
        messageToSend = json.loads(str(message))

        if self.session is not None and 'session_id' in messageToSend and messageToSend[
                'session_id'] != self.session.id:
            return

        if 'janus' in messageToSend and messageToSend['janus'] == 'hangup':
            #Finish camera session caused by user or exception
            self._parent.closePeerSession(messageToSend['session_id'])

        elif 'jsep' in messageToSend:
            self.sendEventToPeer('getSdp', messageToSend)

    #SESSION
    #def session_on_connected(self,session,**kw):
    #	logging.info('SESSION ON OPENED')

    #def session_on_disconnected(self,session,**kw):
    #	logging.info('SESSION ON CLOSED')

    #def session_on_message(self,session,**kw):
    #	logging.info('SESSION ON MESSAGE')

    #def session_on_plugin_attached(self,session,**kw):
    #	logging.info('SESSION ON PLUGIN ATTACHED')

    #def session_on_plugin_detached(self,session,**kw):
    #	logging.info('SESSION ON PLUGIN DETACHED')

    #PLUGIN
    #def streamingPlugin_on_message(self,plugin,**kw):
    #	logging.info('STREAMINGPLUGIN ON MESSAGE')

    #def streamingPlugin_on_attached(self,plugin,**kw):
    #	logging.info('STREAMINGPLUGIN ON ATTACHED')

    #def streamingPlugin_on_detached(self,plugin,**kw):
    #	logging.info('STREAMINGPLUGIN ON DETACHED')

    #def streamingPlugin_on_webrtcup(self,plugin,**kw):
    #	logging.info('STREAMINGPLUGIN ON WEBRTCUP')

    #def streamingPlugin_on_hangup(self,plugin,**kw):
    #	logging.info('STREAMINGPLUGIN ON HANGUP')

    def start(self):
        sem = threading.Event()

        self.streamingPlugin = StreamingPlugin()
        self.session = Session('ws://127.0.0.1:8188',
                               secret='d5faa25fe8e3438d826efb1cd3369a50')

        @self.session.on_plugin_attached.connect
        def receive_data(sender, **kw):
            #wait until Janus plugin is not attached
            sem.set()

        #CONNECTION
        #self.session.cxn_cls
        #
        #SIGNALS
        #
        # Signal fired when `Connection` has been established.
        #	on_opened = blinker.Signal()
        #self.session.cxn_cls.on_opened.connect(self.connection_on_opened)

        #
        # Signal fired when `Connection` has been closed.
        #	on_closed = blinker.Signal()
        #self.session.cxn_cls.on_closed.connect(self.connection_on_closed)

        #
        # Signal fired when `Connection` receives a message
        #	on_message = blinker.Signal()
        self.session.cxn_cls.on_message.connect(self.connection_on_message)

        ##

        #SESSION
        #self.session
        #
        #SIGNALS
        #
        # Signal fired when `Session` has been connected.
        #	on_connected = blinker.Signal()
        #self.session.on_connected.connect(self.session_on_connected)

        #
        # Signal fired when `Session` has been disconnected.
        #	on_disconnected = blinker.Signal()
        #self.session.on_disconnected.connect(self.session_on_disconnected)

        #
        # Signal fired when a `Session` level message is received.
        #	on_message = blinker.Signal()
        #self.session.on_message.connect(self.session_on_message)

        #
        # Signal fired when a `Session` `Plugin` been attached.
        #	on_plugin_attached = blinker.Signal()
        #self.session.on_plugin_attached.connect(self.session_on_plugin_attached)

        #
        # Signal fired when a `Session` `Plugin` been detached.
        #	on_plugin_detached = blinker.Signal()
        #self.session.on_plugin_detached.connect(self.session_on_plugin_detached)

        ##

        #PLUGIN
        #self.streamingPlugin
        #
        #SIGNALS
        #
        # Signal fired when a `Plugin` is attached to a `Session`.
        #	on_attached = blinker.Signal()
        #self.streamingPlugin.on_attached.connect(self.streamingPlugin_on_attached)

        #
        # Signal fired when a `Plugin` is attached to a `Session`.
        #	on_detached = blinker.Signal()
        #self.streamingPlugin.on_detached.connect(self.streamingPlugin_on_detached)

        #
        # Signal fired when a `Plugin` receives a message.
        #	on_message = blinker.Signal()
        #self.streamingPlugin.on_message.connect(self.streamingPlugin_on_message)
        #

        # Signal fired when webrtc for a `Plugin` has been setup.
        #	on_webrtcup = blinker.Signal()
        #self.streamingPlugin.on_webrtcup.connect(self.streamingPlugin_on_webrtcup)

        #
        # Signal fired when webrtc session for a `Plugin` has been torn down.
        #	on_hangup = blinker.Signal()
        #self.streamingPlugin.on_hangup.connect(self.streamingPlugin_on_hangup)

        ##

        self.session.register_plugin(self.streamingPlugin)
        try:
            self.session.connect()
        except Exception as e:
            if e.errno == 111:
                #Connection refused
                self._logger.warn('Janus was unavailable. Restarting...')
                if self._parent.restartJanus():
                    self._logger.info('Janus succesfully restarted')
                    self.session.connect()
                else:
                    self._logger.error('Janus could not be restarted')
                    return None

        self.sessionKa = KeepAlive(self.session)
        self.sessionKa.daemon = True
        self.sessionKa.start()

        waitingState = sem.wait(5)
        sem.clear()

        if waitingState:
            return self.session.id

        else:
            self._logger.error(
                "Error initializing Janus: session can not be started")
            return None

    def close(self):
        #stop the keepalive worker
        self.sessionKa.stop()
        self.sessionKa.join()
        self.sessionKa = None

        #kill the current session
        self.session.unregister_plugin(self.streamingPlugin)
        self.session.disconnect()
        self.session = None
        self.streamingPlugin = None

    def sendEventToPeer(self, type, data=None):
        try:
            boxrouterManager().sendEventToClient(self.clientId, type, data)

        except:
            self._logger.error('Error sending event [%s] to peer %s' %
                               (type, self.clientId),
                               exc_info=True)
Beispiel #3
0
	def start(self):
		sem = threading.Event()

		self.streamingPlugin = StreamingPlugin()
		self.session = Session('ws://127.0.0.1:8188', secret='d5faa25fe8e3438d826efb1cd3369a50')

		@self.session.on_plugin_attached.connect
		def receive_data(sender, **kw):
			#wait until Janus plugin is not attached
			sem.set()


		#CONNECTION
		#self.session.cxn_cls
		#
		#SIGNALS
		#
		# Signal fired when `Connection` has been established.
			#	on_opened = blinker.Signal()
		#self.session.cxn_cls.on_opened.connect(self.connection_on_opened)

		#
		# Signal fired when `Connection` has been closed.
		#	on_closed = blinker.Signal()
		#self.session.cxn_cls.on_closed.connect(self.connection_on_closed)

		#
		# Signal fired when `Connection` receives a message
		#	on_message = blinker.Signal()
		self.session.cxn_cls.on_message.connect(self.connection_on_message)

		##


		#SESSION
		#self.session
		#
		#SIGNALS
		#
		# Signal fired when `Session` has been connected.
		#	on_connected = blinker.Signal()
		#self.session.on_connected.connect(self.session_on_connected)

		#
		# Signal fired when `Session` has been disconnected.
		#	on_disconnected = blinker.Signal()
		#self.session.on_disconnected.connect(self.session_on_disconnected)

		#
		# Signal fired when a `Session` level message is received.
		#	on_message = blinker.Signal()
		#self.session.on_message.connect(self.session_on_message)

		#
		# Signal fired when a `Session` `Plugin` been attached.
		#	on_plugin_attached = blinker.Signal()
		#self.session.on_plugin_attached.connect(self.session_on_plugin_attached)

		#
		# Signal fired when a `Session` `Plugin` been detached.
		#	on_plugin_detached = blinker.Signal()
		#self.session.on_plugin_detached.connect(self.session_on_plugin_detached)

		##


		#PLUGIN
		#self.streamingPlugin
		#
		#SIGNALS
		#
		# Signal fired when a `Plugin` is attached to a `Session`.
		#	on_attached = blinker.Signal()
		#self.streamingPlugin.on_attached.connect(self.streamingPlugin_on_attached)

		#
		# Signal fired when a `Plugin` is attached to a `Session`.
		#	on_detached = blinker.Signal()
		#self.streamingPlugin.on_detached.connect(self.streamingPlugin_on_detached)

		#
		# Signal fired when a `Plugin` receives a message.
		#	on_message = blinker.Signal()
		#self.streamingPlugin.on_message.connect(self.streamingPlugin_on_message)
		#

		# Signal fired when webrtc for a `Plugin` has been setup.
		#	on_webrtcup = blinker.Signal()
		#self.streamingPlugin.on_webrtcup.connect(self.streamingPlugin_on_webrtcup)


		#
		# Signal fired when webrtc session for a `Plugin` has been torn down.
		#	on_hangup = blinker.Signal()
		#self.streamingPlugin.on_hangup.connect(self.streamingPlugin_on_hangup)

		##

		self.session.register_plugin(self.streamingPlugin)
		try:
			self.session.connect()
		except Exception as e:
			if e.errno == 111:
				#Connection refused
				self._logger.warn('Janus was unavailable. Restarting...')
				if self._parent.restartJanus():
					self._logger.info('Janus succesfully restarted')
					self.session.connect()
				else:
					self._logger.error('Janus could not be restarted')
					return None

		self.sessionKa = KeepAlive(self.session)
		self.sessionKa.daemon = True
		self.sessionKa.start()

		waitingState = sem.wait(5)
		sem.clear()

		if waitingState:
			return self.session.id

		else:
			self._logger.error("Error initializing Janus: session can not be started")
			return None
Beispiel #4
0
class WebRtc(object):
    def __init__(self):
        self._connectedPeers = {}
        self._logger = logging.getLogger(__name__)
        self._peerCondition = threading.Condition()
        self._JanusProcess = None
        self.videoId = 1
        initialized = signal('initialized')
        self.peersDeadDetacher = None

    def ensureJanusRunning(self):
        if len(self._connectedPeers.keys()) <= 0:
            return self.startJanus()
        else:
            return True  #Janus was running before it

    def ensureGstreamerRunning(self):
        cam = cameraManager()
        if cam.open_camera():
            if not cam.start_video_stream():
                self._logger.error('Managing Gstreamer error in WebRTC object')
                #Janus is forced to be closed
                self.stopJanus()
                return False
            return False
        else:
            return True

    def shutdown(self):
        self._logger.info('Shutting Down WebRtcManager')
        self.stopJanus()

    def startLocalSession(self, sessionId):
        with self._peerCondition:
            self._connectedPeers[sessionId] = "local"
            return True

    def closeLocalSession(self, sessionId):
        with self._peerCondition:

            if len(self._connectedPeers.keys()) > 0:
                try:
                    peer = self._connectedPeers[sessionId]
                except KeyError:
                    self._logger.warning('Session [%s] for peer not found' %
                                         sessionId)
                    peer = None

                if peer:
                    del self._connectedPeers[sessionId]

                self._logger.info("There are %d peers left.",
                                  len(self._connectedPeers))

                if len(webRtcManager()._connectedPeers.keys()) == 0:
                    #last session
                    self.stopGStreamer()
                    self.stopJanus()

            return True

    def startPeerSession(self, clientId):
        with self._peerCondition:

            if len(self._connectedPeers.keys()) == 0:
                #first session
                self.startJanus()

            peer = ConnectionPeer(clientId, self)

            sessionId = peer.start()

            if sessionId:
                self._connectedPeers[sessionId] = peer
                return sessionId

            else:
                #something went wrong, no session started. Do we still need Janus up?
                if len(self._connectedPeers.keys()) == 0:
                    self.stopGStreamer()
                    self.stopJanus()

                return None

    def closePeerSession(self, sessionId):
        with self._peerCondition:
            if len(self._connectedPeers.keys()) > 0:

                try:
                    peer = self._connectedPeers[sessionId]
                except KeyError:
                    self._logger.warning('Session [%s] for peer not found' %
                                         sessionId)
                    peer = None

                if peer:
                    peer.streamingPlugin.send_message({'request': 'destroy'})
                    peer.close()
                    self.sendEventToPeer(self._connectedPeers[sessionId],
                                         'stopConnection')
                    del self._connectedPeers[sessionId]

                self._logger.info("There are %d peers left.",
                                  len(self._connectedPeers))

                if len(self._connectedPeers.keys()) == 0:
                    #last session
                    self.stopGStreamer()
                    self.stopJanus()
                    ready = signal('manage_fatal_error_webrtc')
                    ready.disconnect(self.closeAllSessions)

    def closeAllSessions(self, sender, message):

        self._logger.info("Closing all streaming sessions")

        for key in self._connectedPeers.keys():
            if self._connectedPeers[key] != 'local':
                if message:
                    self.sendEventToPeer(self._connectedPeers[key], sender,
                                         message)
                self.closePeerSession(key)
            else:
                self.closeLocalSession(key)

        self.stopJanus()

    def preparePlugin(self, sessionId):

        try:
            peer = self._connectedPeers[sessionId]

        except KeyError:
            self._logger.warning('Peer with session [%s] is not found' %
                                 sessionId)
            peer = None
            self.sendEventToPeers('stopConnection')

        if peer:
            peer.streamingPlugin.send_message({'request': 'list'})

            videoEncodingSelected = settings().get(["camera", "encoding"])

            if videoEncodingSelected == 'h264':

                self.videoId = 1

            else:  #VP8

                self.videoId = 2

            self._connectedPeers[sessionId].streamingPlugin.send_message({
                'request':
                'watch',
                'id':
                self.videoId
            })

    def setSessionDescriptionAndStart(self, sessionId, data):

        try:
            peer = self._connectedPeers[sessionId]

        except KeyError:
            self._logger.warning('Peer with session [%s] is not found' %
                                 sessionId)
            peer = None
            self.sendEventToPeers('stopConnection')

        if peer:
            #Janus starting state
            self._connectedPeers[
                sessionId].streamingPlugin.set_session_description(
                    data['type'], data['sdp'])
            self._connectedPeers[sessionId].streamingPlugin.send_message(
                {'request': 'start'})
            #able to serve video
            self.startGStreamer()

    def tickleIceCandidate(self, sessionId, candidate, sdp_mid,
                           sdp_mline_index):
        self._connectedPeers[sessionId].streamingPlugin.add_ice_candidate(
            candidate, sdp_mid, sdp_mline_index)

    def pongCallback(self, data, key):

        if 'pong' != data:
            if 'error' in data:
                self._logger.error(
                    'Webrtc client lost: %s. Automatic peer session closing...',
                    data['error'])
            self.closePeerSession(key)

    def pingPongRounder(self, params=None):

        for key in self._connectedPeers.keys():
            if self._connectedPeers[key] != 'local':
                #sendRequestToClient(self, clientId, type, data, timeout, respCallback)
                boxrouterManager().sendRequestToClient(
                    self._connectedPeers[key].clientId, 'ping', None, 10,
                    self.pongCallback, [key])

    def startGStreamer(self):
        #Start Gstreamer
        if not cameraManager().start_video_stream():
            self._logger.error('Managing Gstreamer error in WebRTC object')
            self.stopJanus()

    def startJanus(self):
        #Start janus command here
        args = ['/opt/janus/bin/./janus']

        try:
            self._JanusProcess = subprocess.Popen(args, stdout=subprocess.PIPE)

        except Exception, error:
            self._logger.error("Error initiating janus process: %s" %
                               str(error))
            self._JanusProcess = None
            self.sendEventToPeers('stopConnection')
            return False

        if self._JanusProcess:
            from requests import Session

            session = Session()
            response = None

            tryingCounter = 0
            while response is None:
                time.sleep(0.3)

                try:
                    response = session.post(url='http://127.0.0.1:8088',
                                            data={
                                                "message": {
                                                    "request": 'info',
                                                    "transaction": 'ready'
                                                }
                                            })

                except Exception, error:
                    #self._logger.warn('Waiting for Janus initialization')
                    tryingCounter += 1

                    if tryingCounter >= 100:
                        self._logger.error(error)
                        return False

            ready = signal('manage_fatal_error')
            ready.connect(self.closeAllSessions)

            #START TIMER FOR LOST PEERS
            self.peersDeadDetacher = interval(30.0, self.pingPongRounder, None)
            self.peersDeadDetacher.start()

            return True
Beispiel #5
0
class ConnectionPeer(object):
	def __init__(self, clientId, parent):
		self._logger = logging.getLogger(__name__ + ':ConnectionPeer')
		self.session = None
		self.clientId = clientId
		self.sessionKa = None
		self.id = None
		self.streamingPlugin = None
		self._parent = parent

	#CONNECTION
	#def connection_on_opened(self,connection):
	#	logging.info('CONNECTION ON OPENED')

	#def connection_on_closed(self, connection, **kw):
	#	self._logger.warn('Lost connection with Janus')

	def connection_on_message(self, connection, message):
		messageToSend = json.loads(str(message))

		if self.session is not None and 'session_id' in messageToSend and messageToSend['session_id'] != self.session.id:
			return

		if 'janus' in messageToSend and messageToSend['janus'] == 'hangup':
			#Finish camera session caused by user or exception
			self._parent.closePeerSession(messageToSend['session_id'])

		elif 'jsep' in messageToSend:
			self.sendEventToPeer('getSdp', messageToSend)

	#SESSION
	#def session_on_connected(self,session,**kw):
	#	logging.info('SESSION ON OPENED')

	#def session_on_disconnected(self,session,**kw):
	#	logging.info('SESSION ON CLOSED')

	#def session_on_message(self,session,**kw):
	#	logging.info('SESSION ON MESSAGE')

	#def session_on_plugin_attached(self,session,**kw):
	#	logging.info('SESSION ON PLUGIN ATTACHED')

	#def session_on_plugin_detached(self,session,**kw):
	#	logging.info('SESSION ON PLUGIN DETACHED')


	#PLUGIN
	#def streamingPlugin_on_message(self,plugin,**kw):
	#	logging.info('STREAMINGPLUGIN ON MESSAGE')

	#def streamingPlugin_on_attached(self,plugin,**kw):
	#	logging.info('STREAMINGPLUGIN ON ATTACHED')

	#def streamingPlugin_on_detached(self,plugin,**kw):
	#	logging.info('STREAMINGPLUGIN ON DETACHED')

	#def streamingPlugin_on_webrtcup(self,plugin,**kw):
	#	logging.info('STREAMINGPLUGIN ON WEBRTCUP')

	#def streamingPlugin_on_hangup(self,plugin,**kw):
	#	logging.info('STREAMINGPLUGIN ON HANGUP')

	def start(self):
		sem = threading.Event()

		self.streamingPlugin = StreamingPlugin()
		self.session = Session('ws://127.0.0.1:8188', secret='d5faa25fe8e3438d826efb1cd3369a50')

		@self.session.on_plugin_attached.connect
		def receive_data(sender, **kw):
			#wait until Janus plugin is not attached
			sem.set()


		#CONNECTION
		#self.session.cxn_cls
		#
		#SIGNALS
		#
		# Signal fired when `Connection` has been established.
			#	on_opened = blinker.Signal()
		#self.session.cxn_cls.on_opened.connect(self.connection_on_opened)

		#
		# Signal fired when `Connection` has been closed.
		#	on_closed = blinker.Signal()
		#self.session.cxn_cls.on_closed.connect(self.connection_on_closed)

		#
		# Signal fired when `Connection` receives a message
		#	on_message = blinker.Signal()
		self.session.cxn_cls.on_message.connect(self.connection_on_message)

		##


		#SESSION
		#self.session
		#
		#SIGNALS
		#
		# Signal fired when `Session` has been connected.
		#	on_connected = blinker.Signal()
		#self.session.on_connected.connect(self.session_on_connected)

		#
		# Signal fired when `Session` has been disconnected.
		#	on_disconnected = blinker.Signal()
		#self.session.on_disconnected.connect(self.session_on_disconnected)

		#
		# Signal fired when a `Session` level message is received.
		#	on_message = blinker.Signal()
		#self.session.on_message.connect(self.session_on_message)

		#
		# Signal fired when a `Session` `Plugin` been attached.
		#	on_plugin_attached = blinker.Signal()
		#self.session.on_plugin_attached.connect(self.session_on_plugin_attached)

		#
		# Signal fired when a `Session` `Plugin` been detached.
		#	on_plugin_detached = blinker.Signal()
		#self.session.on_plugin_detached.connect(self.session_on_plugin_detached)

		##


		#PLUGIN
		#self.streamingPlugin
		#
		#SIGNALS
		#
		# Signal fired when a `Plugin` is attached to a `Session`.
		#	on_attached = blinker.Signal()
		#self.streamingPlugin.on_attached.connect(self.streamingPlugin_on_attached)

		#
		# Signal fired when a `Plugin` is attached to a `Session`.
		#	on_detached = blinker.Signal()
		#self.streamingPlugin.on_detached.connect(self.streamingPlugin_on_detached)

		#
		# Signal fired when a `Plugin` receives a message.
		#	on_message = blinker.Signal()
		#self.streamingPlugin.on_message.connect(self.streamingPlugin_on_message)
		#

		# Signal fired when webrtc for a `Plugin` has been setup.
		#	on_webrtcup = blinker.Signal()
		#self.streamingPlugin.on_webrtcup.connect(self.streamingPlugin_on_webrtcup)


		#
		# Signal fired when webrtc session for a `Plugin` has been torn down.
		#	on_hangup = blinker.Signal()
		#self.streamingPlugin.on_hangup.connect(self.streamingPlugin_on_hangup)

		##

		self.session.register_plugin(self.streamingPlugin)
		try:
			self.session.connect()
		except Exception as e:
			if e.errno == 111:
				#Connection refused
				self._logger.warn('Janus was unavailable. Restarting...')
				if self._parent.restartJanus():
					self._logger.info('Janus succesfully restarted')
					self.session.connect()
				else:
					self._logger.error('Janus could not be restarted')
					return None

		self.sessionKa = KeepAlive(self.session)
		self.sessionKa.daemon = True
		self.sessionKa.start()

		waitingState = sem.wait(5)
		sem.clear()

		if waitingState:
			return self.session.id

		else:
			self._logger.error("Error initializing Janus: session can not be started")
			return None

	def close(self):
		#stop the keepalive worker
		self.sessionKa.stop()
		self.sessionKa.join()
		self.sessionKa = None

		#kill the current session
		self.session.unregister_plugin(self.streamingPlugin)
		self.session.disconnect()
		self.session = None
		self.streamingPlugin = None

	def sendEventToPeer(self, type, data= None):
		try:
			boxrouterManager().sendEventToClient(self.clientId, type, data)

		except:
			self._logger.error('Error sending event [%s] to peer %s' % (type, self.clientId), exc_info = True)