From 3d20d1517f113917a71f7a404a919e7bde7c6611 Mon Sep 17 00:00:00 2001 From: Rob Austein Date: Wed, 4 Jul 2007 00:00:20 +0000 Subject: Cleanup svn path=/scripts/rpki/up_down.py; revision=718 --- scripts/rpki/up_down.py | 84 ++++++++++++++++++++++--------------------------- 1 file changed, 38 insertions(+), 46 deletions(-) (limited to 'scripts/rpki/up_down.py') diff --git a/scripts/rpki/up_down.py b/scripts/rpki/up_down.py index c3aa7539..b0fd7a98 100644 --- a/scripts/rpki/up_down.py +++ b/scripts/rpki/up_down.py @@ -2,9 +2,18 @@ import base64, xml.sax, resource_set +def snarf(obj, attrs, key, func=None): + try: + val = attrs.getValue(key).encode("ascii") + if func: + val = func(val) + except KeyError: + val = None + setattr(obj, key, val) + class msg(object): - def msgToXML(self): + def __str__(self): return ('\ \n\ \n \n" return xml @@ -104,23 +101,16 @@ class list_response(msg): self.resource_classes[-1].issuer = base64.b64decode(text) def toXML(self): - xml = "" - for c in self.resource_classes: - xml += c.toXML() - return xml + return "".join(map(str, self.resource_classes)) class issue(msg): def startElement(self, name, attrs): assert name == "request" - self.class_name = attrs.getValue("class_name") - for k,f in (("req_resource_set_as", resource_set.resource_set_as), - ("req_resource_set_ipv4", resource_set.resource_set_ipv4), - ("req_resource_set_ipv6", resource_set.resource_set_ipv6)): - try: - setattr(self, k, f(attrs.getValue(k).encode("ascii"))) - except KeyError: - setattr(self, k, None) + snarf(self, attrs, "class_name") + snarf(self, attrs, "req_resource_set_as", resource_set.resource_set_as) + snarf(self, attrs, "req_resource_set_ipv4", resource_set.resource_set_ipv4) + snarf(self, attrs, "req_resource_set_ipv6", resource_set.resource_set_ipv6) def endElement(self, name, text): assert name == "request" @@ -145,8 +135,8 @@ class issue_response(list_response): class revoke(msg): def startElement(self, name, attrs): - self.class_name = attrs.getValue("class_name") - self.ski = attrs.getValue("ski") + snarf(self, attrs, "class_name") + snarf(self, attrs, "ski") def toXML(self): return (' \n' % (self.class_name, self.ski)) @@ -191,19 +181,21 @@ class sax_handler(xml.sax.handler.ContentHandler): "revoke" : revoke(), "revoke_response" : revoke_response(), "error_response" : error_response() - }[attrs.getValue("type")] - assert self.obj != None - for k in ("type", "sender", "recipient"): - setattr(self.obj, k, attrs.getValue(k).encode("ascii")) + }[attrs.getValue("type").encode("ascii")] + assert self.obj + snarf(self.obj, attrs, "sender") + snarf(self.obj, attrs, "recipient") + snarf(self.obj, attrs, "type") + else: - assert self.obj != None + assert self.obj self.obj.startElement(name, attrs) def characters(self, content): self.text += content def endElement(self, name): - assert self.obj != None + assert self.obj if name != "message": self.obj.endElement(name, self.text) self.text = "" -- cgit v1.2.3