dbus: add a DBus base object

Currently just handling some properties that are common, but will do other
things soon.
This commit is contained in:
Peter Hutterer 2018-01-24 20:02:43 +10:00
parent 1a6071b93d
commit 584925a0d9
1 changed files with 62 additions and 57 deletions

View File

@ -88,7 +88,15 @@ INTF_MANAGER = 'org.freedesktop.tuhi1.Manager'
INTF_DEVICE = 'org.freedesktop.tuhi1.Device' INTF_DEVICE = 'org.freedesktop.tuhi1.Device'
class TuhiDBusDevice(GObject.Object): class _TuhiDBus(GObject.Object):
def __init__(self, connection, objpath, interface):
GObject.Object.__init__(self)
self.connection = connection
self.objpath = objpath
self.interface = interface
class TuhiDBusDevice(_TuhiDBus):
""" """
Class representing a DBus object for a Tuhi device. This class only Class representing a DBus object for a Tuhi device. This class only
handles the DBus bits, communication with the device is done elsewhere. handles the DBus bits, communication with the device is done elsewhere.
@ -99,7 +107,9 @@ class TuhiDBusDevice(GObject.Object):
} }
def __init__(self, device, connection): def __init__(self, device, connection):
GObject.Object.__init__(self) objpath = device.address.replace(':', '_')
objpath = "{}/{}".format(BASE_PATH, objpath)
_TuhiDBus.__init__(self, connection, objpath, INTF_DEVICE)
self.name = device.name self.name = device.name
self.btaddr = device.address self.btaddr = device.address
@ -108,10 +118,6 @@ class TuhiDBusDevice(GObject.Object):
self.paired = device.paired self.paired = device.paired
self._listening = False self._listening = False
self._listening_client = None self._listening_client = None
objpath = device.address.replace(':', '_')
self.objpath = "{}/{}".format(BASE_PATH, objpath)
self._connection = connection
self._dbusid = self._register_object(connection) self._dbusid = self._register_object(connection)
device.connect('notify::paired', self._on_device_paired) device.connect('notify::paired', self._on_device_paired)
@ -135,11 +141,11 @@ class TuhiDBusDevice(GObject.Object):
inval_props = GLib.VariantBuilder(GLib.VariantType('as')) inval_props = GLib.VariantBuilder(GLib.VariantType('as'))
inval_props = inval_props.end() inval_props = inval_props.end()
self._connection.emit_signal(None, self.objpath, self.connection.emit_signal(None, self.objpath,
"org.freedesktop.DBus.Properties", "org.freedesktop.DBus.Properties",
"PropertiesChanged", "PropertiesChanged",
GLib.Variant.new_tuple( GLib.Variant.new_tuple(
GLib.Variant.new_string(INTF_DEVICE), GLib.Variant.new_string(self.interface),
props, props,
inval_props)) inval_props))
@ -152,12 +158,12 @@ class TuhiDBusDevice(GObject.Object):
self._paired = paired self._paired = paired
def remove(self): def remove(self):
self._connection.unregister_object(self._dbusid) self.connection.unregister_object(self._dbusid)
self._dbusid = None self._dbusid = None
def _register_object(self, connection): def _register_object(self, connection):
introspection = Gio.DBusNodeInfo.new_for_xml(INTROSPECTION_XML) introspection = Gio.DBusNodeInfo.new_for_xml(INTROSPECTION_XML)
intf = introspection.lookup_interface(INTF_DEVICE) intf = introspection.lookup_interface(self.interface)
return connection.register_object(self.objpath, return connection.register_object(self.objpath,
intf, intf,
self._method_cb, self._method_cb,
@ -165,7 +171,7 @@ class TuhiDBusDevice(GObject.Object):
self._property_write_cb) self._property_write_cb)
def _method_cb(self, connection, sender, objpath, interface, methodname, args, invocation): def _method_cb(self, connection, sender, objpath, interface, methodname, args, invocation):
if interface != INTF_DEVICE: if interface != self.interface:
return None return None
if methodname == 'Pair': if methodname == 'Pair':
@ -223,7 +229,7 @@ class TuhiDBusDevice(GObject.Object):
if sender != self._listening_client[0]: if sender != self._listening_client[0]:
status = GLib.Variant.new_int32(-errno.EAGAIN) status = GLib.Variant.new_int32(-errno.EAGAIN)
status = GLib.Variant.new_tuple(status) status = GLib.Variant.new_tuple(status)
connection.emit_signal(sender, self.objpath, INTF_DEVICE, connection.emit_signal(sender, self.objpath, self.interface,
"ListeningStopped", status) "ListeningStopped", status)
return return
@ -262,7 +268,7 @@ class TuhiDBusDevice(GObject.Object):
status = GLib.Variant.new_int32(0) status = GLib.Variant.new_int32(0)
status = GLib.Variant.new_tuple(status) status = GLib.Variant.new_tuple(status)
connection.emit_signal(sender, self.objpath, INTF_DEVICE, connection.emit_signal(sender, self.objpath, self.interface,
"ListeningStopped", status) "ListeningStopped", status)
self.listening = False self.listening = False
self.notify('listening') self.notify('listening')
@ -288,24 +294,24 @@ class TuhiDBusDevice(GObject.Object):
inval_props = GLib.VariantBuilder(GLib.VariantType('as')) inval_props = GLib.VariantBuilder(GLib.VariantType('as'))
inval_props = inval_props.end() inval_props = inval_props.end()
self._connection.emit_signal(None, self.objpath, self.connection.emit_signal(None, self.objpath,
"org.freedesktop.DBus.Properties", "org.freedesktop.DBus.Properties",
"PropertiesChanged", "PropertiesChanged",
GLib.Variant.new_tuple( GLib.Variant.new_tuple(
GLib.Variant.new_string(INTF_DEVICE), GLib.Variant.new_string(self.interface),
props, props,
inval_props)) inval_props))
def notify_button_press_required(self): def notify_button_press_required(self):
logger.debug("Sending ButtonPressRequired signal") logger.debug("Sending ButtonPressRequired signal")
self._connection.emit_signal(None, self.objpath, INTF_DEVICE, self.connection.emit_signal(None, self.objpath, self.interface,
"ButtonPressRequired", None) "ButtonPressRequired", None)
def __repr__(self): def __repr__(self):
return "{} - {}".format(self.objpath, self.name) return "{} - {}".format(self.objpath, self.name)
class TuhiDBusServer(GObject.Object): class TuhiDBusServer(_TuhiDBus):
""" """
Class for the DBus server. Class for the DBus server.
""" """
@ -324,7 +330,7 @@ class TuhiDBusServer(GObject.Object):
} }
def __init__(self): def __init__(self):
GObject.Object.__init__(self) _TuhiDBus.__init__(self, None, BASE_PATH, INTF_MANAGER)
self._devices = [] self._devices = []
self._pairable_devices = {} self._pairable_devices = {}
self._dbus = Gio.bus_own_name(Gio.BusType.SESSION, self._dbus = Gio.bus_own_name(Gio.BusType.SESSION,
@ -356,25 +362,24 @@ class TuhiDBusServer(GObject.Object):
inval_props = GLib.VariantBuilder(GLib.VariantType('as')) inval_props = GLib.VariantBuilder(GLib.VariantType('as'))
inval_props = inval_props.end() inval_props = inval_props.end()
self._connection.emit_signal(None, self.objpath, self.connection.emit_signal(None, self.objpath,
"org.freedesktop.DBus.Properties", "org.freedesktop.DBus.Properties",
"PropertiesChanged", "PropertiesChanged",
GLib.Variant.new_tuple( GLib.Variant.new_tuple(
GLib.Variant.new_string(INTF_MANAGER), GLib.Variant.new_string(self.interface),
props, props,
inval_props)) inval_props))
def _bus_aquired(self, connection, name): def _bus_aquired(self, connection, name):
introspection = Gio.DBusNodeInfo.new_for_xml(INTROSPECTION_XML) introspection = Gio.DBusNodeInfo.new_for_xml(INTROSPECTION_XML)
intf = introspection.lookup_interface(INTF_MANAGER) intf = introspection.lookup_interface(self.interface)
self.objpath = BASE_PATH self.connection = connection
Gio.DBusConnection.register_object(connection, Gio.DBusConnection.register_object(connection,
self.objpath, self.objpath,
intf, intf,
self._method_cb, self._method_cb,
self._property_read_cb, self._property_read_cb,
self._property_write_cb) self._property_write_cb)
self._connection = connection
def _bus_name_aquired(self, connection, name): def _bus_name_aquired(self, connection, name):
logger.debug('Bus name aquired') logger.debug('Bus name aquired')
@ -384,7 +389,7 @@ class TuhiDBusServer(GObject.Object):
pass pass
def _method_cb(self, connection, sender, objpath, interface, methodname, args, invocation): def _method_cb(self, connection, sender, objpath, interface, methodname, args, invocation):
if interface != INTF_MANAGER: if interface != self.interface:
return None return None
if methodname == 'StartSearch': if methodname == 'StartSearch':
@ -395,7 +400,7 @@ class TuhiDBusServer(GObject.Object):
invocation.return_value() invocation.return_value()
def _property_read_cb(self, connection, sender, objpath, interface, propname): def _property_read_cb(self, connection, sender, objpath, interface, propname):
if interface != INTF_MANAGER: if interface != self.interface:
return None return None
if propname == 'Devices': if propname == 'Devices':
@ -417,7 +422,7 @@ class TuhiDBusServer(GObject.Object):
if sender != self._searching_client[0]: if sender != self._searching_client[0]:
status = GLib.Variant.new_int32(-errno.EAGAIN) status = GLib.Variant.new_int32(-errno.EAGAIN)
status = GLib.Variant.new_tuple(status) status = GLib.Variant.new_tuple(status)
connection.emit_signal(sender, self.objpath, INTF_MANAGER, connection.emit_signal(sender, self.objpath, self.interface,
"SearchStopped", status) "SearchStopped", status)
return return
@ -464,8 +469,8 @@ class TuhiDBusServer(GObject.Object):
self.is_searching = False self.is_searching = False
status = GLib.Variant.new_int32(status) status = GLib.Variant.new_int32(status)
status = GLib.Variant.new_tuple(status) status = GLib.Variant.new_tuple(status)
self._connection.emit_signal(self._searching_client[0], self.connection.emit_signal(self._searching_client[0],
self.object_path, INTF_MANAGER, self.object_path, self.interface,
"SearchStopped", status) "SearchStopped", status)
self._searching_client = None self._searching_client = None
@ -480,7 +485,7 @@ class TuhiDBusServer(GObject.Object):
Gio.bus_unown_name(self._dbus) Gio.bus_unown_name(self._dbus)
def create_device(self, device): def create_device(self, device):
dev = TuhiDBusDevice(device, self._connection) dev = TuhiDBusDevice(device, self.connection)
dev.connect('notify::paired', self._on_device_paired) dev.connect('notify::paired', self._on_device_paired)
self._devices.append(dev) self._devices.append(dev)
if not device.paired: if not device.paired:
@ -500,17 +505,17 @@ class TuhiDBusServer(GObject.Object):
inval_props = GLib.VariantBuilder(GLib.VariantType('as')) inval_props = GLib.VariantBuilder(GLib.VariantType('as'))
inval_props = inval_props.end() inval_props = inval_props.end()
self._connection.emit_signal(None, self.objpath, self.connection.emit_signal(None, self.objpath,
"org.freedesktop.DBus.Properties", "org.freedesktop.DBus.Properties",
"PropertiesChanged", "PropertiesChanged",
GLib.Variant.new_tuple( GLib.Variant.new_tuple(
GLib.Variant.new_string(INTF_MANAGER), GLib.Variant.new_string(self.interface),
props, props,
inval_props)) inval_props))
def _emit_pairable_signal(self, device): def _emit_pairable_signal(self, device):
arg = GLib.Variant.new_object_path(device.objpath) arg = GLib.Variant.new_object_path(device.objpath)
self._connection.emit_signal(self._searching_client[0], self.connection.emit_signal(self._searching_client[0],
self.objpath, INTF_MANAGER, self.objpath, self.interface,
"PairableDevice", "PairableDevice",
GLib.Variant.new_tuple(arg)) GLib.Variant.new_tuple(arg))