X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FDeleteNodeFromPCU.py;h=5a3068488e641cc7e3de7dc8c505b3e92db8296a;hb=dd73bbbd06bbd35f5f2c9b45421bee889b70bc48;hp=9e2afec33595e9012e3c6bd3dba071ba5727afe1;hpb=1ca86d7edb5cb3aea58f636dd8fba7747476f300;p=plcapi.git diff --git a/PLC/Methods/DeleteNodeFromPCU.py b/PLC/Methods/DeleteNodeFromPCU.py index 9e2afec..5a30684 100644 --- a/PLC/Methods/DeleteNodeFromPCU.py +++ b/PLC/Methods/DeleteNodeFromPCU.py @@ -1,9 +1,11 @@ +# $Id$ from PLC.Faults import * from PLC.Method import Method from PLC.Parameter import Parameter, Mixed from PLC.Nodes import Node, Nodes from PLC.PCUs import PCU, PCUs -from PLC.Auth import PasswordAuth +from PLC.Sites import Site, Sites +from PLC.Auth import Auth class DeleteNodeFromPCU(Method): """ @@ -17,7 +19,7 @@ class DeleteNodeFromPCU(Method): roles = ['admin', 'pi', 'tech'] accepts = [ - PasswordAuth(), + Auth(), Mixed(Node.fields['node_id'], Node.fields['hostname']), PCU.fields['pcu_id'] @@ -31,18 +33,18 @@ class DeleteNodeFromPCU(Method): if not nodes: raise PLCInvalidArgument, "No such node" - node = nodes.values()[0] + node = nodes[0] # Get PCU pcus = PCUs(self.api, [pcu_id]) if not pcus: raise PLCInvalidArgument, "No such PCU" - pcu = pcus.values()[0] + pcu = pcus[0] if 'admin' not in self.caller['roles']: ok = False - sites = Sites(self.api, self.caller['site_ids']).values() + sites = Sites(self.api, self.caller['site_ids']) for site in sites: if pcu['pcu_id'] in site['pcu_ids']: ok = True @@ -51,7 +53,14 @@ class DeleteNodeFromPCU(Method): raise PLCPermissionDenied, "Not allowed to update that PCU" # Removed node from PCU + if node['node_id'] in pcu['node_ids']: pcu.remove_node(node) - return 1 + # Logging variables + self.event_objects = {'PCU': [pcu['pcu_id']], + 'Node': [node['node_id']]} + self.message = 'Node %d removed from PCU %d' % \ + (node['node_id'], pcu['pcu_id']) + + return 1