X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddNode.py;h=a1e8337a10efcdab59ee0e39b26fd8aedf92314a;hb=e2e924a46c15afa1a91b395c2daec68c62e0552e;hp=178127b14933d298126653940d53b2de4879f3b9;hpb=9dd15ec44b793f5db5cb32d7589873d8e032889c;p=plcapi.git diff --git a/PLC/Methods/AddNode.py b/PLC/Methods/AddNode.py index 178127b..a1e8337 100644 --- a/PLC/Methods/AddNode.py +++ b/PLC/Methods/AddNode.py @@ -1,12 +1,18 @@ # $Id$ +# $URL$ from PLC.Faults import * +from PLC.Auth import Auth from PLC.Method import Method from PLC.Parameter import Parameter, Mixed from PLC.Table import Row -from PLC.Nodes import Node, Nodes -from PLC.NodeGroups import NodeGroup, NodeGroups +from PLC.Namespace import hostname_to_hrn +from PLC.Peers import Peers from PLC.Sites import Site, Sites -from PLC.Auth import Auth +from PLC.Nodes import Node, Nodes +from PLC.TagTypes import TagTypes +from PLC.NodeTags import NodeTags +from PLC.Methods.AddNodeTag import AddNodeTag +from PLC.Methods.UpdateNodeTag import UpdateNodeTag can_update = ['hostname', 'node_type', 'boot_state', 'model', 'version'] @@ -23,7 +29,8 @@ class AddNode(Method): roles = ['admin', 'pi', 'tech'] - accepted_fields = Row.accepted_fields(can_update, [Node.fields,Node.tags]) + accepted_fields = Row.accepted_fields(can_update,Node.fields) + accepted_fields.update(Node.tags) accepts = [ Auth(), @@ -38,6 +45,8 @@ class AddNode(Method): [native,tags,rejected]=Row.split_fields(node_fields,[Node.fields,Node.tags]) + # type checking + native = Row.check_fields(native, self.accepted_fields) if rejected: raise PLCInvalidArgument, "Cannot add Node with column(s) %r"%rejected @@ -64,12 +73,23 @@ class AddNode(Method): node['site_id'] = site['site_id'] node.sync() - if tags: - print 'AddNode: warning, tags not handled yet', - for (k,v) in tags.iteritems(): print k + # since hostname was specified lets add the 'hrn' node tag + root_auth = self.api.config.PLC_HRN_ROOT + login_base = site['login_base'] + tags['hrn'] = hostname_to_hrn(root_auth, login_base, node['hostname']) + + for (tagname,value) in tags.iteritems(): + # the tagtype instance is assumed to exist, just check that + if not TagTypes(self.api,{'tagname':tagname}): + raise PLCInvalidArgument,"No such TagType %s"%tagname + node_tags=NodeTags(self.api,{'tagname':tagname,'node_id':node['node_id']}) + if not node_tags: + AddNodeTag(self.api).__call__(auth,node['node_id'],tagname,value) + else: + UpdateNodeTag(self.api).__call__(auth,node_tags[0]['node_tag_id'],value) - self.event_objects = {'Site': [site['site_id']], - 'Node': [node['node_id']]} - self.message = "Node %s created" % node['node_id'] + self.event_objects = {'Site': [site['site_id']], + 'Node': [node['node_id']]} + self.message = "Node %d=%s created" % (node['node_id'],node['hostname']) return node['node_id']