X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fmethods%2FDescribe.py;h=69d4fb7b4f1e2836f8c503cf199fa89ccdfedcd7;hb=796d35d54ab31e209ddf76b4584b6508b309c6c1;hp=7a03085c32a418afba0987d9be89b4fd6731c4b1;hpb=db5e2034e15c72434fdf67ee40d32b980f971705;p=sfa.git diff --git a/sfa/methods/Describe.py b/sfa/methods/Describe.py index 7a03085c..69d4fb7b 100644 --- a/sfa/methods/Describe.py +++ b/sfa/methods/Describe.py @@ -20,13 +20,14 @@ class Describe(Method): """ interfaces = ['aggregate', 'slicemgr'] accepts = [ + Parameter(type([str]), "List of URNs"), Mixed(Parameter(str, "Credential string"), Parameter(type([str]), "List of credentials")), Parameter(dict, "Options") ] returns = Parameter(str, "List of resources") - def call(self, creds, options): + def call(self, urns, creds, options): self.api.logger.info("interface: %s\tmethod-name: %s" % (self.api.interface, self.name)) # client must specify a version @@ -35,15 +36,16 @@ class Describe(Method): options['geni_rspec_version'] = options['rspec_version'] else: raise SfaInvalidArgument('Must specify an rspec version option. geni_rspec_version cannot be null') - - # Find the valid credentials - valid_creds = self.api.auth.checkCredentials(creds, 'listnodes') + valid_creds = self.api.auth.checkCredentialsSpeaksFor( + creds, 'listnodes', urns, + check_sliver_callback = self.api.driver.check_sliver_credentials, + options=options) # get hrn of the original caller origin_hrn = options.get('origin_hrn', None) if not origin_hrn: - origin_hrn = Credential(string=valid_creds[0]).get_gid_caller().get_hrn() - rspec = self.api.manager.ListResources(self.api, creds, options) + origin_hrn = Credential(cred=valid_creds[0]).get_gid_caller().get_hrn() + desc = self.api.manager.Describe(self.api, creds, urns, options) # filter rspec through sfatables if self.api.interface in ['aggregate']: @@ -51,11 +53,11 @@ class Describe(Method): elif self.api.interface in ['slicemgr']: chain_name = 'FORWARD-OUTGOING' self.api.logger.debug("ListResources: sfatables on chain %s"%chain_name) - filtered_rspec = run_sfatables(chain_name, '', origin_hrn, rspec) + desc['geni_rspec'] = run_sfatables(chain_name, '', origin_hrn, desc['geni_rspec']) - if options.has_key('geni_compressed') and options['geni_compressed'] == True: - filtered_rspec = zlib.compress(filtered_rspec).encode('base64') + if 'geni_compressed' in options and options['geni_compressed'] == True: + desc['geni_rspec'] = zlib.compress(desc['geni_rspec']).encode('base64') - return filtered_rspec + return desc