Skip to content

Releases: netbox-community/netbox

v3.5.2 - 2023-05-22

22 May 20:54
c9b79ca
Compare
Choose a tag to compare

Enhancements

  • #7671 - Introduce REMOTE_AUTH_AUTO_CREATE_GROUPS config parameter to enable the automatic creation of new groups when remote authentication is in use
  • #9068 - Disallow the assignment of network/broadcast IP addresses to interfaces
  • #11017 - Increase the maximum values for allocated and maximum power draws
  • #11233 - Intercept and cleanly report errors upon attempted database writes when maintenance mode is enabled
  • #11599 - Move contacts panels to separate tabs under object views
  • #11670 - Enable setting device type & module type weight via bulk import
  • #11900 - Add an outline to the reservation markers on rack elevations
  • #12131 - Show custom field description as an icon tooltip under object views
  • #12223 - Add columns for parent device bay and position to devices list
  • #12233 - Move related IP addresses table to a separate tab
  • #12286 - Show height and total weight under device view
  • #12323 - Add 100GE CXP interface type
  • #12327 - Introduce the ability to automatically retry failed background jobs
  • #12498 - Hide map button if MAPS_URL is empty
  • #12548 - Optimize REST API performance when retrieving interfaces with L2VPN assignments
  • #12554 - Allow customization or disabling of the maintenance mode banner
  • #12605 - Add LX.5 port types
  • #12629 - Add 400GE CDFP and CFP8 interface types
  • #12678 - Add 200GE QSFP-DD interface type

Bug Fixes

  • #10686 - Enable specifying termination object by virtual chassis master when importing cables
  • #11619 - Enable assigning VLANs without a site to interfaces during bulk edit
  • #12468 - Custom field names should not permit double underscores
  • #12550 - Fix rear port selection widget under front port creation form
  • #12570 - Disable ordering of synchronized object tables by the "synced" attribute
  • #12594 - Enable selecting config context as object type in object counts dashboard widget
  • #12642 - Fix bulk tenant assignment via cluster import form

v3.5.1 - 2023-05-05

05 May 16:51
5f184f2
Compare
Choose a tag to compare

Enhancements

  • #10759 - Support Markdown rendering for custom field descriptions
  • #11190 - Including systemd service & timer configurations for housekeeping tasks
  • #11422 - Match on power panel name when searching for power feeds
  • #11504 - Add filter to select individual racks under rack elevations view
  • #11652 - Add a module status column to module bay tables
  • #11791 - Enable configuration of custom database backend via ENGINE parameter
  • #11801 - Include device description within rack elevation tooltip
  • #11932 - Introduce a list view for image attachments, orderable by date and other attributes
  • #12122 - Enable bulk import oj journal entries
  • #12245 - Enable the assignment of wireless LANs to interfaces under bulk edit

Bug Fixes

  • #10757 - Simplify IP address interface and NAT IP assignment form fields to avoid confusion
  • #11715 - Prefix within a VRF should list global prefixes as parents only if they are containers
  • #12363 - Fix whitespace for paragraph elements in Markdown-rendered table columns
  • #12367 - Fix RelatedObjectDoesNotExist exception under certain conditions (regression from #11550)
  • #12380 - Allow selecting object change as model under object list widget configuration
  • #12384 - Add a three-second timeout for RSS reader widget
  • #12395 - Fix "create & add another" action for objects with custom fields
  • #12396 - Provider account should not be a required field in REST API serializer
  • #12400 - Validate default values for object and multi-object custom fields
  • #12401 - Support the creation of front ports without a pre-populated device ID
  • #12405 - Fix filtering for VLAN groups displayed under site view
  • #12410 - Fix base path for OpenAPI schema (fixes Swagger UI requests)
  • #12416 - Fix FileNotFoundError exception when a managed script file is missing from disk
  • #12412 - Device/VM interface MAC addresses can be nullified via REST API
  • #12415 - Fix ImportError exception when running RQ worker
  • #12433 - Correct the application of URL query parameters for object list dashboard widgets
  • #12436 - Remove extraneous "add" button from contact assignments list
  • #12463 - Fix the association of completed jobs with reports & scripts in the REST API
  • #12464 - Apply credentials for git data source only when connecting via HTTP/S
  • #12476 - Fix TypeError exception when running the runscript management command
  • #12483 - Fix git remote data syncing when with HTTP proxies defined
  • #12496 - Remove obsolete account field from provider UI view

