X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Frspecs%2Felements%2Fversions%2Fpgv2SliverType.py;fp=sfa%2Frspecs%2Felements%2Fversions%2Fpgv2SliverType.py;h=b8ca2d11f37555f0470c391be760fecbb7ed86f7;hb=63bb6c04ee9f566071c3211a76e22559595d42e6;hp=ee9797a323ddc0f93e780c45ded8d8ccb76e9136;hpb=155a986546de9ce3e5356305f371aaee1927df6d;p=sfa.git diff --git a/sfa/rspecs/elements/versions/pgv2SliverType.py b/sfa/rspecs/elements/versions/pgv2SliverType.py index ee9797a3..b8ca2d11 100644 --- a/sfa/rspecs/elements/versions/pgv2SliverType.py +++ b/sfa/rspecs/elements/versions/pgv2SliverType.py @@ -3,6 +3,8 @@ from sfa.rspecs.elements.sliver import Sliver from sfa.rspecs.elements.versions.pgv2DiskImage import PGv2DiskImage from sfa.rspecs.elements.versions.plosv1FWRule import PLOSv1FWRule +from sfa.util.sfalogging import logger + class PGv2SliverType: @staticmethod @@ -29,16 +31,29 @@ class PGv2SliverType: PGv2SliverType.add_sliver_attributes(sliver_elem, sliver.get('tags', [])) @staticmethod - def add_sliver_attributes(xml, attributes): - if attributes: - for attribute in attributes: - if attribute['name'] == 'initscript': - xml.add_element('{%s}initscript' % xml.namespaces['planetlab'], name=attribute['value']) - elif attribute['tagname'] == 'flack_info': - attrib_elem = xml.add_element('{%s}info' % self.namespaces['flack']) + def add_sliver_attributes(xml, tags): + if tags is None: + return + for tag in tags: + tagname = tag['tagname'] if 'tagname' in tag else tag['name'] + if tagname == 'flack_info': + attrib_elem = xml.add_element('{%s}info' % self.namespaces['flack']) + try: attrib_dict = eval(tag['value']) for (key, value) in attrib_dict.items(): attrib_elem.set(key, value) + except Exception as e: + logger.warning("Could not parse dictionary in flack tag -- {}".format(e)) + elif tagname == 'initscript': + xml.add_element('{%s}initscript' % xml.namespaces['planetlab'], + name=tag['value']) + else: + xml.add_element('{%s}attribute' % (xml.namespaces['planetlab']), + name = tagname, + value = tag['value'], + scope = tag.get('scope', 'unknown'), + ) + @staticmethod def get_slivers(xml, filter=None): if filter is None: filter={}