X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddSliceToNodes.py;h=a7124d881798937bde40dac07eeedb99e63bd706;hb=9ad1311ca10e1d8010a6494a2cde43ffcd3aa8e7;hp=3b194b41e86d084896586fa89d089820a2af1299;hpb=0a42d0abbc2b448a84477481b06bff52b24f7130;p=plcapi.git diff --git a/PLC/Methods/AddSliceToNodes.py b/PLC/Methods/AddSliceToNodes.py index 3b194b4..a7124d8 100644 --- a/PLC/Methods/AddSliceToNodes.py +++ b/PLC/Methods/AddSliceToNodes.py @@ -3,12 +3,17 @@ 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.Persons import Person, Persons from PLC.Auth import Auth +from PLC.Plugins import PluginManager 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. """ @@ -19,26 +24,21 @@ class AddSliceToNodes(Method): Auth(), Mixed(Slice.fields['slice_id'], Slice.fields['name']), - [Mixed(Node.fields['node_id'], + [Mixed(Node.fields['node_id'], Node.fields['hostname'])] ] returns = Parameter(int, '1 if successful') - event_type = 'AddTo' - object_type = 'Node' - object_ids = [] - 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.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']: @@ -47,14 +47,29 @@ 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, commit = False) slice.sync() - self.object_ids = [node['node_id'] for node in nodes] + 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) + + PluginManager(self.api, auth).notify("slice.AddToNodes", self.event_objects) return 1