from sfa.trust.auth import Auth
from sfa.trust.credential import Credential
-from sfa.plc.slices import Slices
-
class delete_slice(Method):
"""
Remove the slice from all nodes.
client_gid_str = client_gid.save_to_string(save_parents=True)
self.api.auth.authenticateGid(client_gid_str, [cred, hrn], request_hash)
self.api.auth.check(cred, 'deleteslice')
- slices = Slices(self.api, caller_cred=caller_cred)
- slices.delete_slice(hrn)
+
+
+ # send the call to the right manager
+ manager_base = 'sfa.managers'
+ if self.api.interface in ['component']:
+ mgr_type = self.api.config.SFA_CM_TYPE
+ manager_module = manager_base + ".component_manager_%s" % mgr_type
+ manager = __import__(manager_module, fromlist=[manager_base])
+ manager.delete_slice(self.api, hrn)
+ elif self.api.interface in ['aggregate']:
+ mgr_type = self.api.config.SFA_AGGREGATE_TYPE
+ manager_module = manager_base + ".aggregate_manager_%s" % mgr_type
+ manager = __import__(manager_module, fromlist=[manager_base])
+ manager.delete_slice(self.api, hrn)
+ elif self.api.interface in ['slicemgr']:
+ mgr_type = self.api.config.SFA_SM_TYPE
+ manager_module = manager_base + ".slice_manager_%s" % mgr_type
+ manager = __import__(manager_module, fromlist=[manager_base])
+ manager.delete_slice(self.api, hrn, caller_cred)
+
return 1