- def call(self, auth, nodegroup_id, name, description):
- #if filter(lambda field: field not in self.update_fields, optional_vals):
- # raise PLCInvalidArgument, "Invalid fields specified"
-
- # Authenticated function
- assert self.caller is not None
-
- # make sure we are 'admin'
- if 'admin' not in self.caller['roles']:
- raise PLCPermissionDenied, "Not allowed to update node groups"
-
- # Get nodegroup information
- nodegroups = NodeGroups(self.api, [nodegroup_id])
- if not nodegroups:
- raise PLCInvalidArgument, "No such nodegroup"
-
- nodegroup = nodegroups.values()[0]
-
- # Modify node group
- update_fields = {
- 'name': name,
- 'description': description
- }
-
- nodegroup.update(update_fields)
- nodegroup.flush()
-
- return 1
+ def call(self, auth, nodegroup_id_or_name, name, description):
+ return UpdateNodeGroup.call(self, auth, nodegroup_id_or_name,
+ {'name': name, 'description': description})