summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorDaniel Wagner <wagi@monom.org>2011-07-07 19:47:24 +0300
committerSamuel Ortiz <sameo@linux.intel.com>2011-07-07 19:07:23 +0200
commit08642ea4e3ed3306a6a468809dc249caa1fe1e29 (patch)
treedbda014d014bceba778afe3e3631285d02266344 /test
parentb47073ad559febfcec83ff9e7a8ba7501545790e (diff)
downloadconnman-08642ea4e3ed3306a6a468809dc249caa1fe1e29.tar.gz
connman-08642ea4e3ed3306a6a468809dc249caa1fe1e29.tar.bz2
connman-08642ea4e3ed3306a6a468809dc249caa1fe1e29.zip
monitor-connman: Parse Notification messages
Diffstat (limited to 'test')
-rwxr-xr-xtest/monitor-connman47
1 files changed, 45 insertions, 2 deletions
diff --git a/test/monitor-connman b/test/monitor-connman
index cf8f7a67..4d44519a 100755
--- a/test/monitor-connman
+++ b/test/monitor-connman
@@ -7,12 +7,54 @@ import dbus.mainloop.glib
from dbus.lowlevel import MethodCallMessage, HANDLER_RESULT_NOT_YET_HANDLED
-def property_changed(name, value, path, interface):
- iface = interface[interface.rfind(".") + 1:]
+def extract_list(list):
+ val = "["
+ for i in list:
+ if type(i).__name__ == 'Dictionary':
+ val = extract_values(i)
+ else:
+ val += " " + str(i)
+ val += " ]"
+ return val
+
+def extract_values(values):
+ val = "{"
+ for key in values.keys():
+ val += " " + key + "="
+ if key in ["PrefixLength"]:
+ val += "%s" % (int(values[key]))
+ elif key in ["IPv4", "IPv6", "Ethernet" ]:
+ val += extract_values(values[key])
+ elif key in [ "AllowedBearers" ]:
+ val += extract_list(values[key])
+ else:
+ if key in ["Servers", "Excludes"]:
+ val += extract_list(values[key])
+ else:
+ val += str(values[key])
+ val += " }"
+ return val
+
+def extract(name, value):
+ val = None
+
if name in ["Strength", "Priority"]:
val = int(value)
+ elif name in ["IPv4", "IPv6", "Ethernet", "Proxy" ]:
+ val = extract_values(value)
+ elif name in ["Nameservers", "Domains", "Services",
+ "Update", "Technologies", "AvailableTechnologies",
+ "EnabledTechnologies", "ConnectedTechnologies" ]:
+ val = extract_list(value)
else:
val = str(value)
+
+ return val
+
+def property_changed(name, value, path, interface):
+ iface = interface[interface.rfind(".") + 1:]
+ val = extract(name, value)
+
print "{%s} [%s] %s = %s" % (iface, path, name, val)
def message_filter(connection, message):
@@ -42,4 +84,5 @@ if __name__ == '__main__':
bus.add_message_filter(message_filter)
mainloop = gobject.MainLoop()
+
mainloop.run()