From fb9a2ae2290f2751bfc1333ff977ba3edd63894d Mon Sep 17 00:00:00 2001 From: Tony Mack Date: Tue, 24 May 2011 15:10:18 -0400 Subject: [PATCH] PG manifest and request rspecs should only contain nodes with slivers --- sfa/client/sfiAddSliver.py | 4 ++-- sfa/plc/aggregate.py | 3 +-- sfa/rspecs/pg_rspec.py | 29 +++++++++++++++++++++-------- sfa/rspecs/rspec.py | 15 +++++++++++++-- 4 files changed, 37 insertions(+), 14 deletions(-) diff --git a/sfa/client/sfiAddSliver.py b/sfa/client/sfiAddSliver.py index 7716f971..a96c678c 100755 --- a/sfa/client/sfiAddSliver.py +++ b/sfa/client/sfiAddSliver.py @@ -26,15 +26,15 @@ else: outfile=sys.stdout rspec = parse_rspec(infile) +rspec.type = 'request' nodes = file(command.opts.nodefile).read().split() try: if rspec.version['type'].lower() == 'protogeni': rspec.xml.set('type', 'request') - rspec.remove_element('available') slivers = [{'hostname': node} for node in nodes] rspec.add_slivers(slivers) except: print >> sys.stderr, "FAILED: %s" % nodes sys.exit(1) -print >>outfile, rspec.toxml() +print >>outfile, rspec.toxml(cleanup=True) sys.exit(0) diff --git a/sfa/plc/aggregate.py b/sfa/plc/aggregate.py index 7f4fcb25..d7c03a0b 100644 --- a/sfa/plc/aggregate.py +++ b/sfa/plc/aggregate.py @@ -91,7 +91,6 @@ class Aggregate: if slice_xrn: # If slicename is specified then resulting rspec is a manifest. # Add sliver details to rspec and remove 'advertisement' elements - rspec.remove_element('available') slice_hrn, _ = urn_to_hrn(slice_xrn) slice_name = hrn_to_pl_slicename(slice_hrn) slices = self.api.plshell.GetSlices(self.api.plauth, slice_name) @@ -114,4 +113,4 @@ class Aggregate: sliver.tags.append(tag) rspec.add_slivers(slivers, sliver_urn=slice_xrn) - return rspec.toxml() + return rspec.toxml(cleanup=True) diff --git a/sfa/rspecs/pg_rspec.py b/sfa/rspecs/pg_rspec.py index 9f35d30e..2fd8b766 100755 --- a/sfa/rspecs/pg_rspec.py +++ b/sfa/rspecs/pg_rspec.py @@ -63,11 +63,6 @@ class PGRSpec(RSpec): if self.type: self.xml.set('type', self.type) - def remove_element(self, element_name, root_node=None): - if not element_name.startswith('rspecv2:'): - element_name = 'rspecv2:' + element_name - RSpec.remove_element(self, element_name, root_node) - def get_network(self): network = None nodes = self.xml.xpath('//rspecv2:node[@component_manager_uuid][1]', namespaces=self.namespaces) @@ -80,11 +75,12 @@ class PGRSpec(RSpec): return set(networks) def get_node_elements(self): - nodes = self.xml.xpath('//rspecv2:node', namespaces=self.namespaces) + nodes = self.xml.xpath('//rspecv2:node | //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) + xpath = '//rspecv2:node[@component_name]/@component_name | //node[@component_name]/@component_name' + return self.xml.xpath(xpath, namespaces=self.namespaces) def get_nodes_with_slivers(self, network=None): if network: @@ -160,7 +156,24 @@ class PGRSpec(RSpec): for child in root.getchildren(): self.xml.append(child) - + def cleanup(self): + # remove unncecessary elements, attributes + if self.type in ['request', 'manifest']: + # remove nodes without slivers + nodes = self.get_node_elements() + for node in nodes: + delete = True + hostname = node.get('component_name') + parent = node.getparent() + children = node.getchildren() + for child in children: + if child.tag.endswith('sliver_type'): + delete = False + if delete: + parent.remove(node) + + # remove 'available' element from remaining node elements + self.remove_element('//rspecv2:available | //available') if __name__ == '__main__': rspec = PGRSpec() diff --git a/sfa/rspecs/rspec.py b/sfa/rspecs/rspec.py index 48f79b39..ad2075b0 100755 --- a/sfa/rspecs/rspec.py +++ b/sfa/rspecs/rspec.py @@ -100,7 +100,10 @@ class RSpec: if not root_node: root_node = self.xml - elements = root_node.xpath('//%s ' % element_name, namespaces=self.namespaces) + if not element_name.startswith('//'): + element_name = '//' + element_name + + elements = root_node.xpath('%s ' % element_name, namespaces=self.namespaces) for element in elements: parent = element.getparent() parent.remove(element) @@ -123,10 +126,18 @@ class RSpec: return True + def cleanup(self): + """ + Optional method which inheriting classes can choose to implent. + """ + pass + def __str__(self): return self.toxml() - def toxml(self): + def toxml(self, cleanup=False): + if cleanup: + self.cleanup() return self.header + etree.tostring(self.xml, pretty_print=True) def save(self, filename): -- 2.43.0