'error_cmd': Parameter(str, "Shell command to execute if any error occurs", max = 1024, nullok = True),
'ignore_cmd_errors': Parameter(bool, "Install file anyway even if an error occurs"),
'always_update': Parameter(bool, "Always attempt to install file even if unchanged"),
- 'node_ids': Parameter(int, "List of nodes linked to this file"),
+ 'site_id': Parameter(int, "Identifier of the site to which this conf file belongs"),
+ 'creator_id': Parameter(int, "Identifer of the person who created this conf file"),
+ 'last_modified_by_id': Parameter(int, "Identifier of the person who last updated this conf file"),
+ 'date_created': Parameter(int, "Date and time when this conf file was created", ro = True),
+ 'last_modified': Parameter(int, "Date and time when this conf file was last modified", ro = True),
+ 'node_ids': Parameter(int, "List of nodes linked to this file"),
'nodegroup_ids': Parameter(int, "List of node groups linked to this file"),
}
self['nodegroup_ids'].remove(nodegroup_id)
nodegroup['conf_file_ids'].remove(conf_file_id)
+ def update_last_modified():
+ """
+ Update last_updated field with current time
+ """
+
+ assert 'conf_file_id' in self
+ assert self.table_name
+
+ self.api.db.do("UPDATE %s SET last_modified = CURRENT_TIMESTAMP " % (self.table_name) + \
+ " where conf_file_id = %d" % (self['conf_file_id']) )
+ self.sync(commit)
+
+ validate_date_created = Row.validate_timestamp
+ validate_last_updated = Row.validate_timestamp
+
class ConfFiles(Table):
"""
Representation of the conf_files table in the database.
from PLC.Auth import Auth
can_update = lambda (field, value): field not in \
- ['conf_file_id', 'node_ids', 'nodegroup_ids']
+ ['conf_file_id', 'node_ids', 'nodegroup_ids', 'creator_id', 'last_modified_by_id']
class AddConfFile(Method):
"""
Returns the new conf_file_id (> 0) if successful, faults otherwise.
"""
- roles = ['admin']
+ roles = ['admin', 'pi', 'user']
conf_file_fields = dict(filter(can_update, ConfFile.fields.items()))
def call(self, auth, conf_file_fields):
conf_file_fields = dict(filter(can_update, conf_file_fields.items()))
conf_file = ConfFile(self.api, conf_file_fields)
+ conf_file['creator_id'] = self.caller['person_id']
+ conf_file['last_modified_by_id'] = self.caller['person_id']
+ if 'site_id' not in conf_file_fields:
+ conf_file['site_id'] = self.caller['site_ids'][0]
conf_file.sync()
self.event_objects = {'ConfFile': [conf_file['conf_file_id']]}
from PLC.Auth import Auth
can_update = lambda (field, value): field not in \
- ['conf_file_id', 'node_ids', 'nodegroup_ids']
+ ['conf_file_id', 'node_ids', 'nodegroup_ids', 'creator_id', 'last_modified_by_id']
class UpdateConfFile(Method):
"""
Returns 1 if successful, faults otherwise.
"""
- roles = ['admin']
+ roles = ['admin', 'pi', 'user']
conf_file_fields = dict(filter(can_update, ConfFile.fields.items()))
conf_file_fields = dict(filter(can_update, conf_file_fields.items()))
conf_files = ConfFiles(self.api, [conf_file_id])
+
if not conf_files:
raise PLCInvalidArgument, "No such configuration file"
-
- conf_file = conf_files[0]
- conf_file.update(conf_file_fields)
+
+ conf_file = conf_files[0]
+
+ if 'admin' not in self.caller['roles']:
+ if conf_file['site_id'] not in self.caller['site_ids']:
+ raise PLCPermissionDenied, "Not allowed to update that conf file"
+
+ conf_file.update(conf_file_fields)
+ conf_file['last_modified_by_id'] = self.caller['person_id']
+ conf_file.update_last_modified(commit = False)
conf_file.sync()
self.event_objects = {'ConfFile': [conf_file['conf_file_id']]}