1 from PLC.Faults import *
2 from PLC.Method import Method
3 from PLC.Parameter import Parameter, Mixed
4 from PLC.Nodes import Node, Nodes
5 from PLC.NodeGroups import NodeGroup, NodeGroups
6 from PLC.Sites import Site, Sites
7 from PLC.Auth import PasswordAuth
9 class AdmAddNode(Method):
11 Adds a new node. Any values specified in optional_vals are used,
12 otherwise defaults are used.
14 PIs and techs may only add nodes to their own sites. Admins may
15 add nodes to any site.
17 Returns the new node_id (> 0) if successful, faults otherwise.
20 roles = ['admin', 'pi', 'tech']
22 can_update = lambda (field, value): field in \
24 update_fields = dict(filter(can_update, Node.fields.items()))
28 Mixed(Site.fields['site_id'],
29 Site.fields['login_base']),
30 Node.fields['hostname'],
31 Node.fields['boot_state'],
35 returns = Parameter(int, 'New node_id (> 0) if successful')
37 def call(self, auth, site_id_or_login_base, hostname, boot_state, optional_vals = {}):
38 if filter(lambda field: field not in self.update_fields, optional_vals):
39 raise PLCInvalidArgument, "Invalid fields specified"
41 # Get site information
42 sites = Sites(self.api, [site_id_or_login_base])
44 raise PLCInvalidArgument, "No such site"
46 site = sites.values()[0]
48 # Authenticated function
49 assert self.caller is not None
51 # If we are not an admin, make sure that the caller is a
53 if 'admin' not in self.caller['roles']:
54 if site['site_id'] not in self.caller['site_ids']:
55 assert self.caller['person_id'] not in site['person_ids']
56 raise PLCPermissionDenied, "Not allowed to add nodes to specified site"
58 assert self.caller['person_id'] in site['person_ids']
60 node = Node(self.api, optional_vals)
61 node['hostname'] = hostname
62 node['boot_state'] = boot_state
63 node['site_id'] = site['site_id']
64 node.sync(commit = False)
66 return node['node_id']