Devices can be added to locations
This commit is contained in:
parent
5944086435
commit
45824ba4f3
|
@ -42,3 +42,12 @@
|
||||||
# position: 3
|
# position: 3
|
||||||
# custom_field_data:
|
# custom_field_data:
|
||||||
# text_field: Description
|
# text_field: Description
|
||||||
|
# - name: server04
|
||||||
|
# device_role: server
|
||||||
|
# device_type: Other
|
||||||
|
# site: SING 1
|
||||||
|
# location: cage 101
|
||||||
|
# face: front
|
||||||
|
# position: 3
|
||||||
|
# custom_field_data:
|
||||||
|
# text_field: Description
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from dcim.models import Device, DeviceRole, DeviceType, Platform, Rack, Site
|
from dcim.models import Device, DeviceRole, DeviceType, Platform, Rack, Site, Location
|
||||||
from startup_script_utils import load_yaml, pop_custom_fields, set_custom_fields_values
|
from startup_script_utils import load_yaml, pop_custom_fields, set_custom_fields_values
|
||||||
from tenancy.models import Tenant
|
from tenancy.models import Tenant
|
||||||
from virtualization.models import Cluster
|
from virtualization.models import Cluster
|
||||||
|
@ -21,6 +21,7 @@ optional_assocs = {
|
||||||
"platform": (Platform, "name"),
|
"platform": (Platform, "name"),
|
||||||
"rack": (Rack, "name"),
|
"rack": (Rack, "name"),
|
||||||
"cluster": (Cluster, "name"),
|
"cluster": (Cluster, "name"),
|
||||||
|
"location": (Location, "name"),
|
||||||
}
|
}
|
||||||
|
|
||||||
for params in devices:
|
for params in devices:
|
||||||
|
|
|
@ -1,51 +0,0 @@
|
||||||
import sys
|
|
||||||
|
|
||||||
from dcim.models import Device, DeviceRole, DeviceType, Platform, Rack, Site
|
|
||||||
from startup_script_utils import load_yaml, pop_custom_fields, set_custom_fields_values
|
|
||||||
from tenancy.models import Tenant
|
|
||||||
from virtualization.models import Cluster
|
|
||||||
|
|
||||||
devices = load_yaml("/opt/netbox/initializers/devices.yml")
|
|
||||||
|
|
||||||
if devices is None:
|
|
||||||
sys.exit()
|
|
||||||
|
|
||||||
required_assocs = {
|
|
||||||
"device_role": (DeviceRole, "name"),
|
|
||||||
"device_type": (DeviceType, "model"),
|
|
||||||
"site": (Site, "name"),
|
|
||||||
}
|
|
||||||
|
|
||||||
optional_assocs = {
|
|
||||||
"tenant": (Tenant, "name"),
|
|
||||||
"platform": (Platform, "name"),
|
|
||||||
"rack": (Rack, "name"),
|
|
||||||
"cluster": (Cluster, "name"),
|
|
||||||
}
|
|
||||||
|
|
||||||
for params in devices:
|
|
||||||
custom_field_data = pop_custom_fields(params)
|
|
||||||
|
|
||||||
# primary ips are handled later in `270_primary_ips.py`
|
|
||||||
params.pop("primary_ip4", None)
|
|
||||||
params.pop("primary_ip6", None)
|
|
||||||
|
|
||||||
for assoc, details in required_assocs.items():
|
|
||||||
model, field = details
|
|
||||||
query = {field: params.pop(assoc)}
|
|
||||||
|
|
||||||
params[assoc] = model.objects.get(**query)
|
|
||||||
|
|
||||||
for assoc, details in optional_assocs.items():
|
|
||||||
if assoc in params:
|
|
||||||
model, field = details
|
|
||||||
query = {field: params.pop(assoc)}
|
|
||||||
|
|
||||||
params[assoc] = model.objects.get(**query)
|
|
||||||
|
|
||||||
device, created = Device.objects.get_or_create(**params)
|
|
||||||
|
|
||||||
if created:
|
|
||||||
set_custom_fields_values(device, custom_field_data)
|
|
||||||
|
|
||||||
print("🖥️ Created device", device.name)
|
|
Loading…
Reference in New Issue