v3.5.0 - 2023-04-27

27 Apr 18:40
eac7d01
Compare
Choose a tag to compare

Breaking Changes

  • The account field has been removed from the provider model. This information is now tracked using the new provider account model. Multiple accounts can be assigned per provider.
  • A minimum length of 50 characters is now enforced for the SECRET_KEY configuration parameter.
  • The JobResult model has been moved from the extras app to core and renamed to Job. Accordingly, its REST API endpoint has been moved from /api/extras/job-results/ to /api/core/jobs/.
  • The obj_type field on the Job model (previously JobResult) has been renamed to object_type for consistency with other models.
  • The JOBRESULT_RETENTION configuration parameter has been renamed to JOB_RETENTION.
  • The obj context variable is no longer passed when rendering custom links: Use object instead.
  • The REST API schema is now generated using the OpenAPI 3.0 spec
  • The URLs for the REST API schema documentation have changed:
    • /api/docs/ is now /api/schema/swagger-ui/
    • /api/redoc/ is now /api/schema/redoc/

New Features

Customizable Dashboard (#9416)

The static home view has been replaced with a fully customizable dashboard. Users can construct and rearrange their own personal dashboard to convey the information most pertinent to them. Supported widgets include object statistics, configurable object lists, RSS feeds, and notes, and we expect to continue adding new widgets over time.

Remote Data Sources (#11558)

NetBox now has the ability to synchronize arbitrary data from external sources through the new DataSource and DataFile models. Synchronized files are stored in the PostgreSQL database, and may be referenced and consumed by other NetBox models, such as export templates and config contexts. Currently, replication from local filesystem paths, git repositories, and Amazon S3 buckets is supported, and we expect to introduce additional backends in the near future.

Configuration Template Rendering (#11559)

This release introduces the ability to render device configurations from Jinja2 templates natively within NetBox, via both the UI and REST API. The new ConfigTemplate model stores template code (which may be defined locally or sourced from remote data files). The rendering engine passes data gleaned from both config contexts and request parameters to generate complete configurations suitable for direct application to network devices.

NAPALM Integration Plugin (#10520)

The NAPALM integration feature found in previous NetBox releases has been moved from the core application to a dedicated plugin. This allows greater control over the feature's configuration and will unlock additional potential as a separate project.

ASN Ranges (#8550)

A new ASN range model has been introduced to facilitate the provisioning of new autonomous system numbers from within a prescribed range. For example, an administrator might define an ASN range of 65000-65099 to be used for internal site identification. This includes a REST API endpoint suitable for automatic provisioning, very similar to the allocation of available prefixes and IP addresses.

Provider Accounts (#9047)

A new model has been introduced to represent individual accounts within a common circuit provider. This replaces the account field on the provider model, enabling users to track multiple accounts per provider. New provider account instances will be created automatically during upgrade for all providers which currently have an account assigned. The assignment of individual circuits to a provider account remains optional.

Job-Triggered Webhooks (#8958)

Two new webhook trigger events have been introduced: job_start and job_end. These enable users to configure webhook to trigger when a background job starts or ends, respectively. This new functionality can be used, for example, to inform a remote system when a custom script has been executed.

Enhancements

  • #7947 - Enable marking IP ranges as fully utilized
  • #8184 - Employ HTMX to dynamically render tables listing related objects
  • #8272 - Support bridge relationships among device type interfaces
  • #8749 - Support replicating custom field values when cloning an object
  • #9073 - Enable syncing config context data from remote sources
  • #9653 - Enable setting a default platform for device types
  • #10054 - Introduce advanced object selector for UI forms
  • #10242 - Redirect to filtered objects list after bulk import
  • #10374 - Require unique tenant names & slugs per group
  • #10729 - Add date & time custom field type
  • #11029 - Enable change logging for cable terminations
  • #11254 - Introduce the X-Request-ID HTTP header to annotate the unique ID of each request for change logging
  • #11255 - Introduce the scheduling_enabled settings for reports & scripts
  • #11291 - Optimized GraphQL API request handling
  • #11440 - Add an enabled field for device type interfaces
  • #11494 - Enable filtering objects by create/update request IDs
  • #11517 - Standardize the inclusion of related objects across the entire UI
  • #11584 - Add a list view for contact assignments
  • #11625 - Add HTMX support to ObjectEditView
  • #11693 - Enable syncing export template content from remote sources
  • #11780 - Enable loading import data from remote sources
  • #11790 - Create database indexes for all generic foreign keys
  • #11968 - Add navigation menu buttons to create device & VM components
  • #12068 - Enable generic foreign key relationships from jobs to NetBox objects
  • #12085 - Add a file source view for reports
  • #12218 - Provide more relevant API endpoint descriptions in schema
  • #12343 - Enforce a minimum length for SECRET_KEY configuration parameter

Bug Fixes (From Beta2)

  • #12149 - Fix OpenAPI schema warnings relating to enum collisions
  • #12195 - Fix exception when setting IP address role to null via REST API
  • #12256 - Fix OpenAPI schema warnings relating to nested serializers
  • #12278 - Fix schema warnings related to IPAddressField
  • #12288 - Include servers definition in OpenAPI spec
  • #12299 - Fix object list widget support for filtering by multiple values

Other Changes

  • #9608 - Upgrade REST API schema to OpenAPI 3.0
  • #10604 - Remove unused extra_tabs block from object.html generic template
  • #10923 - Remove unused NetBoxModelCSVForm class (replaced by NetBoxModelImportForm)
  • #11489 - Consolidated several middleware classes
  • #11611 - Refactor API viewset classes and introduce NetBoxReadOnlyModelViewSet
  • #11694 - Remove obsolete SmallTextarea form widget
  • #11737 - ChangeLoggedModel now inherits WebhooksMixin
  • #11765 - Retire the StaticSelect and StaticSelectMultiple form widgets
  • #11955 - Remove the unused CSVDataField and CSVFileField classes
  • #12067 - Move & rename extras.JobResult to core.Job

v3.4.10 - 2023-04-27

27 Apr 16:03
72767fb
Compare
Choose a tag to compare

Bug Fixes

  • #11607 - Fix custom object field assignments made via REST API for for cables
  • #12252 - Fix ordering of search results when sorting by object name
  • #12355 - Fix escaping of certain characters in URL when rendering custom links

v3.4.9 - 2023-04-26

26 Apr 18:55
f867cb3
Compare
Choose a tag to compare

Enhancements

  • #10987 - Show peer racks as a dropdown list under rack view
  • #11386 - Introduce CSRF_COOKIE_SECURE, SECURE_SSL_REDIRECT, and SESSION_COOKIE_SECURE configuration parameters
  • #11623 - Hide PSK strings under wireless LAN & link views
  • #12205 - Sanitize rendered custom links to mitigate malicious links
  • #12226 - Enable setting user name & email values via remote authenticate headers
  • #12337 - Enable anonymized reporting of census data

Bug Fixes

  • #11383 - Fix ordering of global search results by object type
  • #11902 - Fix import of inventory items for devices with duplicated names
  • #12238 - Improve error message for API token IP prefix validation failures
  • #12255 - Restore the ability to move inventory items among devices
  • #12270 - Fix pre-population of list values when creating a saved filter
  • #12296 - Fix "mark connected" form field for bulk editing front & rear ports

v3.5-beta2 - 2023-04-18

18 Apr 13:36
Compare
Choose a tag to compare
Pre-release

Bug Fixes (From Beta1)

  • #12103 - Limit the types of objects available for object count & list widgets
  • #12105 - Prevent data sources from becoming stuck in "syncing" status when an exception is raised
  • #12106 - Fix exception when saving dashboard widget with minimum width/height
  • #12108 - Limit the draggable area of widgets to their headers
  • #12109 - Fix migration error when replicating more than 100 job results
  • #12112 - Do not link data source URL for local paths
  • #12115 - Fix rendering config templates from a data file
  • #12144 - Ensure consistent treatment of context data when rendering config templates via UI & API
  • #12145 - Employ HTMXSelect widget to fix inclusion of <select> field values during form regeneration
  • #12146 - Do not display object selector for disabled fields
  • #12151 - Remove incorrect OpenAPI string mapping for choice fields
  • #12167 - Catch and report on exceptions raised when rendering a config template

v3.4.8 - 2023-04-12

12 Apr 19:30
3c91331
Compare
Choose a tag to compare

Enhancements

  • #10414 - Enable general purpose image attachments for device types
  • #10600 - Allow custom object fields to reference a user or group
  • #11015 - Remove unit from commit rate column header in circuits table
  • #11431 - Disallow changing custom field type after creation
  • #11453 - Display a warning banner when DEBUG is enabled
  • #12007 - Enable filtering of VM Interfaces by assigned VLAN
  • #12095 - Specify UTF-8 encoding for default export template MIME type
  • #12207 - Introduce the grant_token permission for controlling the creation of API tokens on behalf of other users

Bug Fixes

  • #10221 - Validate generic foreign key relations assigned via REST API requests
  • #11432 - Prevent existing components & component templates from being reassigned to different devices/device types via the REST API
  • #11454 - Raise validation error if generic foreign key assignment does not specify both object type and ID
  • #11746 - Fix cleanup of object data when deleting a custom field
  • #12011 - Fix KeyError exception when attempting to add module bays in bulk
  • #12040 - Display relevant UI tab upon bulk import validation failure
  • #12074 - Fix the automatic assignment of racks to devices via the REST API
  • #12084 - Fix exception when attempting to create a saved filter for applied filters
  • #12087 - Fix bulk editing of many-to-many relationships
  • #12117 - Hide clone button for objects with no clonable attributes
  • #12118 - Fix instantiation of nested inventory item templates when creating a device
  • #12184 - Fix filtered bulk deletion for various models
  • #12190 - Fix form layout for plugin textarea fields
  • #12227 - Fix tenant assignment on bulk import of L2VPNs

v3.5-beta1 - 2023-03-30

30 Mar 19:58
Compare
Choose a tag to compare
Pre-release

Breaking Changes

  • The JobResult model has been moved from the extras app to core and renamed to Job. Accordingly, its REST API endpoint has been moved from /api/extras/job-results/ to /api/core/jobs/.
  • The obj_type field on the Job model (previously JobResult) has been renamed to object_type for consistency with other models.
  • The JOBRESULT_RETENTION configuration parameter has been renamed to JOB_RETENTION.
  • The REST API schema is now generated using the OpenAPI 3.0 spec
  • The URLs for the REST API schema documentation have changed:
    • /api/docs/ is now /api/schema/swagger-ui/
    • /api/redoc/ is now /api/schema/redoc/

New Features

Customizable Dashboard (#9416)

The static home view has been replaced with a fully customizable dashboard. Users can construct and rearrange their own personal dashboard to convey the information most pertinent to them. Supported widgets include object statistics, configurable object lists, RSS feeds, and notes, and we expect to continue adding new widgets over time.

Remote Data Sources (#11558)

NetBox now has the ability to synchronize arbitrary data from external sources through the new DataSource and DataFile models. Synchronized files are stored in the PostgreSQL database, and may be referenced and consumed by other NetBox models, such as export templates and config contexts. Currently, replication from local filesystem paths, git repositories, and Amazon S3 buckets is supported, and we expect to introduce additional backends in the near future.

Configuration Template Rendering (#11559)

This release introduces the ability to render device configurations from Jinja2 templates natively within NetBox, via both the UI and REST API. The new ConfigTemplate model stores template code (which may be defined locally or sourced from remote data files). The rendering engine passes data gleaned from both config contexts and request parameters to generate complete configurations suitable for direct application to network devices.

NAPALM Plugin (#10520)

The NAPALM integration feature found in previous NetBox releases has been moved from the core application to a dedicated plugin. This allows greater control over the feature's configuration and will unlock additional potential as a separate project.

ASN Ranges (#8550)

A new ASN range model has been introduced to facilitate the provisioning of new autonomous system numbers from within a prescribed range. For example, an administrator might define an ASN range of 65000-65099 to be used for internal site identification. This includes a REST API endpoint suitable for automatic provisioning, very similar to the allocation of available prefixes and IP addresses.

Provider Accounts (#9047)

A new model has been introduced to represent individual accounts within a common circuit provider. This replaces the account field on the provider model, enabling users to track multiple accounts per provider. New provider account instances will be created automatically during upgrade for all providers which currently have an account assigned. The assignment of individual circuits to a provider account remains optional.

Job-Triggered Webhooks (#8958)

Two new webhook trigger events have been introduced: job_start and job_end. These enable users to configure webhook to trigger when a background job starts or ends, respectively. This new functionality can be used, for example, to inform a remote system when a custom script has been executed.

Enhancements

  • #7947 - Enable marking IP ranges as fully utilized
  • #8184 - Employ HTMX to dynamically render tables listing related objects
  • #8272 - Support bridge relationships among device type interfaces
  • #8749 - Support replicating custom field values when cloning an object
  • #9073 - Enable syncing config context data from remote sources
  • #9653 - Enable setting a default platform for device types
  • #10054 - Introduce advanced object selector for UI forms
  • #10242 - Redirect to filtered objects list after bulk import
  • #10374 - Require unique tenant names & slugs per group
  • #10729 - Add date & time custom field type
  • #11254 - Introduce the X-Request-ID HTTP header to annotate the unique ID of each request for change logging
  • #11291 - Optimized GraphQL API request handling
  • #11440 - Add an enabled field for device type interfaces
  • #11494 - Enable filtering objects by create/update request IDs
  • #11517 - Standardize the inclusion of related objects across the entire UI
  • #11584 - Add a list view for contact assignments
  • #11625 - Add HTMX support to ObjectEditView
  • #11693 - Enable syncing export template content from remote sources
  • #11780 - Enable loading import data from remote sources
  • #11790 - Create database indexes for all generic foreign keys
  • #11968 - Add navigation menu buttons to create device & VM components
  • #12068 - Enable generic foreign key relationships from jobs to NetBox objects
  • #12085 - Add a file source view for reports

Other Changes

  • #10604 - Remove unused extra_tabs block from object.html generic template
  • #10923 - Remove unused NetBoxModelCSVForm class (replaced by NetBoxModelImportForm)
  • #11489 - Consoldated several middleware classes
  • #11611 - Refactor API viewset classes and introduce NetBoxReadOnlyModelViewSet
  • #11694 - Remove obsolete SmallTextarea form widget
  • #11737 - ChangeLoggedModel now inherits WebhooksMixin
  • #11765 - Retire the StaticSelect and StaticSelectMultiple form widgets
  • #11955 - Remove the unused CSVDataField and CSVFileField classes
  • #12067 - Move & rename extras.JobResult to core.Job

v3.4.7 - 2023-03-28

28 Mar 18:08
Compare
Choose a tag to compare

Enhancements

  • #11645 - Automatically set the scheduled time when executing reports/scripts at a recurring interval
  • #11833 - Add fieldset support for custom script forms
  • #11973 - Use SSID for representing wireless links, if set
  • #11977 - Support designating multiple backends via REMOTE_AUTH_BACKEND config parameter
  • #11990 - Improve error reporting for duplicate CSV column headings
  • #11991 - Enable VDC assignment during bulk import/edit of interfaces

Bug Fixes

  • #11914 - Include parameters when exporting saved filters
  • #11933 - Fix cloning of saved filters
  • #11984 - Remove erroneous 802.3az PoE type
  • #11979 - Correct URL for tags in route targets list
  • #12008 - Enable cloning of export templates
  • #12029 - Restore missing description field on virtual chassis form
  • #12038 - Correct display of zero values for virtual chassis member priority
  • #12048 - Enable cloning of tags
  • #12058 - Enable cloning of config contexts

v3.4.6 - 2023-03-13

13 Mar 15:56
6b6ea36
Compare
Choose a tag to compare

Enhancements

  • #10058 - Enable searching for devices/VMs by primary IP address
  • #11011 - Add ability to toggle visibility of virtual interfaces under device view
  • #11294 - Enable live preview of Markdown content
  • #11807 - Restore default page size when navigating between views
  • #11817 - Add connected_endpoints field to GraphQL API for cabled objects
  • #11851 - Include IP version in GraphQL API representations of aggregates, prefixes, and IP addresses
  • #11862 - Add Cisco StackWise 1T interface type
  • #11871 - Add IEEE 802.3az PoE type for interfaces
  • #11929 - Strip whitespace from CSV headers prior to validation

Bug Fixes

  • #11470 - Avoid raising exception when filtering IPs by an invalid address
  • #11565 - Apply custom field defaults to IP address created during FHRP group creation
  • #11631 - Fix filtering changelog & journal entries by multiple content type IDs
  • #11758 - Support non-URL-safe characters in plugin menu titles
  • #11796 - When importing devices, restrict rack by location only if the location field is specified
  • #11819 - Fix filtering of cable terminations by object type
  • #11850 - Fix loading of CSV files containing a byte order mark
  • #11903 - Fix escaping of return URL values for action buttons in tables
  • #11927 - Correct loading of plugin resources with custom paths