X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=osmclient%2Fcommon%2Futils.py;h=aed7d2964a36359c130f4e64ee9749ed582ab73b;hb=e7c24981a7021176e68ee87998c86d21e87f548e;hp=937e12175ee2942169a26dfadf695cdd6f53659a;hpb=d6eb17bc67230c86a053a71ccc7bb44a567618fc;p=osm%2Fosmclient.git diff --git a/osmclient/common/utils.py b/osmclient/common/utils.py index 937e121..aed7d29 100644 --- a/osmclient/common/utils.py +++ b/osmclient/common/utils.py @@ -59,32 +59,35 @@ def get_key_val_from_pkg(descriptor_file): tar = tarfile.open(descriptor_file) yamlfile = None for member in tar.getmembers(): - if (re.match('.*.yaml', member.name) and - len(member.name.split('/')) == 2): + if re.match(".*.yaml", member.name) and len(member.name.split("/")) == 2: yamlfile = member.name break if yamlfile is None: return None - dict = yaml.load(tar.extractfile(yamlfile)) + dict = yaml.safe_load(tar.extractfile(yamlfile)) result = {} - for k1, v1 in list(dict.items()): - if not k1.endswith('-catalog'): - continue - for k2, v2 in list(v1.items()): - if not k2.endswith('nsd') and not k2.endswith('vnfd'): + for k in dict: + if "nsd" in k: + result["type"] = "nsd" + else: + result["type"] = "vnfd" + if "type" not in result: + for k1, v1 in list(dict.items()): + if not k1.endswith("-catalog"): continue + for k2, v2 in v1.items(): + if not k2.endswith("nsd") and not k2.endswith("vnfd"): + continue + if "nsd" in k2: + result["type"] = "nsd" + else: + result["type"] = "vnfd" + for entry in v2: + for k3, v3 in list(entry.items()): + # strip off preceeding chars before : + key_name = k3.split(":").pop() + result[key_name] = v3 - if 'nsd' in k2: - result['type'] = 'nsd' - else: - result['type'] = 'vnfd' - - for entry in v2: - for k3, v3 in list(entry.items()): - # strip off preceeding chars before : - key_name = k3.split(':').pop() - - result[key_name] = v3 tar.close() return result