X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fmethods%2FCreateSliver.py;h=b28d1a536bf95969d018966515100fff72839bfc;hb=02a4a59a4a49183ec8c631cc03243b97f4602d50;hp=bb0051a9ce2417df28071cb91fd0ff94f75e69ce;hpb=ec5c590f9bd45a7bf3a23ce06533b8542eeeb786;p=sfa.git diff --git a/sfa/methods/CreateSliver.py b/sfa/methods/CreateSliver.py index bb0051a9..b28d1a53 100644 --- a/sfa/methods/CreateSliver.py +++ b/sfa/methods/CreateSliver.py @@ -1,9 +1,10 @@ -from sfa.util.faults import SfaInvalidArgument +from sfa.util.faults import SfaInvalidArgument, InvalidRSpec from sfa.util.xrn import urn_to_hrn from sfa.util.method import Method -from sfa.util.parameter import Parameter, Mixed from sfa.util.sfatablesRuntime import run_sfatables +import sys from sfa.trust.credential import Credential +from sfa.storage.parameter import Parameter, Mixed from sfa.rspecs.rspec import RSpec class CreateSliver(Method): @@ -25,15 +26,15 @@ class CreateSliver(Method): Parameter(type([str]), "List of credentials")), Parameter(str, "RSpec"), Parameter(type([]), "List of user information"), - Parameter(str, "call_id"), + Parameter(dict, "options"), ] returns = Parameter(str, "Allocated RSpec") - def call(self, slice_xrn, creds, rspec, users, call_id=""): + def call(self, slice_xrn, creds, rspec, users, options): hrn, type = urn_to_hrn(slice_xrn) self.api.logger.info("interface: %s\ttarget-hrn: %s\tmethod-name: %s"%(self.api.interface, hrn, self.name)) - + print >>sys.stderr, " \r\n \r\n Createsliver.py call %s\ttarget-hrn: %s\tmethod-name: %s "%(self.api.interface, hrn, self.name) # Find the valid credentials valid_creds = self.api.auth.checkCredentials(creds, 'createsliver', hrn) origin_hrn = Credential(string=valid_creds[0]).get_gid_caller().get_hrn() @@ -43,8 +44,6 @@ class CreateSliver(Method): msg = "'users' musst be specified and cannot be null. You may need to update your client." raise SfaInvalidArgument(name='users', extra=msg) - manager = self.api.get_interface_manager() - # flter rspec through sfatables if self.api.interface in ['aggregate']: chain_name = 'INCOMING' @@ -53,8 +52,7 @@ class CreateSliver(Method): self.api.logger.debug("CreateSliver: sfatables on chain %s"%chain_name) rspec = run_sfatables(chain_name, hrn, origin_hrn, rspec) slivers = RSpec(rspec).version.get_nodes_with_slivers() - if slivers: - result = manager.CreateSliver(self.api, slice_xrn, creds, rspec, users, call_id) - else: - result = rspec + if not slivers: + raise InvalidRSpec("Missing or element. Request rspec must explicitly allocate slivers") + result = self.api.manager.CreateSliver(self.api, slice_xrn, creds, rspec, users, options) return result