From 4f482e484ff028596236299c59fc133a0d8f5249 Mon Sep 17 00:00:00 2001 From: Tobias Genannt Date: Thu, 9 Dec 2021 22:06:59 +0100 Subject: [PATCH 01/13] Fixed GHCR link --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index d8aedf4de..18669fe26 100644 --- a/README.md +++ b/README.md @@ -19,7 +19,7 @@ please join [our Slack][netbox-docker-slack] and ask for help in the [`#netbox-d [netbox-docker-microbadger]: https://microbadger.com/images/netboxcommunity/netbox [netbox-dockerhub]: https://hub.docker.com/r/netboxcommunity/netbox/ [netbox-quayio]: https://quay.io/repository/netboxcommunity/netbox -[netbox-ghcr]: https://ghcr.io/netbox-community/netbox/ +[netbox-ghcr]: /~https://github.com/netbox-community/netbox-docker/pkgs/container/netbox [netbox-docker-github]: /~https://github.com/netbox-community/netbox-docker/ [netbox-docker-slack]: https://join.slack.com/t/netdev-community/shared_invite/zt-mtts8g0n-Sm6Wutn62q_M4OdsaIycrQ [netbox-docker-slack-channel]: https://netdev-community.slack.com/archives/C01P0GEVBU7 From 60d191bb2ab481ef7d0167488ecd17fbacb9814e Mon Sep 17 00:00:00 2001 From: Tobias Genannt Date: Thu, 9 Dec 2021 22:23:03 +0100 Subject: [PATCH 02/13] Fixed textlint errors --- README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 18669fe26..b76f9cf55 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,7 @@ ![Docker Pulls](https://img.shields.io/docker/pulls/netboxcommunity/netbox) [![GitHub license](https://img.shields.io/github/license/netbox-community/netbox-docker)][netbox-docker-license] -[The Github repository](netbox-docker-github) houses the components needed to build NetBox as a container. +[The GitHub repository](netbox-docker-github) houses the components needed to build NetBox as a container. Images are built regularly using the code in that repository and are pushed to [Docker Hub][netbox-dockerhub], [Quay.io][netbox-quayio] and [GitHub Container Registry][netbox-ghcr]. Do you have any questions? @@ -75,7 +75,7 @@ New container images are built and published automatically every ~24h. You must use _NetBox Docker version_ `a.b.c` to guarantee the compatibility. These images are automatically built from [the `master` branch of NetBox][netbox-master]. * `snapshot-a.b.c`: - These are pre-release builds. + These are prerelease builds. They contain the support files of _NetBox Docker version_ `a.b.c`. You must use _NetBox Docker version_ `a.b.c` to guarantee the compatibility. These images are automatically built from the [`develop` branch of NetBox][netbox-develop]. @@ -106,7 +106,7 @@ Then there is currently one extra tags for each of the above tags: ## Documentation -Please refer [to our wiki on Github][netbox-docker-wiki] for further information on how to use the NetBox Docker image properly. +Please refer [to our wiki on GitHub][netbox-docker-wiki] for further information on how to use the NetBox Docker image properly. The wiki covers advanced topics such as using files for secrets, configuring TLS, deployment to Kubernetes, monitoring and configuring NAPALM and LDAP. Our wiki is a community effort. @@ -116,7 +116,7 @@ Feel free to correct errors, update outdated information or provide additional g ## Getting Help -Feel free to ask questions in our [Github Community][netbox-community] +Feel free to ask questions in our [GitHub Community][netbox-community] or [join our Slack][netbox-docker-slack] and ask [in our channel `#netbox-docker`][netbox-docker-slack-channel], which is free to use and where there are almost always people online that can help you in the Slack channel. From ed48909f96316bca446f4cace5cf1732975575aa Mon Sep 17 00:00:00 2001 From: Tobias Genannt Date: Fri, 10 Dec 2021 14:29:53 +0100 Subject: [PATCH 03/13] Removed Alpine edge from tests --- .github/workflows/push.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml index 608e6e051..d77ceb58b 100644 --- a/.github/workflows/push.yml +++ b/.github/workflows/push.yml @@ -46,7 +46,6 @@ jobs: - ./build.sh develop docker_from: - '' # use the default of the build script - - alpine:edge fail-fast: false runs-on: ubuntu-latest name: Builds new NetBox Docker Images From 46afa266fa2e7d06f316c50a17c964ffe1e909b8 Mon Sep 17 00:00:00 2001 From: Renovate Bot Date: Sun, 26 Dec 2021 15:22:25 +0000 Subject: [PATCH 04/13] Update dependency ruamel.yaml to v0.17.19 --- requirements-container.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements-container.txt b/requirements-container.txt index f47f232a4..b7979b3c1 100644 --- a/requirements-container.txt +++ b/requirements-container.txt @@ -1,5 +1,5 @@ napalm==3.3.1 -ruamel.yaml==0.17.17 +ruamel.yaml==0.17.19 django-auth-ldap==3.0.0 google-crc32c==1.3.0 django-storages[azure,boto3,dropbox,google,libcloud,sftp]==1.12.3 From 22c42124381ffd3f11fff714056fd07c5f877c65 Mon Sep 17 00:00:00 2001 From: Renovate Bot Date: Mon, 3 Jan 2022 09:48:22 +0000 Subject: [PATCH 05/13] Update dependency ruamel.yaml to v0.17.20 --- requirements-container.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements-container.txt b/requirements-container.txt index b7979b3c1..bbb3d33d5 100644 --- a/requirements-container.txt +++ b/requirements-container.txt @@ -1,5 +1,5 @@ napalm==3.3.1 -ruamel.yaml==0.17.19 +ruamel.yaml==0.17.20 django-auth-ldap==3.0.0 google-crc32c==1.3.0 django-storages[azure,boto3,dropbox,google,libcloud,sftp]==1.12.3 From ee47ba04bc2363595080781f61824b9de87b4bae Mon Sep 17 00:00:00 2001 From: Tobias Genannt Date: Mon, 10 Jan 2022 10:49:51 +0100 Subject: [PATCH 06/13] Added ASN initializer script --- initializers/asns.yml | 7 +++++++ initializers/sites.yml | 4 ---- startup_scripts/155_asns.py | 33 +++++++++++++++++++++++++++++++++ 3 files changed, 40 insertions(+), 4 deletions(-) create mode 100644 initializers/asns.yml create mode 100644 startup_scripts/155_asns.py diff --git a/initializers/asns.yml b/initializers/asns.yml new file mode 100644 index 000000000..f75408b15 --- /dev/null +++ b/initializers/asns.yml @@ -0,0 +1,7 @@ +# - asn: 1 +# rir: RFC1918 +# tenant: tenant1 +# - asn: 2 +# rir: RFC4193 ULA +# - asn: 3 +# rir: RFC3849 diff --git a/initializers/sites.yml b/initializers/sites.yml index 7ace3aa9a..700c8530c 100644 --- a/initializers/sites.yml +++ b/initializers/sites.yml @@ -3,7 +3,6 @@ # region: Downtown # status: active # facility: Amsterdam 1 -# asn: 12345 # custom_field_data: # text_field: Description for AMS1 # - name: AMS 2 @@ -11,7 +10,6 @@ # region: Downtown # status: active # facility: Amsterdam 2 -# asn: 54321 # custom_field_data: # text_field: Description for AMS2 # - name: AMS 3 @@ -19,7 +17,6 @@ # region: Suburbs # status: active # facility: Amsterdam 3 -# asn: 67890 # tenant: tenant1 # custom_field_data: # text_field: Description for AMS3 @@ -28,7 +25,6 @@ # region: Singapore # status: active # facility: Singapore 1 -# asn: 09876 # tenant: tenant2 # custom_field_data: # text_field: Description for SING1 diff --git a/startup_scripts/155_asns.py b/startup_scripts/155_asns.py new file mode 100644 index 000000000..893f3ba91 --- /dev/null +++ b/startup_scripts/155_asns.py @@ -0,0 +1,33 @@ +import sys + +from ipam.models import ASN, RIR +from startup_script_utils import load_yaml +from tenancy.models import Tenant + +asns = load_yaml("/opt/netbox/initializers/asns.yml") + +if asns is None: + sys.exit() + +required_assocs = {"rir": (RIR, "name")} + +optional_assocs = {"tenant": (Tenant, "name")} + +for params in asns: + 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) + + asn, created = ASN.objects.get_or_create(**params) + + if created: + print(f"🔡 Created ASN {asn.asn}") From 52876be723d81ea3872ef2ebfcecb1adebdde9e2 Mon Sep 17 00:00:00 2001 From: ryanmerolle Date: Mon, 31 Jan 2022 21:45:29 -0500 Subject: [PATCH 07/13] add graphql --- configuration/configuration.py | 3 +++ env/netbox.env | 1 + 2 files changed, 4 insertions(+) diff --git a/configuration/configuration.py b/configuration/configuration.py index 311d1f0d6..1db605111 100644 --- a/configuration/configuration.py +++ b/configuration/configuration.py @@ -147,6 +147,9 @@ def _read_secret(secret_name, default = None): # by anonymous users. List models in the form `.`. Add '*' to this list to exempt all models. EXEMPT_VIEW_PERMISSIONS = list(filter(None, environ.get('EXEMPT_VIEW_PERMISSIONS', '').split(' '))) +# Enable GraphQL API. +GRAPHQL_ENABLED = environ.get('GRAPHQL_ENABLED', 'True').lower() == 'true' + # Enable custom logging. Please see the Django documentation for detailed guidance on configuring custom logs: # https://docs.djangoproject.com/en/stable/topics/logging/ LOGGING = {} diff --git a/env/netbox.env b/env/netbox.env index 6593cbcfd..456cac989 100644 --- a/env/netbox.env +++ b/env/netbox.env @@ -14,6 +14,7 @@ EMAIL_USERNAME=netbox # EMAIL_USE_SSL and EMAIL_USE_TLS are mutually exclusive, i.e. they can't both be `true`! EMAIL_USE_SSL=false EMAIL_USE_TLS=false +GRAPHQL_ENABLED=true HOUSEKEEPING_INTERVAL=86400 MAX_PAGE_SIZE=1000 MEDIA_ROOT=/opt/netbox/netbox/media From 297aab1fd30ac6c1be1d14734d7d7c19b13b5013 Mon Sep 17 00:00:00 2001 From: Tobias Genannt Date: Wed, 2 Feb 2022 16:49:29 +0100 Subject: [PATCH 08/13] Fixed build for Netbox feature branch --- Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Dockerfile b/Dockerfile index 505b88863..51cd3594f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -97,7 +97,7 @@ WORKDIR /opt/netbox/netbox RUN mkdir -p static /opt/unit/state/ /opt/unit/tmp/ \ && chown -R unit:root media /opt/unit/ \ && chmod -R g+w media /opt/unit/ \ - && cd /opt/netbox/ && /opt/netbox/venv/bin/python -m mkdocs build \ + && cd /opt/netbox/ && SECRET_KEY="dummy" /opt/netbox/venv/bin/python -m mkdocs build \ --config-file /opt/netbox/mkdocs.yml --site-dir /opt/netbox/netbox/project-static/docs/ \ && SECRET_KEY="dummy" /opt/netbox/venv/bin/python /opt/netbox/netbox/manage.py collectstatic --no-input From 8860d32f976510a2f148c88b6da90cdf72ed4cd0 Mon Sep 17 00:00:00 2001 From: Ryan Merolle Date: Thu, 3 Feb 2022 11:10:39 -0500 Subject: [PATCH 09/13] Cleanup & Reorg startup scripts (#691) * Cleanup & Reorg startup scripts --- ...rmissions.py => 020_object_permissions.py} | 0 ..._custom_fields.py => 030_custom_fields.py} | 0 ...80_custom_links.py => 040_custom_links.py} | 0 startup_scripts/{020_tags.py => 050_tags.py} | 0 .../{290_webhooks.py => 060_webhooks.py} | 0 ..._tenant_groups.py => 070_tenant_groups.py} | 0 .../{030_tenants.py => 080_tenants.py} | 0 .../{030_regions.py => 090_regions.py} | 0 .../{040_sites.py => 110_sites.py} | 0 .../{075_locations.py => 120_locations.py} | 0 .../{070_rack_roles.py => 130_rack_roles.py} | 0 startup_scripts/140_clusters.py | 42 ------------------- .../{080_racks.py => 140_racks.py} | 0 ...30_power_panels.py => 150_power_panels.py} | 0 ...{340_power_feeds.py => 160_power_feeds.py} | 0 startup_scripts/165_cluster_groups.py | 15 ------- ..._manufacturers.py => 170_manufacturers.py} | 0 ...90_device_roles.py => 180_device_roles.py} | 0 ...60_device_types.py => 190_device_types.py} | 0 .../{140_devices.py => 200_devices.py} | 0 ...m_interfaces.py => 210_dcim_interfaces.py} | 0 .../{100_platforms.py => 220_platforms.py} | 0 ..._route_targets.py => 230_route_targets.py} | 0 startup_scripts/{180_vrfs.py => 240_vrfs.py} | 0 startup_scripts/{150_rirs.py => 250_rirs.py} | 0 startup_scripts/{155_asns.py => 260_asns.py} | 0 .../{160_aggregates.py => 270_aggregates.py} | 0 ...vlan_roles.py => 280_prefix_vlan_roles.py} | 0 ..._cluster_types.py => 290_cluster_types.py} | 0 ...luster_groups.py => 300_cluster_groups.py} | 0 .../{135_clusters.py => 310_clusters.py} | 0 ...{200_vlan_groups.py => 320_vlan_groups.py} | 0 .../{210_vlans.py => 330_vlans.py} | 0 ...al_machines.py => 340_virtual_machines.py} | 0 ...es.py => 350_virtualization_interfaces.py} | 0 .../{220_prefixes.py => 360_prefixes.py} | 0 ...60_ip_addresses.py => 370_ip_addresses.py} | 1 + ...{270_primary_ips.py => 380_primary_ips.py} | 0 .../{320_services.py => 400_services.py} | 0 .../{280_providers.py => 420_providers.py} | 0 ..._circuit_types.py => 440_circuit_types.py} | 0 .../{300_circuits.py => 450_circuits.py} | 0 42 files changed, 1 insertion(+), 57 deletions(-) rename startup_scripts/{015_object_permissions.py => 020_object_permissions.py} (100%) rename startup_scripts/{020_custom_fields.py => 030_custom_fields.py} (100%) rename startup_scripts/{280_custom_links.py => 040_custom_links.py} (100%) rename startup_scripts/{020_tags.py => 050_tags.py} (100%) rename startup_scripts/{290_webhooks.py => 060_webhooks.py} (100%) rename startup_scripts/{020_tenant_groups.py => 070_tenant_groups.py} (100%) rename startup_scripts/{030_tenants.py => 080_tenants.py} (100%) rename startup_scripts/{030_regions.py => 090_regions.py} (100%) rename startup_scripts/{040_sites.py => 110_sites.py} (100%) rename startup_scripts/{075_locations.py => 120_locations.py} (100%) rename startup_scripts/{070_rack_roles.py => 130_rack_roles.py} (100%) delete mode 100644 startup_scripts/140_clusters.py rename startup_scripts/{080_racks.py => 140_racks.py} (100%) rename startup_scripts/{330_power_panels.py => 150_power_panels.py} (100%) rename startup_scripts/{340_power_feeds.py => 160_power_feeds.py} (100%) delete mode 100644 startup_scripts/165_cluster_groups.py rename startup_scripts/{050_manufacturers.py => 170_manufacturers.py} (100%) rename startup_scripts/{090_device_roles.py => 180_device_roles.py} (100%) rename startup_scripts/{060_device_types.py => 190_device_types.py} (100%) rename startup_scripts/{140_devices.py => 200_devices.py} (100%) rename startup_scripts/{250_dcim_interfaces.py => 210_dcim_interfaces.py} (100%) rename startup_scripts/{100_platforms.py => 220_platforms.py} (100%) rename startup_scripts/{175_route_targets.py => 230_route_targets.py} (100%) rename startup_scripts/{180_vrfs.py => 240_vrfs.py} (100%) rename startup_scripts/{150_rirs.py => 250_rirs.py} (100%) rename startup_scripts/{155_asns.py => 260_asns.py} (100%) rename startup_scripts/{160_aggregates.py => 270_aggregates.py} (100%) rename startup_scripts/{190_prefix_vlan_roles.py => 280_prefix_vlan_roles.py} (100%) rename startup_scripts/{130_cluster_types.py => 290_cluster_types.py} (100%) rename startup_scripts/{135_cluster_groups.py => 300_cluster_groups.py} (100%) rename startup_scripts/{135_clusters.py => 310_clusters.py} (100%) rename startup_scripts/{200_vlan_groups.py => 320_vlan_groups.py} (100%) rename startup_scripts/{210_vlans.py => 330_vlans.py} (100%) rename startup_scripts/{230_virtual_machines.py => 340_virtual_machines.py} (100%) rename startup_scripts/{240_virtualization_interfaces.py => 350_virtualization_interfaces.py} (100%) rename startup_scripts/{220_prefixes.py => 360_prefixes.py} (100%) rename startup_scripts/{260_ip_addresses.py => 370_ip_addresses.py} (99%) rename startup_scripts/{270_primary_ips.py => 380_primary_ips.py} (100%) rename startup_scripts/{320_services.py => 400_services.py} (100%) rename startup_scripts/{280_providers.py => 420_providers.py} (100%) rename startup_scripts/{290_circuit_types.py => 440_circuit_types.py} (100%) rename startup_scripts/{300_circuits.py => 450_circuits.py} (100%) diff --git a/startup_scripts/015_object_permissions.py b/startup_scripts/020_object_permissions.py similarity index 100% rename from startup_scripts/015_object_permissions.py rename to startup_scripts/020_object_permissions.py diff --git a/startup_scripts/020_custom_fields.py b/startup_scripts/030_custom_fields.py similarity index 100% rename from startup_scripts/020_custom_fields.py rename to startup_scripts/030_custom_fields.py diff --git a/startup_scripts/280_custom_links.py b/startup_scripts/040_custom_links.py similarity index 100% rename from startup_scripts/280_custom_links.py rename to startup_scripts/040_custom_links.py diff --git a/startup_scripts/020_tags.py b/startup_scripts/050_tags.py similarity index 100% rename from startup_scripts/020_tags.py rename to startup_scripts/050_tags.py diff --git a/startup_scripts/290_webhooks.py b/startup_scripts/060_webhooks.py similarity index 100% rename from startup_scripts/290_webhooks.py rename to startup_scripts/060_webhooks.py diff --git a/startup_scripts/020_tenant_groups.py b/startup_scripts/070_tenant_groups.py similarity index 100% rename from startup_scripts/020_tenant_groups.py rename to startup_scripts/070_tenant_groups.py diff --git a/startup_scripts/030_tenants.py b/startup_scripts/080_tenants.py similarity index 100% rename from startup_scripts/030_tenants.py rename to startup_scripts/080_tenants.py diff --git a/startup_scripts/030_regions.py b/startup_scripts/090_regions.py similarity index 100% rename from startup_scripts/030_regions.py rename to startup_scripts/090_regions.py diff --git a/startup_scripts/040_sites.py b/startup_scripts/110_sites.py similarity index 100% rename from startup_scripts/040_sites.py rename to startup_scripts/110_sites.py diff --git a/startup_scripts/075_locations.py b/startup_scripts/120_locations.py similarity index 100% rename from startup_scripts/075_locations.py rename to startup_scripts/120_locations.py diff --git a/startup_scripts/070_rack_roles.py b/startup_scripts/130_rack_roles.py similarity index 100% rename from startup_scripts/070_rack_roles.py rename to startup_scripts/130_rack_roles.py diff --git a/startup_scripts/140_clusters.py b/startup_scripts/140_clusters.py deleted file mode 100644 index 2748f2038..000000000 --- a/startup_scripts/140_clusters.py +++ /dev/null @@ -1,42 +0,0 @@ -import sys - -from dcim.models import 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, ClusterGroup, ClusterType - -clusters = load_yaml("/opt/netbox/initializers/clusters.yml") - -if clusters is None: - sys.exit() - -required_assocs = {"type": (ClusterType, "name")} - -optional_assocs = { - "site": (Site, "name"), - "group": (ClusterGroup, "name"), - "tenant": (Tenant, "name"), -} - -for params in clusters: - custom_field_data = pop_custom_fields(params) - - 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) - - cluster, created = Cluster.objects.get_or_create(**params) - - if created: - set_custom_fields_values(cluster, custom_field_data) - - print("🗄️ Created cluster", cluster.name) diff --git a/startup_scripts/080_racks.py b/startup_scripts/140_racks.py similarity index 100% rename from startup_scripts/080_racks.py rename to startup_scripts/140_racks.py diff --git a/startup_scripts/330_power_panels.py b/startup_scripts/150_power_panels.py similarity index 100% rename from startup_scripts/330_power_panels.py rename to startup_scripts/150_power_panels.py diff --git a/startup_scripts/340_power_feeds.py b/startup_scripts/160_power_feeds.py similarity index 100% rename from startup_scripts/340_power_feeds.py rename to startup_scripts/160_power_feeds.py diff --git a/startup_scripts/165_cluster_groups.py b/startup_scripts/165_cluster_groups.py deleted file mode 100644 index fedd292ec..000000000 --- a/startup_scripts/165_cluster_groups.py +++ /dev/null @@ -1,15 +0,0 @@ -import sys - -from startup_script_utils import load_yaml -from virtualization.models import ClusterGroup - -cluster_groups = load_yaml("/opt/netbox/initializers/cluster_groups.yml") - -if cluster_groups is None: - sys.exit() - -for params in cluster_groups: - cluster_group, created = ClusterGroup.objects.get_or_create(**params) - - if created: - print("🗄️ Created Cluster Group", cluster_group.name) diff --git a/startup_scripts/050_manufacturers.py b/startup_scripts/170_manufacturers.py similarity index 100% rename from startup_scripts/050_manufacturers.py rename to startup_scripts/170_manufacturers.py diff --git a/startup_scripts/090_device_roles.py b/startup_scripts/180_device_roles.py similarity index 100% rename from startup_scripts/090_device_roles.py rename to startup_scripts/180_device_roles.py diff --git a/startup_scripts/060_device_types.py b/startup_scripts/190_device_types.py similarity index 100% rename from startup_scripts/060_device_types.py rename to startup_scripts/190_device_types.py diff --git a/startup_scripts/140_devices.py b/startup_scripts/200_devices.py similarity index 100% rename from startup_scripts/140_devices.py rename to startup_scripts/200_devices.py diff --git a/startup_scripts/250_dcim_interfaces.py b/startup_scripts/210_dcim_interfaces.py similarity index 100% rename from startup_scripts/250_dcim_interfaces.py rename to startup_scripts/210_dcim_interfaces.py diff --git a/startup_scripts/100_platforms.py b/startup_scripts/220_platforms.py similarity index 100% rename from startup_scripts/100_platforms.py rename to startup_scripts/220_platforms.py diff --git a/startup_scripts/175_route_targets.py b/startup_scripts/230_route_targets.py similarity index 100% rename from startup_scripts/175_route_targets.py rename to startup_scripts/230_route_targets.py diff --git a/startup_scripts/180_vrfs.py b/startup_scripts/240_vrfs.py similarity index 100% rename from startup_scripts/180_vrfs.py rename to startup_scripts/240_vrfs.py diff --git a/startup_scripts/150_rirs.py b/startup_scripts/250_rirs.py similarity index 100% rename from startup_scripts/150_rirs.py rename to startup_scripts/250_rirs.py diff --git a/startup_scripts/155_asns.py b/startup_scripts/260_asns.py similarity index 100% rename from startup_scripts/155_asns.py rename to startup_scripts/260_asns.py diff --git a/startup_scripts/160_aggregates.py b/startup_scripts/270_aggregates.py similarity index 100% rename from startup_scripts/160_aggregates.py rename to startup_scripts/270_aggregates.py diff --git a/startup_scripts/190_prefix_vlan_roles.py b/startup_scripts/280_prefix_vlan_roles.py similarity index 100% rename from startup_scripts/190_prefix_vlan_roles.py rename to startup_scripts/280_prefix_vlan_roles.py diff --git a/startup_scripts/130_cluster_types.py b/startup_scripts/290_cluster_types.py similarity index 100% rename from startup_scripts/130_cluster_types.py rename to startup_scripts/290_cluster_types.py diff --git a/startup_scripts/135_cluster_groups.py b/startup_scripts/300_cluster_groups.py similarity index 100% rename from startup_scripts/135_cluster_groups.py rename to startup_scripts/300_cluster_groups.py diff --git a/startup_scripts/135_clusters.py b/startup_scripts/310_clusters.py similarity index 100% rename from startup_scripts/135_clusters.py rename to startup_scripts/310_clusters.py diff --git a/startup_scripts/200_vlan_groups.py b/startup_scripts/320_vlan_groups.py similarity index 100% rename from startup_scripts/200_vlan_groups.py rename to startup_scripts/320_vlan_groups.py diff --git a/startup_scripts/210_vlans.py b/startup_scripts/330_vlans.py similarity index 100% rename from startup_scripts/210_vlans.py rename to startup_scripts/330_vlans.py diff --git a/startup_scripts/230_virtual_machines.py b/startup_scripts/340_virtual_machines.py similarity index 100% rename from startup_scripts/230_virtual_machines.py rename to startup_scripts/340_virtual_machines.py diff --git a/startup_scripts/240_virtualization_interfaces.py b/startup_scripts/350_virtualization_interfaces.py similarity index 100% rename from startup_scripts/240_virtualization_interfaces.py rename to startup_scripts/350_virtualization_interfaces.py diff --git a/startup_scripts/220_prefixes.py b/startup_scripts/360_prefixes.py similarity index 100% rename from startup_scripts/220_prefixes.py rename to startup_scripts/360_prefixes.py diff --git a/startup_scripts/260_ip_addresses.py b/startup_scripts/370_ip_addresses.py similarity index 99% rename from startup_scripts/260_ip_addresses.py rename to startup_scripts/370_ip_addresses.py index 3f0aed000..7f166f0bb 100644 --- a/startup_scripts/260_ip_addresses.py +++ b/startup_scripts/370_ip_addresses.py @@ -52,6 +52,7 @@ params["assigned_object_id"] = Interface.objects.get(**query).id else: query = {field: params.pop(assoc)} + params[assoc] = model.objects.get(**query) ip_address, created = IPAddress.objects.get_or_create(**params) diff --git a/startup_scripts/270_primary_ips.py b/startup_scripts/380_primary_ips.py similarity index 100% rename from startup_scripts/270_primary_ips.py rename to startup_scripts/380_primary_ips.py diff --git a/startup_scripts/320_services.py b/startup_scripts/400_services.py similarity index 100% rename from startup_scripts/320_services.py rename to startup_scripts/400_services.py diff --git a/startup_scripts/280_providers.py b/startup_scripts/420_providers.py similarity index 100% rename from startup_scripts/280_providers.py rename to startup_scripts/420_providers.py diff --git a/startup_scripts/290_circuit_types.py b/startup_scripts/440_circuit_types.py similarity index 100% rename from startup_scripts/290_circuit_types.py rename to startup_scripts/440_circuit_types.py diff --git a/startup_scripts/300_circuits.py b/startup_scripts/450_circuits.py similarity index 100% rename from startup_scripts/300_circuits.py rename to startup_scripts/450_circuits.py From b31d99b936b51fb54fe91f829ca26c93493d2e81 Mon Sep 17 00:00:00 2001 From: Renovate Bot Date: Thu, 3 Feb 2022 16:50:11 +0000 Subject: [PATCH 10/13] Update dependency django-auth-ldap to v4 --- requirements-container.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements-container.txt b/requirements-container.txt index bbb3d33d5..4ab8d19ea 100644 --- a/requirements-container.txt +++ b/requirements-container.txt @@ -1,5 +1,5 @@ napalm==3.3.1 ruamel.yaml==0.17.20 -django-auth-ldap==3.0.0 +django-auth-ldap==4.0.0 google-crc32c==1.3.0 django-storages[azure,boto3,dropbox,google,libcloud,sftp]==1.12.3 From dad2e93572ae6525ac7f8f47201cf5806f271f61 Mon Sep 17 00:00:00 2001 From: Renovate Bot Date: Sat, 12 Feb 2022 11:16:45 +0000 Subject: [PATCH 11/13] Update dependency ruamel.yaml to v0.17.21 --- requirements-container.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements-container.txt b/requirements-container.txt index 4ab8d19ea..9aca62348 100644 --- a/requirements-container.txt +++ b/requirements-container.txt @@ -1,5 +1,5 @@ napalm==3.3.1 -ruamel.yaml==0.17.20 +ruamel.yaml==0.17.21 django-auth-ldap==4.0.0 google-crc32c==1.3.0 django-storages[azure,boto3,dropbox,google,libcloud,sftp]==1.12.3 From 3afdd3bf135ab1a0a6890a25c1a724e8edf6d65c Mon Sep 17 00:00:00 2001 From: Tobias Genannt Date: Wed, 16 Feb 2022 09:32:03 +0100 Subject: [PATCH 12/13] Added missing tzdata --- requirements-container.txt | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/requirements-container.txt b/requirements-container.txt index 9aca62348..254239516 100644 --- a/requirements-container.txt +++ b/requirements-container.txt @@ -1,5 +1,6 @@ -napalm==3.3.1 -ruamel.yaml==0.17.21 django-auth-ldap==4.0.0 -google-crc32c==1.3.0 django-storages[azure,boto3,dropbox,google,libcloud,sftp]==1.12.3 +google-crc32c==1.3.0 +napalm==3.3.1 +ruamel.yaml==0.17.21 +tzdata==2021.5 From b6d6f85dc0d363aaf92ec465a589f914ec02eb15 Mon Sep 17 00:00:00 2001 From: Tobias Genannt Date: Mon, 21 Feb 2022 11:25:37 +0100 Subject: [PATCH 13/13] Preparation for 1.6.0 --- VERSION | 2 +- docker-compose.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/VERSION b/VERSION index 26ca59460..dc1e644a1 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -1.5.1 +1.6.0 diff --git a/docker-compose.yml b/docker-compose.yml index 3b68f084f..9c6a284f3 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,7 +1,7 @@ version: '3.4' services: netbox: &netbox - image: netboxcommunity/netbox:${VERSION-v3.1-1.5.1} + image: netboxcommunity/netbox:${VERSION-v3.1-1.6.0} depends_on: - postgres - redis