blob: a8cf948ce587407ec325e01ba20db42df03256ec [file] [log] [blame]
#!/usr/bin/python
import gobject
import dbus
import dbus.mainloop.glib
from dbus.lowlevel import MethodCallMessage, HANDLER_RESULT_NOT_YET_HANDLED
def extract_list(list):
val = "["
for i in list:
val += " " + str(i)
val += " ]"
return val
def extract_bool(b):
if b == dbus.Boolean(1):
val = "true"
else:
val = "false"
return val
def property_changed_tag(name, value, path):
tag = path[path.rfind("/") + 1:]
if name in ["Records"]:
val = extract_list(value)
print "[Tag] [%s] %s = %s" % (tag, name, val)
def property_changed_device(name, value, path):
device = path[path.rfind("/") + 1:]
if name in ["Records"]:
val = extract_list(value)
print "[Device] [%s] %s = %s" % (device, name, val)
def property_changed_adapter(name, value, path):
adapter = path[path.rfind("/") + 1:]
if name in ["Polling"]:
val = extract_bool(value)
elif name in ["Tags", "Devices"]:
val = extract_list(value)
else:
val = str(value)
print "[Adapter] [%s] %s = %s" % (adapter, name, val)
def property_changed_manager(name, value, path):
manager = path[path.rfind("/") + 1:]
if name in ["Adapters"]:
val = extract_list(value)
print "[Manager] %s = %s" % (name, val)
if __name__ == '__main__':
dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
bus = dbus.SystemBus()
bus.add_signal_receiver(property_changed_manager,
bus_name="org.neard",
dbus_interface="org.neard.Manager",
signal_name = "PropertyChanged",
path_keyword="path")
bus.add_signal_receiver(property_changed_adapter,
bus_name="org.neard",
dbus_interface="org.neard.Adapter",
signal_name = "PropertyChanged",
path_keyword="path")
bus.add_signal_receiver(property_changed_tag,
bus_name="org.neard",
dbus_interface="org.neard.Tag",
signal_name = "PropertyChanged",
path_keyword="path")
bus.add_signal_receiver(property_changed_device,
bus_name="org.neard",
dbus_interface="org.neard.Device",
signal_name = "PropertyChanged",
path_keyword="path")
mainloop = gobject.MainLoop()
mainloop.run()