Пример #1
0
    def __init__(self, device):
        self.device = device
        self.device_type = self.device.get_friendly_device_type()
        self.version = int(self.device.get_device_type_version())
        self.icons = device.icons

        self.wan_connection_device = None
        self.wan_common_interface_connection = None

        self.embedded_device_detection_completed = False
        self.service_detection_completed = False

        louie.connect(self.embedded_device_notified, signal='Coherence.UPnP.EmbeddedDeviceClient.detection_completed', sender=self.device)

        try:
            wan_connection_device = self.device.get_embedded_device_by_type('WANConnectionDevice')[0]
            self.wan_connection_device = WANConnectionDeviceClient(wan_connection_device)
        except:
            self.warning("Embedded WANConnectionDevice device not available, device not implemented properly according to the UPnP specification")
            raise

        louie.connect(self.service_notified, signal='Coherence.UPnP.DeviceClient.Service.notified', sender=self.device)
        for service in self.device.get_services():
            if service.get_type() in ["urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1"]:
                self.wan_common_interface_connection = WANCommonInterfaceConfigClient(service)

        self.info("WANDevice %s" % (self.device.get_friendly_name()))
Пример #2
0
    def __init__(self, device):
        log.LogAble.__init__(self)
        EventDispatcher.__init__(self)
        self.register_event(
            'embedded_device_client_detection_completed',
        )

        self.device = device
        self.device.bind(
            embedded_device_client_detection_completed=self.embedded_device_notified,  # noqa
            service_notified=self.service_notified
        )
        self.device_type = self.device.get_friendly_device_type()

        self.version = int(self.device.get_device_type_version())
        self.icons = device.icons

        self.wan_connection_device = None
        self.wan_common_interface_connection = None

        try:
            wan_connection_device = \
                self.device.get_embedded_device_by_type(
                    'WANConnectionDevice')[0]
            self.wan_connection_device = WANConnectionDeviceClient(
                wan_connection_device)
        except Exception as er:
            self.warning(
                f'Embedded WANConnectionDevice device not available, device '
                f'not implemented properly according to the UPnP '
                f'specification [ERROR: {er}]')
            raise

        for service in self.device.get_services():
            if service.get_type() in [
                    'urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1']:
                self.wan_common_interface_connection = \
                    WANCommonInterfaceConfigClient(service)

        self.info(f'WANDevice {device.get_friendly_name()}')
Пример #3
0
    def __init__(self, device):
        log.Loggable.__init__(self)
        self.device = device
        self.device_type = self.device.get_friendly_device_type()
        self.version = int(self.device.get_device_type_version())
        self.icons = device.icons

        self.wan_connection_device = None
        self.wan_common_interface_connection = None

        self.embedded_device_detection_completed = False
        self.service_detection_completed = False

        louie.connect(
            self.embedded_device_notified,
            signal='Coherence.UPnP.EmbeddedDeviceClient.detection_completed',
            sender=self.device)

        try:
            wan_connection_device = self.device.get_embedded_device_by_type(
                'WANConnectionDevice')[0]
            self.wan_connection_device = WANConnectionDeviceClient(
                wan_connection_device)
        except:
            self.warning(
                "Embedded WANConnectionDevice device not available, device not implemented properly according to the UPnP specification"
            )
            raise

        louie.connect(self.service_notified,
                      signal='Coherence.UPnP.DeviceClient.Service.notified',
                      sender=self.device)
        for service in self.device.get_services():
            if service.get_type() in [
                    "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1"
            ]:
                self.wan_common_interface_connection = WANCommonInterfaceConfigClient(
                    service)

        self.info("WANDevice %s", self.device.get_friendly_name())
