3 from lcm.pub.utils.toscaparser import EtsiNsdInfoModel
6 class EtsiVnfdInfoModel(EtsiNsdInfoModel):
8 def __init__(self, path, params):
9 super(EtsiVnfdInfoModel, self).__init__(path, params)
11 def parseModel(self, tosca):
12 self.buidMetadata(tosca)
13 if hasattr(tosca, 'topology_template') and hasattr(tosca.topology_template, 'inputs'):
14 self.inputs = self.buildInputs(tosca.topology_template.inputs)
16 nodeTemplates = map(functools.partial(self.buildNode, inputs=tosca.inputs, parsed_params=tosca.parsed_params),
19 self.services = self._get_all_services(nodeTemplates)
20 self.vcloud = self._get_all_vcloud(nodeTemplates)
21 self.vcenter = self._get_all_vcenter(nodeTemplates)
24 def _get_all_services(self, nodeTemplates):
26 for node in nodeTemplates:
27 if self.isService(node):
29 service['serviceId'] = node['name']
30 if 'description' in node:
31 service['description'] = node['description']
32 service['properties'] = node['properties']
33 service['dependencies'] = map(lambda x: self.get_requirement_node_name(x),
34 self.getNodeDependencys(node))
35 service['networks'] = map(lambda x: self.get_requirement_node_name(x), self.getVirtualLinks(node))
40 def _get_all_vcloud(self, nodeTemplates):
42 for node in nodeTemplates:
43 if self._isVcloud(node):
45 if 'vdc_name' in node['properties']:
46 ret['vdc_name'] = node['properties']['vdc_name']
49 if 'storage_clusters' in node['properties']:
50 ret['storage_clusters'] = node['properties']['storage_clusters']
52 ret['storage_clusters'] = []
57 def _isVcloud(self, node):
58 return node['nodeType'].upper().find('.VCLOUD.') >= 0 or node['nodeType'].upper().endswith('.VCLOUD')
60 def _get_all_vcenter(self, nodeTemplates):
62 for node in nodeTemplates:
63 if self._isVcenter(node):
65 if 'compute_clusters' in node['properties']:
66 ret['compute_clusters'] = node['properties']['compute_clusters']
68 ret['compute_clusters'] = []
69 if 'storage_clusters' in node['properties']:
70 ret['storage_clusters'] = node['properties']['storage_clusters']
72 ret['storage_clusters'] = []
73 if 'network_clusters' in node['properties']:
74 ret['network_clusters'] = node['properties']['network_clusters']
76 ret['network_clusters'] = []
81 def _isVcenter(self, node):
82 return node['nodeType'].upper().find('.VCENTER.') >= 0 or node['nodeType'].upper().endswith('.VCENTER')