X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddSliceToNodes.py;h=c57cfb2edb75e60518d818e559a57caccbc959d7;hb=fa0ae3939a782624e7289aadd3e192c01f1c3842;hp=f2b042f56d9d5eed218879528d019e6461241735;hpb=3ab53c5221664528325a0edc7ca40c57eb783428;p=plcapi.git diff --git a/PLC/Methods/AddSliceToNodes.py b/PLC/Methods/AddSliceToNodes.py index f2b042f..c57cfb2 100644 --- a/PLC/Methods/AddSliceToNodes.py +++ b/PLC/Methods/AddSliceToNodes.py @@ -7,11 +7,11 @@ from PLC.Auth import Auth class AddSliceToNodes(Method): """ - Adds the specified slice to the specified nodes. - Nodes can be either local or foreign nodes, as returned by GetNodes + Adds the specified slice to the specified nodes. Nodes may be + either local or foreign nodes. - If the slice is - already associated with a node, no errors are returned. + If the slice is already associated with a node, no errors are + returned. Returns 1 if successful, faults otherwise. """ @@ -28,28 +28,28 @@ class AddSliceToNodes(Method): returns = Parameter(int, '1 if successful') + object_type = 'Node' + def call(self, auth, slice_id_or_name, node_id_or_hostname_list): # Get slice information slices = Slices(self.api, [slice_id_or_name]) if not slices: raise PLCInvalidArgument, "No such slice" - slice = slices[0] - PLCCheckLocalSlice(slice,"AddSliceToNodes") + + 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 - # Thierry : I cannot figure out how this works - # how is having pi role related to being in a slice ? elif 'pi' not in self.caller['roles']: raise PLCPermissionDenied, "Not a member of the specified slice" elif slice['site_id'] not in self.caller['site_ids']: raise PLCPermissionDenied, "Specified slice not associated with any of your sites" - # Get specified nodes, add them to the slice - + # Get specified nodes, add them to the slice nodes = Nodes(self.api, node_id_or_hostname_list) for node in nodes: if slice['slice_id'] not in node['slice_ids']: