6 import dbus.mainloop.glib
8 from dbus.lowlevel import MethodCallMessage, HANDLER_RESULT_NOT_YET_HANDLED
10 def property_changed(name, value, path, interface):
11 iface = interface[interface.rfind(".") + 1:]
12 if name in ["Strength", "Priority"]:
16 print "{%s} [%s] %s = %s" % (iface, path, name, val)
18 def message_filter(connection, message):
19 if not isinstance(message, MethodCallMessage):
20 return HANDLER_RESULT_NOT_YET_HANDLED
22 interface = message.get_interface()
23 path = message.get_path()
24 name = message.get_member()
25 args = message.get_args_list()
27 property_changed(name, args, path, interface)
29 if __name__ == '__main__':
30 dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
32 bus = dbus.SystemBus()
34 bus.add_signal_receiver(property_changed,
35 bus_name="net.connman",
36 signal_name = "PropertyChanged",
38 interface_keyword="interface")
40 bus.add_match_string("member=Change,interface=net.connman.Session")
41 bus.add_match_string("member=Update,interface=net.connman.Notification")
42 bus.add_message_filter(message_filter)
44 mainloop = gobject.MainLoop()