Пример #4
0
class WANDeviceClient(EventDispatcher, log.LogAble):
    '''
    .. versionchanged:: 0.9.0

        * Introduced inheritance from EventDispatcher
        * The emitted events changed:

            - Coherence.UPnP.EmbeddedDeviceClient.detection_completed =>
              embedded_device_client_detection_completed

        * Changed some class variable to benefit from the EventDispatcher's
          properties:

            - :attr:`embedded_device_detection_completed`
            - :attr:`service_detection_completed`

    '''

    logCategory = 'wan_device_client'

    embedded_device_detection_completed = Property(False)
    '''
    To know whenever the embedded device detection has completed. Defaults to
    `False` and it will be set automatically to `True` by the class method
    :meth:`embedded_device_notified`.
    '''

    service_detection_completed = Property(False)
    '''
    To know whenever the service detection has completed. Defaults to `False`
    and it will be set automatically to `True` by the class method
    :meth:`service_notified`.
    '''
    def __init__(self, device):
        log.LogAble.__init__(self)
        EventDispatcher.__init__(self)
        self.register_event('embedded_device_client_detection_completed')

        self.device = device
        self.device.bind(
            embedded_device_client_detection_completed=self.
            embedded_device_notified,  # noqa
            service_notified=self.service_notified,
        )
        self.device_type = self.device.get_friendly_device_type()

        self.version = int(self.device.get_device_type_version())
        self.icons = device.icons

        self.wan_connection_device = None
        self.wan_common_interface_connection = None

        try:
            wan_connection_device = self.device.get_embedded_device_by_type(
                'WANConnectionDevice')[0]
            self.wan_connection_device = WANConnectionDeviceClient(
                wan_connection_device)
        except Exception as er:
            self.warning(
                f'Embedded WANConnectionDevice device not available, device ' +
                f'not implemented properly according to the UPnP ' +
                f'specification [ERROR: {er}]')
            raise

        for service in self.device.get_services():
            if service.get_type() in [
                    'urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1'
            ]:
                self.wan_common_interface_connection = WANCommonInterfaceConfigClient(  # noqa: E501
                    service)

        self.info(f'WANDevice {device.get_friendly_name()}')

    def remove(self):
        self.info('removal of WANDeviceClient started')
        if self.wan_common_interface_connection is not None:
            self.wan_common_interface_connection.remove()
        if self.wan_connection_device is not None:
            self.wan_connection_device.remove()

    def embedded_device_notified(self, device):
        self.info(f'EmbeddedDevice {device} sent notification')
        if self.embedded_device_detection_completed:
            return

        self.embedded_device_detection_completed = True
        if (self.embedded_device_detection_completed is True
                and self.service_detection_completed is True):
            self.dispatch_event('embedded_device_client_detection_completed',
                                self)

    def service_notified(self, service):
        self.info(f'Service {service} sent notification')
        if self.service_detection_completed:
            return
        if self.wan_common_interface_connection is not None:
            if not hasattr(
                    self.wan_common_interface_connection.service,
                    'last_time_updated',
            ):
                return
            if (self.wan_common_interface_connection.service.last_time_updated
                    is None):
                return
        self.service_detection_completed = True
        if (self.embedded_device_detection_completed is True
                and self.service_detection_completed is True):
            self.dispatch_event('embedded_device_client_detection_completed',
                                self)
Пример #5
0
class WANDeviceClient(log.Loggable):
    logCategory = 'wan_device_client'

    def __init__(self, device):
        self.device = device
        self.device_type = self.device.get_friendly_device_type()
        self.version = int(self.device.get_device_type_version())
        self.icons = device.icons

        self.wan_connection_device = None
        self.wan_common_interface_connection = None

        self.embedded_device_detection_completed = False
        self.service_detection_completed = False

        louie.connect(
            self.embedded_device_notified,
            signal='Coherence.UPnP.EmbeddedDeviceClient.detection_completed',
            sender=self.device)

        try:
            wan_connection_device = self.device.get_embedded_device_by_type(
                'WANConnectionDevice')[0]
            self.wan_connection_device = WANConnectionDeviceClient(
                wan_connection_device)
        except:
            self.warning(
                "Embedded WANConnectionDevice device not available, device not implemented properly according to the UPnP specification"
            )
            raise

        louie.connect(self.service_notified,
                      signal='Coherence.UPnP.DeviceClient.Service.notified',
                      sender=self.device)
        for service in self.device.get_services():
            if service.get_type() in [
                    "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1"
            ]:
                self.wan_common_interface_connection = WANCommonInterfaceConfigClient(
                    service)

        self.info("WANDevice %s" % (self.device.get_friendly_name()))

    def remove(self):
        self.info("removal of WANDeviceClient started")
        if self.wan_common_interface_connection != None:
            self.wan_common_interface_connection.remove()
        if self.wan_connection_device != None:
            self.wan_connection_device.remove()

    def embedded_device_notified(self, device):
        self.info("EmbeddedDevice %r sent notification" % device)
        if self.embedded_device_detection_completed == True:
            return

        self.embedded_device_detection_completed = True
        if self.embedded_device_detection_completed == True and self.service_detection_completed == True:
            louie.send(
                'Coherence.UPnP.EmbeddedDeviceClient.detection_completed',
                None, self)

    def service_notified(self, service):
        self.info("Service %r sent notification" % service)
        if self.service_detection_completed == True:
            return
        if self.wan_common_interface_connection != None:
            if not hasattr(self.wan_common_interface_connection.service,
                           'last_time_updated'):
                return
            if self.wan_common_interface_connection.service.last_time_updated == None:
                return
        self.service_detection_completed = True
        if self.embedded_device_detection_completed == True and self.service_detection_completed == True:
            louie.send(
                'Coherence.UPnP.EmbeddedDeviceClient.detection_completed',
                None, self)
Пример #6
0
class WANDeviceClient(log.Loggable):
    logCategory = 'wan_device_client'

    def __init__(self, device):
        self.device = device
        self.device_type = self.device.get_friendly_device_type()
        self.version = int(self.device.get_device_type_version())
        self.icons = device.icons

        self.wan_connection_device = None
        self.wan_common_interface_connection = None

        self.embedded_device_detection_completed = False
        self.service_detection_completed = False

        louie.connect(self.embedded_device_notified, signal='Coherence.UPnP.EmbeddedDeviceClient.detection_completed', sender=self.device)

        try:
            wan_connection_device = self.device.get_embedded_device_by_type('WANConnectionDevice')[0]
            self.wan_connection_device = WANConnectionDeviceClient(wan_connection_device)
        except:
            self.warning("Embedded WANConnectionDevice device not available, device not implemented properly according to the UPnP specification")
            raise

        louie.connect(self.service_notified, signal='Coherence.UPnP.DeviceClient.Service.notified', sender=self.device)
        for service in self.device.get_services():
            if service.get_type() in ["urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1"]:
                self.wan_common_interface_connection = WANCommonInterfaceConfigClient(service)

        self.info("WANDevice %s" % (self.device.get_friendly_name()))

    def remove(self):
        self.info("removal of WANDeviceClient started")
        if self.wan_common_interface_connection != None:
            self.wan_common_interface_connection.remove()
        if self.wan_connection_device != None:
            self.wan_connection_device.remove()

    def embedded_device_notified(self, device):
        self.info("EmbeddedDevice %r sent notification" % device);
        if self.embedded_device_detection_completed == True:
            return

        self.embedded_device_detection_completed = True
        if self.embedded_device_detection_completed == True and self.service_detection_completed == True:
            louie.send('Coherence.UPnP.EmbeddedDeviceClient.detection_completed', None,
                               self)

    def service_notified(self, service):
        self.info("Service %r sent notification" % service);
        if self.service_detection_completed == True:
            return
        if self.wan_common_interface_connection != None:
            if not hasattr(self.wan_common_interface_connection.service, 'last_time_updated'):
                return
            if self.wan_common_interface_connection.service.last_time_updated == None:
                return
        self.service_detection_completed = True
        if self.embedded_device_detection_completed == True and self.service_detection_completed == True:
            louie.send('Coherence.UPnP.EmbeddedDeviceClient.detection_completed', None,
                               self)