Merge pull request #485 from tobiasge/prepare-2.11

Initializer updates for Netbox 2.11
This commit is contained in:
Tobias Genannt 2021-04-16 20:00:35 +02:00 committed by GitHub
commit c7df608696
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 64 additions and 73 deletions

View File

@ -14,6 +14,9 @@ jobs:
name: Checks syntax of our code name: Checks syntax of our code
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
with:
# Full git history is needed to get a proper list of changed files within `super-linter`
fetch-depth: 0
- uses: actions/setup-python@v2 - uses: actions/setup-python@v2
- name: Lint Code Base - name: Lint Code Base
uses: github/super-linter@v3 uses: github/super-linter@v3

View File

@ -10,12 +10,12 @@
## Examples: ## Examples:
# - name: link_to_repo # - name: link_to_repo
# text: 'Link to Netbox Docker' # link_text: 'Link to Netbox Docker'
# url: 'https://github.com/netbox-community/netbox-docker' # link_url: 'https://github.com/netbox-community/netbox-docker'
# new_window: False # new_window: False
# content_type: device # content_type: device
# - name: link_to_localhost # - name: link_to_localhost
# text: 'Link to localhost' # link_text: 'Link to localhost'
# url: 'http://localhost' # link_url: 'http://localhost'
# new_window: True # new_window: True
# content_type: device # content_type: device

View File

@ -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

View File

@ -2,4 +2,4 @@
# site: AMS 1 # site: AMS 1
# - name: power panel SING 1 # - name: power panel SING 1
# site: SING 1 # site: SING 1
# rack_group: cage 101 # location: cage 101

View File

@ -32,7 +32,7 @@
# text_field: Description # text_field: Description
# - site: SING 1 # - site: SING 1
# name: rack-03 # name: rack-03
# group: cage 101 # location: cage 101
# role: Role 3 # role: Role 3
# type: 4-post-cabinet # type: 4-post-cabinet
# width: 19 # width: 19

View File

@ -1,6 +1,24 @@
# - name: VLAN group 1 # - name: VLAN group 1
# site: AMS 1 # scope_type: dcim.region
# scope: Amsterdam
# slug: vlan-group-1 # slug: vlan-group-1
# - name: VLAN group 2 # - name: VLAN group 2
# site: AMS 1 # scope_type: dcim.site
# scope: AMS 1
# slug: vlan-group-2 # slug: vlan-group-2
# - name: VLAN group 3
# scope_type: dcim.location
# scope: cage 101
# slug: vlan-group-3
# - name: VLAN group 4
# scope_type: dcim.rack
# scope: rack-01
# slug: vlan-group-4
# - name: VLAN group 5
# scope_type: virtualization.cluster
# scope: cluster1
# slug: vlan-group-5
# - name: VLAN group 6
# scope_type: virtualization.clustergroup
# scope: Group 1
# slug: vlan-group-6

View File

@ -1,9 +1,9 @@
import sys import sys
from dcim.models import RackGroup, Site from dcim.models import Location, Site
from startup_script_utils import load_yaml from startup_script_utils import load_yaml
rack_groups = load_yaml("/opt/netbox/initializers/rack_groups.yml") rack_groups = load_yaml("/opt/netbox/initializers/locations.yml")
if rack_groups is None: if rack_groups is None:
sys.exit() sys.exit()
@ -17,7 +17,7 @@ for params in rack_groups:
query = {field: params.pop(assoc)} query = {field: params.pop(assoc)}
params[assoc] = model.objects.get(**query) params[assoc] = model.objects.get(**query)
rack_group, created = RackGroup.objects.get_or_create(**params) location, created = Location.objects.get_or_create(**params)
if created: if created:
print("🎨 Created rack group", rack_group.name) print("🎨 Created location", location.name)

View File

@ -1,6 +1,6 @@
import sys import sys
from dcim.models import Rack, RackGroup, RackRole, Site from dcim.models import Location, Rack, RackRole, Site
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
@ -14,7 +14,7 @@ required_assocs = {"site": (Site, "name")}
optional_assocs = { optional_assocs = {
"role": (RackRole, "name"), "role": (RackRole, "name"),
"tenant": (Tenant, "name"), "tenant": (Tenant, "name"),
"group": (RackGroup, "name"), "location": (Location, "name"),
} }
for params in racks: for params in racks:

View File

@ -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, Location, Platform, Rack, Site
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:

View File

@ -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)

View File

@ -1,6 +1,6 @@
import sys import sys
from dcim.models import Site from django.contrib.contenttypes.models import ContentType
from ipam.models import VLANGroup from ipam.models import VLANGroup
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
@ -9,7 +9,7 @@ vlan_groups = load_yaml("/opt/netbox/initializers/vlan_groups.yml")
if vlan_groups is None: if vlan_groups is None:
sys.exit() sys.exit()
optional_assocs = {"site": (Site, "name")} optional_assocs = {"scope": (None, "name")}
for params in vlan_groups: for params in vlan_groups:
custom_field_data = pop_custom_fields(params) custom_field_data = pop_custom_fields(params)
@ -18,9 +18,20 @@ for params in vlan_groups:
if assoc in params: if assoc in params:
model, field = details model, field = details
query = {field: params.pop(assoc)} query = {field: params.pop(assoc)}
# Get model from Contenttype
params[assoc] = model.objects.get(**query) scope_type = params.pop("scope_type", None)
if not scope_type:
print(f"VLAN Group '{params['name']}': scope_type is missing from VLAN Group")
continue
app_label, model = str(scope_type).split(".")
ct = ContentType.objects.filter(app_label=app_label, model=model).first()
if not ct:
print(
f"VLAN Group '{params['name']}': ContentType for "
+ f"app_label = '{app_label}' and model = '{model}' not found"
)
continue
params["scope_id"] = ct.model_class().objects.get(**query).id
vlan_group, created = VLANGroup.objects.get_or_create(**params) vlan_group, created = VLANGroup.objects.get_or_create(**params)
if created: if created:

View File

@ -1,6 +1,6 @@
import sys import sys
from dcim.models import PowerPanel, RackGroup, Site from dcim.models import Location, PowerPanel, Site
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
power_panels = load_yaml("/opt/netbox/initializers/power_panels.yml") power_panels = load_yaml("/opt/netbox/initializers/power_panels.yml")
@ -10,7 +10,7 @@ if power_panels is None:
required_assocs = {"site": (Site, "name")} required_assocs = {"site": (Site, "name")}
optional_assocs = {"rack_group": (RackGroup, "name")} optional_assocs = {"location": (Location, "name")}
for params in power_panels: for params in power_panels:
custom_field_data = pop_custom_fields(params) custom_field_data = pop_custom_fields(params)