test: Update service monitoring script
[platform/upstream/connman.git] / test / monitor-services
1 #!/usr/bin/python
2
3 import gobject
4
5 import dbus
6 import dbus.mainloop.glib
7
8 def extract_values(values):
9         val = "{"
10         for key in values.keys():
11                 val += " " + key + "="
12                 if key in ["Servers", "Excludes"]:
13                         val += extract_list(values[key])
14                 else:
15                         val += str(values[key])
16         val += " }"
17         return val
18
19 def extract_list(list):
20         val = "["
21         for i in list:
22                 val += " " + str(i)
23         val += " ]"
24         return val
25
26 def property_changed(name, value, path):
27         service = path[path.rfind("/") + 1:]
28         if name in ["Services"]:
29                 val = "["
30                 for i in value:
31                         val = val + " " + i[i.rfind("/") + 1:]
32                 val = val + " ]"
33         elif name in ["IPv4", "IPv4.Configuration",
34                         "IPv6", "IPv6.Configuration",
35                         "Proxy", "Proxy.Configuration", "Ethernet", "Provider"]:
36                 val = extract_values(value)
37         elif name in ["Nameservers", "Nameservers.Configuration",
38                         "Domains", "Domains.Configuration",
39                         "Timeservers", "Timeservers.Configuration", "Security"]:
40                 val = extract_list(value)
41         elif name in ["Strength", "Priority"]:
42                 val = int(value)
43         else:
44                 val = str(value)
45         print "[%s] %s = %s" % (service, name, val)
46
47 def services_changed(services, removed):
48         for i in services:
49                 service = i[0][i[0].rfind("/") + 1:]
50                 print "[%s] added / update" % (service)
51                 for n in i[1].keys():
52                         property_changed(n, i[1][n], i[0])
53         for i in removed:
54                 service = i[i.rfind("/") + 1:]
55                 print "[%s] removed" % (service)
56
57 if __name__ == '__main__':
58         dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
59
60         bus = dbus.SystemBus()
61
62         bus.add_signal_receiver(property_changed,
63                                 bus_name="net.connman",
64                                 dbus_interface="net.connman.Service",
65                                 signal_name="PropertyChanged",
66                                 path_keyword="path")
67
68         bus.add_signal_receiver(property_changed,
69                                 bus_name="net.connman",
70                                 dbus_interface="net.connman.Manager",
71                                 signal_name="PropertyChanged",
72                                 path_keyword="path")
73
74         bus.add_signal_receiver(services_changed,
75                                 bus_name="net.connman",
76                                 dbus_interface="net.connman.Manager",
77                                 signal_name="ServicesChanged")
78
79         mainloop = gobject.MainLoop()
80         mainloop.run()