X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fmethods%2FCreateSliver.py;h=96b535dbccd209861952650612121b4322eb30d6;hb=4ff67c801ceeb1d0c7ca2863c2b7bf8152182b8f;hp=e8f9b94ffad659d8df967f91df751e2bfa6ea93f;hpb=d9ab2d5930e31e1e5edb979bf96e66744934314b;p=sfa.git diff --git a/sfa/methods/CreateSliver.py b/sfa/methods/CreateSliver.py index e8f9b94f..96b535db 100644 --- a/sfa/methods/CreateSliver.py +++ b/sfa/methods/CreateSliver.py @@ -1,11 +1,9 @@ from sfa.util.faults import * -from sfa.util.namespace import * +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.util.sfalogging import logger class CreateSliver(Method): """ @@ -25,11 +23,12 @@ class CreateSliver(Method): Mixed(Parameter(str, "Credential string"), Parameter(type([str]), "List of credentials")), Parameter(str, "RSpec"), - Parameter(type([]), "List of user information") + Parameter(type([]), "List of user information"), + Parameter(str, "call_id"), ] returns = Parameter(str, "Allocated RSpec") - def call(self, slice_xrn, creds, rspec, users): + def call(self, slice_xrn, creds, rspec, users, call_id=""): 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)) @@ -42,11 +41,13 @@ class CreateSliver(Method): # flter rspec through sfatables if self.api.interface in ['aggregate']: - chain_name = 'OUTGOING' + chain_name = 'INCOMING' elif self.api.interface in ['slicemgr']: - chain_name = 'FORWARD-OUTGOING' + chain_name = 'FORWARD-INCOMING' + self.api.logger.debug("CreateSliver: sfatables on chain %s"%chain_name) rspec = run_sfatables(chain_name, hrn, origin_hrn, rspec) - allocated = manager.create_slice(self.api, slice_xrn, valid_creds, rspec, users) - - return rspec - + # the aggregate's CreateSliver returns false if call_id was already handled + if manager.CreateSliver(self.api, slice_xrn, creds, rspec, users, call_id): + return rspec + else: + return ""