X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fmethods%2FShutdown.py;h=f8e32942bbd1ba5f59f4a40d580e26a8600a6849;hb=4d17883d9210a0bee2572d7c237e2e40d1e66b5c;hp=cd36532dc2260162c21b7e30666e1cc908609c06;hpb=952322d76247f8991f3c2688ed7e1f5a22ca4572;p=sfa.git diff --git a/sfa/methods/Shutdown.py b/sfa/methods/Shutdown.py index cd36532d..f8e32942 100644 --- a/sfa/methods/Shutdown.py +++ b/sfa/methods/Shutdown.py @@ -2,9 +2,9 @@ from sfa.util.faults import * from sfa.util.namespace import * from sfa.util.method import Method from sfa.util.parameter import Parameter +from sfa.methods.Stop import Stop - -class Shutdown(Method): +class Shutdown(Stop): """ Perform an emergency shut down of a sliver. This operation is intended for administrative use. The sliver is shut down but remains available for further forensics. @@ -12,7 +12,7 @@ class Shutdown(Method): @param slice_urn (string) URN of slice to renew @param credentials ([string]) of credentials """ - interfaces = ['geni_am'] + interfaces = ['aggregate', 'slicemgr'] accepts = [ Parameter(str, "Slice URN"), Parameter(type([str]), "List of credentials"), @@ -20,20 +20,6 @@ class Shutdown(Method): returns = Parameter(bool, "Success or Failure") def call(self, slice_xrn, creds): - hrn, type = urn_to_hrn(slice_xrn) - - self.api.logger.info("interface: %s\ttarget-hrn: %s\tcaller-creds: %s\tmethod-name: %s"%(self.api.interface, hrn, creds, self.name)) - - # Find the valid credentials - ValidCreds = self.api.auth.checkCredentials(creds, 'shutdown', hrn) - - manager_base = 'sfa.managers' - - if self.api.interface in ['geni_am']: - mgr_type = self.api.config.SFA_GENI_AGGREGATE_TYPE - manager_module = manager_base + ".geni_am_%s" % mgr_type - manager = __import__(manager_module, fromlist=[manager_base]) - return manager.Shutdown(self.api, slice_xrn, ValidCreds) - return '' + return Stop.call(self, slice_xrn, creds)