X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddNodeGroup.py;h=bdde7fe54e8e7bd616152f301b1f47f456ebf0b8;hb=fa0ae3939a782624e7289aadd3e192c01f1c3842;hp=fe16b8111bfa5aa038c8ce39062e696c74aee3a5;hpb=2d9b3a88df1d606e2517fa2e1e1bc421d7b370ec;p=plcapi.git diff --git a/PLC/Methods/AddNodeGroup.py b/PLC/Methods/AddNodeGroup.py index fe16b81..bdde7fe 100644 --- a/PLC/Methods/AddNodeGroup.py +++ b/PLC/Methods/AddNodeGroup.py @@ -2,10 +2,10 @@ from PLC.Faults import * from PLC.Method import Method from PLC.Parameter import Parameter, Mixed from PLC.NodeGroups import NodeGroup, NodeGroups -from PLC.Auth import PasswordAuth +from PLC.Auth import Auth can_update = lambda (field, value): field in \ - ['description'] + ['name', 'description'] class AddNodeGroup(Method): """ @@ -17,20 +17,23 @@ class AddNodeGroup(Method): roles = ['admin'] - update_fields = dict(filter(can_update, NodeGroup.fields.items())) + nodegroup_fields = dict(filter(can_update, NodeGroup.fields.items())) accepts = [ - PasswordAuth(), - NodeGroup.fields['name'], - update_fields + Auth(), + nodegroup_fields ] returns = Parameter(int, 'New nodegroup_id (> 0) if successful') - def call(self, auth, name, nodegroup_fields = {}): + + def call(self, auth, nodegroup_fields): nodegroup_fields = dict(filter(can_update, nodegroup_fields.items())) nodegroup = NodeGroup(self.api, nodegroup_fields) - nodegroup['name'] = name nodegroup.sync() + # Logging variables + self.object_ids = [nodegroup['nodegroup_id']] + self.message = 'Node group %d created' % nodegroup['nodegroup_id'] + return nodegroup['nodegroup_id']