from sfa.util.config import Config
# RSpecManager_pl is not used. This is just to resolve issues with the dynamic __import__ that comes later.
import sfa.rspecs.aggregates.rspec_manager_pl
+from sfa.trust.credential import Credential
class create_slice(Method):
returns = Parameter(int, "1 if successful")
- def call(self, cred, hrn, rspec):
+ def call(self, cred, hrn, rspec, caller_cred=None):
+ if caller_cred==None:
+ caller_cred=cred
+ #log the call
+ self.api.logger.info("interface: %s\tcaller-hrn: %s\ttarget-hrn: %s\tmethod-name: %s"%(self.api.interface, Credential(string=caller_cred).get_gid_caller().get_hrn(), hrn, self.name))
+
sfa_aggregate_type = Config().get_aggregate_rspec_type()
self.api.auth.check(cred, 'createslice')
if (sfa_aggregate_type == 'pl'):
- slices = Slices(self.api)
+ slices = Slices(self.api, caller_cred=caller_cred)
slices.create_slice(hrn, rspec)
else:
# To clean up after July 21 - SB
from sfa.util.method import Method
from sfa.util.parameter import Parameter, Mixed
from sfa.trust.auth import Auth
+from sfa.trust.credential import Credential
from sfa.plc.slices import Slices
returns = Parameter(int, "1 if successful")
- def call(self, cred, hrn):
+ def call(self, cred, hrn, caller_cred=None):
+ if caller_cred==None:
+ caller_cred=cred
+ #log the call
+ self.api.logger.info("interface: %s\tcaller-hrn: %s\ttarget-hrn: %s\tmethod-name: %s"%(self.api.interface, Credential(string=caller_cred).get_gid_caller().get_hrn(), hrn, self.name))
+
self.api.auth.check(cred, 'deleteslice')
- slices = Slices(self.api)
+ slices = Slices(self.api, caller_cred=caller_cred)
slices.delete_slice(hrn)
return 1
from sfa.plc.nodes import Nodes
# RSpecManager_pl is not used. This is just to resolve issues with the dynamic __import__ that comes later.
import sfa.rspecs.aggregates.rspec_manager_pl
+from sfa.trust.credential import Credential
class get_resources(Method):
"""
returns = Parameter(str, "String representatin of an rspec")
- def call(self, cred, hrn=None):
+ def call(self, cred, hrn=None, caller_cred=None):
sfa_aggregate_type = Config().get_aggregate_rspec_type()
self.api.auth.check(cred, 'listnodes')
+ if caller_cred==None:
+ caller_cred=cred
+
+ #log the call
+ self.api.logger.info("interface: %s\tcaller-hrn: %s\ttarget-hrn: %s\tmethod-name: %s"%(self.api.interface, Credential(string=caller_cred).get_gid_caller().get_hrn(), hrn, self.name))
+
if (sfa_aggregate_type == 'pl'):
- nodes = Nodes(self.api)
+ nodes = Nodes(self.api, caller_cred=caller_cred)
if hrn:
rspec = nodes.get_rspec(hrn)
else:
from sfa.util.record import GeniRecord
from sfa.server.registry import Registries
from sfa.util.prefixTree import prefixTree
+from sfa.trust.credential import Credential
class list(Method):
"""
@param hrn human readable name of authority to list
@return list of record dictionaries
"""
-
interfaces = ['registry']
accepts = [
returns = [GeniRecord]
- def call(self, cred, hrn):
-
+ def call(self, cred, hrn, caller_cred=None):
+
self.api.auth.check(cred, 'list')
+ if caller_cred==None:
+ caller_cred=cred
+
+ #log the call
+ self.api.logger.info("interface: %s\tcaller-hrn: %s\ttarget-hrn: %s\tmethod-name: %s"%(self.api.interface, Credential(string=caller_cred).get_gid_caller().get_hrn(), hrn, self.name))
records = []
# load all know registry names into a prefix tree and attempt to find
# if the best match (longest matching hrn) is not the local registry,
# forward the request
if registry_hrn != self.api.hrn:
- credential = self.api.getCredential()
+ credential = self.api.getCredential()
try:
- record_list = registries[registry_hrn].list(credential, hrn)
+ record_list = registries[registry_hrn].list(credential, hrn, caller_cred=caller_cred)
records = [record.as_dict() for record in record_list]
if records:
return records