git://git.onelab.eu
/
plcapi.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
- log object_type
[plcapi.git]
/
PLC
/
Methods
/
DeleteSlice.py
diff --git
a/PLC/Methods/DeleteSlice.py
b/PLC/Methods/DeleteSlice.py
index
c5b511e
..
bfb6cd6
100644
(file)
--- a/
PLC/Methods/DeleteSlice.py
+++ b/
PLC/Methods/DeleteSlice.py
@@
-2,15
+2,15
@@
from PLC.Faults import *
from PLC.Method import Method
from PLC.Parameter import Parameter, Mixed
from PLC.Slices import Slice, Slices
from PLC.Method import Method
from PLC.Parameter import Parameter, Mixed
from PLC.Slices import Slice, Slices
-from PLC.Auth import
Password
Auth
+from PLC.Auth import Auth
class DeleteSlice(Method):
"""
Deletes the specified slice.
Users may only delete slices of which they are members. PIs may
class DeleteSlice(Method):
"""
Deletes the specified slice.
Users may only delete slices of which they are members. PIs may
- delete any of the slices at their sites
. Admins may delete any
- slice.
+ delete any of the slices at their sites
, or any slices of which
+
they are members. Admins may delete any
slice.
Returns 1 if successful, faults otherwise.
"""
Returns 1 if successful, faults otherwise.
"""
@@
-18,19
+18,23
@@
class DeleteSlice(Method):
roles = ['admin', 'pi', 'user']
accepts = [
roles = ['admin', 'pi', 'user']
accepts = [
-
Password
Auth(),
+ Auth(),
Mixed(Slice.fields['slice_id'],
Slice.fields['name']),
]
returns = Parameter(int, '1 if successful')
Mixed(Slice.fields['slice_id'],
Slice.fields['name']),
]
returns = Parameter(int, '1 if successful')
+
def call(self, auth, slice_id_or_name):
def call(self, auth, slice_id_or_name):
- slices = Slices(self.api, [slice_id_or_name])
.values()
+ slices = Slices(self.api, [slice_id_or_name])
if not slices:
raise PLCInvalidArgument, "No such slice"
slice = slices[0]
if not slices:
raise PLCInvalidArgument, "No such slice"
slice = slices[0]
+ if slice['peer_id'] is not None:
+ raise PLCInvalidArgument, "Not a local slice"
+
if 'admin' not in self.caller['roles']:
if self.caller['person_id'] in slice['person_ids']:
pass
if 'admin' not in self.caller['roles']:
if self.caller['person_id'] in slice['person_ids']:
pass
@@
-40,5
+44,6
@@
class DeleteSlice(Method):
raise PLCPermissionDenied, "Specified slice not associated with any of your sites"
slice.delete()
raise PLCPermissionDenied, "Specified slice not associated with any of your sites"
slice.delete()
+ self.object_ids = [slice['slice_id']]
return 1
return 1