can_update = lambda (field, value): field in \
['hostname', 'boot_state', 'model', 'version',
- 'key', 'session']
+ 'key', 'session', 'boot_nonce']
class UpdateNode(Method):
"""
updated, all other fields are left untouched.
PIs and techs can update only the nodes at their sites. Only
- admins can update the key and session fields.
+ admins can update the key, session, and boot_nonce fields.
Returns 1 if successful, faults otherwise.
"""
returns = Parameter(int, '1 if successful')
+ object_type = 'Node'
+
def call(self, auth, node_id_or_hostname, node_fields):
node_fields = dict(filter(can_update, node_fields.items()))
# Remove admin only fields
if 'admin' not in self.caller['roles']:
- for key in 'key', 'session':
+ for key in 'key', 'session', 'boot_nonce':
del node_fields[key]
# Get account information
nodes = Nodes(self.api, [node_id_or_hostname])
if not nodes:
raise PLCInvalidArgument, "No such node"
+ node = nodes[0]
- node = nodes.values()[0]
+ if node['peer_id'] is not None:
+ raise PLCInvalidArgument, "Not a local node"
# Authenticated function
assert self.caller is not None
node.update(node_fields)
node.sync()
+
+ # Logging variables
+ self.object_ids = [node['node_id']]
+ self.message = 'Node %d updated: %s.' % \
+ (node['node_id'], ", ".join(node_fields.keys()))
+ if 'boot_state' in node_fields.keys():
+ self.message += ' boot_state updated to %s' % node_fields['boot_state']
return 1