X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddSliceToNodes.py;h=db074caf4c6c797b765ea9246f4ab28ded8f5612;hb=475ee53aaaa011ba14a34af34d3340257d6f9d59;hp=7e0a5d90f389371d1a88629c3d3f200fec712981;hpb=f8f4a4d9f9a50e95f195edf8be9bb8e03a455b3c;p=plcapi.git diff --git a/PLC/Methods/AddSliceToNodes.py b/PLC/Methods/AddSliceToNodes.py index 7e0a5d9..db074ca 100644 --- a/PLC/Methods/AddSliceToNodes.py +++ b/PLC/Methods/AddSliceToNodes.py @@ -3,12 +3,16 @@ from PLC.Method import Method from PLC.Parameter import Parameter, Mixed from PLC.Nodes import Node, Nodes from PLC.Slices import Slice, Slices -from PLC.Auth import PasswordAuth +from PLC.Persons import Person, Persons +from PLC.Auth import Auth class AddSliceToNodes(Method): """ - Adds the specified slice to the specified nodes. If the slice is - already associated with a node, no errors are returned. + 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. Returns 1 if successful, faults otherwise. """ @@ -16,10 +20,10 @@ class AddSliceToNodes(Method): roles = ['admin', 'pi', 'user'] accepts = [ - PasswordAuth(), + Auth(), Mixed(Slice.fields['slice_id'], Slice.fields['name']), - [Mixed(Node.fields['node_id'], + [Mixed(Node.fields['node_id'], Node.fields['hostname'])] ] @@ -29,12 +33,11 @@ class AddSliceToNodes(Method): # Get slice information slices = Slices(self.api, [slice_id_or_name]) if not slices: - raise PLCInvalidArgument, "No such slice" - - slice = slices.values()[0] + raise PLCInvalidArgument, "No such slice %r"%slice_id_or_name + slice = slices[0] - # Get specified nodes - nodes = Nodes(self.api, node_id_or_hostname_list).values() + 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']: @@ -43,10 +46,27 @@ class AddSliceToNodes(Method): 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" - - # Add slice to all nodes found - for node in nodes: + + # Get specified nodes, add them to the slice + nodes = Nodes(self.api, node_id_or_hostname_list, + ['node_id', 'hostname', 'slice_ids', 'slice_ids_whitelist', 'site_id']) + + for node in nodes: + # check the slice whitelist on each node first + # allow users at site to add node to slice, ignoring whitelist + if node['slice_ids_whitelist'] and \ + slice['slice_id'] not in node['slice_ids_whitelist'] and \ + not set(self.caller['site_ids']).intersection([node['site_id']]): + raise PLCInvalidArgument, "%s is not allowed on %s (not on the whitelist)" % \ + (slice['name'], node['hostname']) if slice['slice_id'] not in node['slice_ids']: - slice.add_node(node) + slice.add_node(node, commit = False) + + slice.sync() + + nodeids = [node['node_id'] for node in nodes] + self.event_objects = {'Node': nodeids, + 'Slice': [slice['slice_id']]} + self.message = 'Slice %d added to nodes %s' % (slice['slice_id'], nodeids) return 1