Source code for gstswitch.controller

"""
The controller is the interface for all remote method calls over dbus.
The Controller class creates the controller,
which can be used to invoke the remote methods.
"""

import ast
from .connection import Connection
from .exception import ConnectionReturnError

__all__ = ["Controller", ]


[docs]class Controller(object): """A Class to control all interactions with the gst-switch-srv over dbus. Provides the interface for higher level interactions :param: None """ def __init__( self, address="unix:abstract=gstswitch", bus_name='info.duzy.gst.switch.SwitchController', object_path="/info/duzy/gst/switch/SwitchController", default_interface="info.duzy.gst.switch.SwitchControllerInterface" ): super(Controller, self).__init__() self._address = None self._bus_name = None self._object_path = None self._default_interface = None self.connection = None self.address = address self.bus_name = bus_name self.object_path = object_path self.default_interface = default_interface @property def address(self): """ Get the address """ return self._address @address.setter
[docs] def address(self, address): """Set the Address http://dbus.freedesktop.org/doc/dbus-specification.html#addresses """ if not address: raise ValueError("Address '{0}' cannot be blank") else: adr = str(address) if adr.find(':') > 0: self._address = adr else: raise ValueError("Address must follow specifications mentioned" " at http://dbus.freedesktop.org/doc/" "dbus-specification.html#addresses")
@property def bus_name(self): """Get the bus name """ if self._bus_name is None: return None return self._bus_name @bus_name.setter
[docs] def bus_name(self, bus_name): """Set the Bus Name http://dbus.freedesktop.org/doc/dbus-specification.html\ #message-protocol-names-bus """ if bus_name is None: self._bus_name = None return bus = str(bus_name) self._bus_name = bus
@property def object_path(self): """Get the object path """ return self._object_path @object_path.setter
[docs] def object_path(self, object_path): """Set the object_path http://dbus.freedesktop.org/doc/dbus-specification.html\ #message-protocol-marshaling-object-path """ if not object_path: raise ValueError("object_path '{0} cannot be blank'") else: obj = str(object_path) if obj[0] == '/': self._object_path = obj else: raise ValueError("object_path must follow specifications" " mentioned at " "http://dbus.freedesktop.org/doc/" "dbus-specification.html" "#message-protocol-marshaling-object-path""")
@property def default_interface(self): """Get the default interface """ return self._default_interface @default_interface.setter
[docs] def default_interface(self, default_interface): """Set the default_interface http://dbus.freedesktop.org/doc/dbus-specification.html\ #message-protocol-names-interface """ if not default_interface: raise ValueError("default_interface '{0} cannot be blank'") else: intr = str(default_interface) if intr.count('.') > 1: self._default_interface = intr else: raise ValueError("default_interface must follow " "specifications mentioned at " "http://dbus.freedesktop.org/" "doc/dbus-specification.html" "#message-protocol-names-interface")
[docs] def establish_connection(self): """Establishes a fresh connection to the dbus Connection stored as self.connection :param: None :returns: None """ self.connection = Connection( address=self.address, bus_name=self.bus_name, object_path=self.object_path, default_interface=self.default_interface) self.connection.connect_dbus()
[docs] def get_compose_port(self): """Get the compose port number :param: None :returns: compose port number """ conn = self.connection.get_compose_port() try: compose_port = conn.unpack()[0] return compose_port except AttributeError: raise ConnectionReturnError('Connection returned invalid values.' 'Should return a GVariant tuple')
[docs] def get_encode_port(self): """Get the encode port number :param: None :returns: encode port number """ conn = self.connection.get_encode_port() try: encode_port = conn.unpack()[0] return encode_port except AttributeError: raise ConnectionReturnError('Connection returned invalid values.' ' Should return a GVariant tuple')
[docs] def get_audio_port(self): """Get the audio port number :param: None :returns: audio port number """ conn = self.connection.get_audio_port() try: audio_port = conn.unpack()[0] return audio_port except AttributeError: raise ConnectionReturnError('Connection returned invalid values. ' 'Should return a GVariant tuple')
[docs] def get_preview_ports(self): """Get all the preview ports :param: None :returns: list of all preview ports """ conn = self.connection.get_preview_ports() try: res = conn.unpack()[0] preview_ports = self.parse_preview_ports(res) return preview_ports except AttributeError: raise ConnectionReturnError('Connection returned invalid values. ' 'Should return a GVariant tuple')
[docs] def set_composite_mode(self, mode): """Set the current composite mode. Modes between 0 and 3 are allowed. :param mode: new composite mode :returns: True when requested """ self.establish_connection() # only modes from 0 to 3 are supported if mode >= 0 and mode <= 3: try: conn = self.connection.set_composite_mode(mode) print conn res = conn.unpack()[0] if res is True: print "Set composite mode to %s" % (str(mode)) except AttributeError: raise ConnectionReturnError('Connection returned invalid ' 'values. Should return a ' 'GVariant tuple') else: pass # raise some Exception return res
[docs] def set_encode_mode(self, channel): """Set the encode mode WARNING: THIS DOES NOT WORK. :param: channel :returns: True when requested """ self.establish_connection() try: conn = self.connection.set_encode_mode(channel) res = conn.unpack()[0] if res is True: print "Set encode mode to %s" % (str(channel)) else: pass # raise some exception return res except AttributeError: raise ConnectionReturnError('Connection returned invalid values. ' 'Should return a GVariant tuple')
[docs] def new_record(self): """Start a new recording :param: None """ self.establish_connection() try: conn = self.connection.new_record() res = conn.unpack()[0] if res is True: # logging print "New record" else: pass except AttributeError: raise ConnectionReturnError('Connection returned invalid values. ' 'Should return a GVariant tuple') return res
[docs] def adjust_pip(self, xpos, ypos, width, height): """Change the PIP position and size :param xpos: the x position of the PIP :param ypos: the y position of the PIP :param width: the width of the PIP :param height: the height of the PIP :returns: result - PIP has been changed succefully """ self.establish_connection() try: conn = self.connection.adjust_pip(xpos, ypos, width, height) res = conn.unpack()[0] print "adjust pip xpos:%s ypos:%s w:%s h:%s" % ( str(xpos), str(ypos), str(width), str(height)) except AttributeError: raise ConnectionReturnError('Connection returned invalid values. ' 'Should return a GVariant tuple') # to-do - parse return res
[docs] def switch(self, channel, port): """Switch the channel to the target port :param channel: The channel to be switched, 'A', 'B', 'a' :param port: The target port number :returns: True when requested """ self.establish_connection() try: conn = self.connection.switch(channel, port) res = conn.unpack()[0] if res is True: print "Switch channel:%s port:%s" % (str(channel), str(port)) else: pass return res except AttributeError: raise ConnectionReturnError('Connection returned invalid values. ' 'Should return a GVariant tuple')
[docs] def click_video(self, xpos, ypos, width, height): """User click on the video :param xpos: :param ypos: :param width: :param height: :returns: True when requested """ self.establish_connection() try: conn = self.connection.click_video(xpos, ypos, width, height) res = conn.unpack()[0] if res is True: print "Click video: xpos:%s ypos:%s width:%s height:%s" % ( str(xpos), str(ypos), str(width), str(height)) else: pass except: raise ConnectionReturnError('Connection returned invalid values. ' 'Should return a GVariant tuple') return res
[docs] def mark_face(self, faces): """Mark faces :param faces: tuple having four elements :returns: True when requested """ # faces is list of a tuple of four elements self.establish_connection() self.connection.mark_face(faces)
[docs] def mark_tracking(self, faces): """Mark tracking :param faces: tuple having four elements :returns: True when requested """ self.establish_connection() self.connection.mark_tracking(faces)
@classmethod
[docs] def parse_preview_ports(cls, res): """Parses the preview_ports string""" # res = '[(a, b, c), (a, b, c)*]' try: liststr = ast.literal_eval(res) except (ValueError, SyntaxError): raise ConnectionReturnError(("Connection returned " "invalid values:{0}") .format(res)) preview_ports = [] for tupl in liststr: preview_ports.append(int(tupl[0])) return preview_ports