X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Frspecs%2Fpg_rspec.py;h=a2033cdc2746e4f4bdbc27f3b19b2a2737e564f4;hb=b4d3c48e1f55ef03042a03173dcdf8e9ef425937;hp=8b452f4e3f7a6fc50408044565eb57d2a7dee05c;hpb=acdfe055b4a7f0fdb94c60bc7ee05ca41b7b6645;p=sfa.git diff --git a/sfa/rspecs/pg_rspec.py b/sfa/rspecs/pg_rspec.py index 8b452f4e..a2033cdc 100755 --- a/sfa/rspecs/pg_rspec.py +++ b/sfa/rspecs/pg_rspec.py @@ -7,54 +7,89 @@ from sfa.util.plxrn import hostname_to_urn from sfa.util.config import Config class PGRSpec(RSpec): - xml = None header = '\n' + template = """""" namespaces = {'rspecv2':'http://www.protogeni.net/resources/rspec/0.2', 'xsi': 'http://www.w3.org/2001/XMLSchema-instance' } schemas = {'xsi': 'http://www.protogeni.net/resources/rspec/0.2 http://www.protogeni.net/resources/rspec/0.2/ad.xsd' } - - def create(self, type="advertisement"): - RSpec.create(self) - for namespace in self.namespaces: - xmlns = "xmlns" - if namespace not in 'rspecv2': - xmlns = xmlns + ":" + namespace - self.xml.set(xmlns, self.namespaces[namespace]) - for schema in self.schemas: - self.xml.set(schema+":schemaLocation", self.schemas[schema]) + format = 'pg' + format = 'protogeni' + xml = None def get_network(self): network = None - nodes = self.xml.xpath('//rspecv2:node[@component_manager_uuid][1]', self.namespaces) + nodes = self.xml.xpath('//rspecv2:node[@component_manager_uuid][1]', namespaces=self.namespaces) if nodes: network = nodes[0].get('component_manager_uuid') return network - def get_nodes(self, nodes_with_slivers=False): - nodes = self.xml.xpath('//rspecv2:node', self.namespaces) + def get_networks(self): + networks = self.xml.xpath('//rspecv2:node[@component_manager_uuid]/@component_manager_uuid', namespaces=self.namespaces) + return set(networks) + + def get_node_elements(self): + nodes = self.xml.xpath('//rspecv2:node', namespaces=self.namespaces) return nodes + def get_nodes(self, network=None): + return self.xml.xpath('//rspecv2:node[@component_name]/@component_name', namespaces=self.namespaces) + + def get_nodes_with_slivers(self, network=None): + if network: + return self.xml.xpath('//rspecv2:node[@component_manager_id="%s"][sliver_type]/@component_name' % network, namespaces=self.namespaces) + else: + return self.xml.xpath('//rspecv2:node[rspecv2:sliver_type]/@component_name', namespaces=self.namespaces) + + def get_nodes_without_slivers(self, network=None): + pass + def add_nodes(self, nodes, check_for_dupes=False): if not isinstance(nodes, list): nodes = [nodes] for node in nodes: urn = "" if check_for_dupes and \ - self.xml.xpath('//rspecv2:node[@component_uuid="%s"]' % urn, self.namespaces): + self.xml.xpath('//rspecv2:node[@component_uuid="%s"]' % urn, namespaces=self.namespaces): # node already exists continue node_tag = etree.SubElement(self.xml, 'node') + if 'network_urn' in node: + node_tag.set('component_manager_id', node['network_urn']) + if 'urn' in node: + node_tag.set('component_id', node['urn']) + if 'hostname' in node: + node_tag.set('component_name', node['hostname']) node_type_tag = etree.SubElement(node_tag, 'node_type', type_name='pcvm', type_slots='100') available_tag = etree.SubElement(node_tag, 'available').text = 'true' exclusive_tag = etree.SubElement(node_tag, 'exclusive').text = 'false' - location_tag = etree.SubElement(node_tag, 'location') - interface_tag = etree.SubElement(node_tag, 'interface') + location_tag = etree.SubElement(node_tag, 'location', location="US") + if 'site' in node: + if 'longitude' in node['site']: + location_tag.set('longitude', str(node['site']['longitude'])) + if 'latitude' in node['site']: + location_tag.set('latitude', str(node['site']['latitude'])) + #if 'interfaces' in node: def add_slivers(self, slivers, check_for_dupes=False): + if not isinstance(slivers, list): + slivers = [slivers] + + nodes_with_slivers = self.get_nodes_with_slivers() + for sliver in slivers: + hostname = sliver['hostname'] + if hostname in nodes_with_slivers: + continue + nodes = self.xml.xpath('//rspecv2:node[@component_name="%s"] | //node[@component_name="%s"]' % (hostname, hostname), namespaces=self.namespaces) + if nodes: + node = nodes[0] + node.set('client_id', hostname) + etree.SubElement(node, 'sliver_type', name='planetlab-vnode') + + def add_interfaces(self, interfaces, check_for_dupes=False): pass def add_links(self, links, check_for_dupes=False):