support netbox >=2.9 #177

Merged
Solvik merged 22 commits from 176-netbox-2.9 into master 2022-03-07 16:03:05 +01:00
4 changed files with 21 additions and 3 deletions
Showing only changes of commit 7cfcd685f3 - Show all commits

View file

@ -111,7 +111,7 @@ network:
# blade_role: "Blade" # blade_role: "Blade"
# server_role: "Server" # server_role: "Server"
# tags: server, blade, ,just a comma,delimited,list # tags: server, blade, ,just a comma,delimited,list
# # custom_fields: field1=value1,field2=value2#
# #
# Can use this to set the tenant # Can use this to set the tenant
# #

View file

@ -18,14 +18,15 @@ network:
# blade_role: "Blade" # blade_role: "Blade"
# server_role: "Server" # server_role: "Server"
# tags: server, blade, ,just a comma,delimited,list # tags: server, blade, ,just a comma,delimited,list
# custom_fields: field1=value1,field2=value2
#
# #
# Use this to set the tenant # Use this to set the tenant
# #
#tenant: #tenant:
# driver: "file:/tmp/tenant" # driver: "file:/tmp/tenant"
# regex: "(.*)" # regex: "(.*)"
datacenter_location: datacenter_location:
driver: "cmd:cat /etc/qualification | tr [A-Z] [a-z]" driver: "cmd:cat /etc/qualification | tr [A-Z] [a-z]"
regex: "datacenter: (?P<datacenter>[A-Za-z0-9]+)" regex: "datacenter: (?P<datacenter>[A-Za-z0-9]+)"

View file

@ -45,6 +45,8 @@ def get_config():
help="Command to output hostname, used as Device's name in netbox") help="Command to output hostname, used as Device's name in netbox")
p.add_argument('--device.tags', default=r'', p.add_argument('--device.tags', default=r'',
help='tags to use for a host') help='tags to use for a host')
p.add_argument('--device.custom_fields', default=r'',
help='custom_fields to use for a host, eg: field1=v1,field2=v2')
p.add_argument('--device.blade_role', default=r'Blade', p.add_argument('--device.blade_role', default=r'Blade',
help='role to use for a blade server') help='role to use for a blade server')
p.add_argument('--device.chassis_role', default=r'Server Chassis', p.add_argument('--device.chassis_role', default=r'Server Chassis',

View file

@ -32,6 +32,15 @@ class ServerBase():
x.strip() for x in config.device.tags.split(',') if x.strip() x.strip() for x in config.device.tags.split(',') if x.strip()
])) if config.device.tags else [] ])) if config.device.tags else []
self.nb_tags = list(create_netbox_tags(self.tags)) self.nb_tags = list(create_netbox_tags(self.tags))
config_cf = set([
f.strip() for f in config.device.custom_fields.split(",")
if f.strip()
])
self.custom_fields = {}
self.custom_fields.update(dict([
(k.strip(), v.strip()) for k, v in
[f.split("=", 1) for f in config_cf]
]))
def get_tenant(self): def get_tenant(self):
tenant = Tenant() tenant = Tenant()
@ -195,6 +204,7 @@ class ServerBase():
tenant=tenant.id if tenant else None, tenant=tenant.id if tenant else None,
rack=rack.id if rack else None, rack=rack.id if rack else None,
tags=[{'name': x} for x in self.tags], tags=[{'name': x} for x in self.tags],
custom_fields=self.custom_fields,
) )
return new_chassis return new_chassis
@ -217,6 +227,7 @@ class ServerBase():
tenant=tenant.id if tenant else None, tenant=tenant.id if tenant else None,
rack=rack.id if rack else None, rack=rack.id if rack else None,
tags=[{'name': x} for x in self.tags], tags=[{'name': x} for x in self.tags],
custom_fields=self.custom_fields,
) )
return new_blade return new_blade
@ -438,6 +449,10 @@ class ServerBase():
server.tags = [x.id for x in self.nb_tags] server.tags = [x.id for x in self.nb_tags]
update += 1 update += 1
if server.custom_fields != self.custom_fields:
server.custom_fields = self.custom_fields
update += 1
if config.update_all or config.update_location: if config.update_all or config.update_location:
ret, server = self.update_netbox_location(server) ret, server = self.update_netbox_location(server)
update += ret update += ret