+# $Id$
+# $URL$
from PLC.Faults import *
from PLC.Method import Method
from PLC.Parameter import Parameter, Mixed
from PLC.ConfFiles import ConfFile, ConfFiles
from PLC.NodeGroups import NodeGroup, NodeGroups
-from PLC.Auth import PasswordAuth
+from PLC.Auth import Auth
class AddConfFileToNodeGroup(Method):
"""
roles = ['admin']
accepts = [
- PasswordAuth(),
+ Auth(),
ConfFile.fields['conf_file_id'],
Mixed(NodeGroup.fields['nodegroup_id'],
- NodeGroup.fields['name'])
+ NodeGroup.fields['groupname'])
]
returns = Parameter(int, '1 if successful')
- event_type = 'AddTo'
- object_type = 'ConfFile'
- object_ids = []
def call(self, auth, conf_file_id, nodegroup_id_or_name):
- # Get configuration file
+ # Get configuration file
conf_files = ConfFiles(self.api, [conf_file_id])
if not conf_files:
raise PLCInvalidArgument, "No such configuration file"
- conf_file = conf_files.values()[0]
+ conf_file = conf_files[0]
# Get node
- nodegroups = NodeGroups(self.api, [nodegroup_id_or_name])
- if not nodegroups:
+ nodegroups = NodeGroups(self.api, [nodegroup_id_or_name])
+ if not nodegroups:
raise PLCInvalidArgument, "No such node group"
- nodegroup = nodegroups.values()[0]
-
- # Link configuration file to node
+ nodegroup = nodegroups[0]
+
+ # Link configuration file to node
if nodegroup['nodegroup_id'] not in conf_file['nodegroup_ids']:
conf_file.add_nodegroup(nodegroup)
# Log affected objects
- self.object_ids = [conf_file_id, nodegroup['nodegroup_id']]
+ self.event_objects = {'ConfFile': [conf_file_id],
+ 'NodeGroup': [nodegroup['nodegroup_id']] }
return 1