A topology visualization plugin for Nautobot powered by NextUI Toolkit.
Project description
Nautobot UI Plugin
A topology visualization plugin for Nautobot powered by NextUI Toolkit. Tested with Nautobot 2.0.0.
Installation
General installation steps and considerations follow the official guidelines.
Package Installation from PyPi
Assuming you use a Virtual Environment for Nautobot:
$ source /opt/nautobot/venv/bin/activate
(venv) $ pip3 install nautobot-ui-plugin
Package Installation from Source Code
The source code is available on our GitLab.
Download and install the package. Assuming you use a Virtual Environment for Nautobot:
$ git clone https://gitlab-ce.gwdg.de/gwdg-netz/nautobot-plugins/nautobot-ui-plugin
$ cd nautobot-ui-plugin
$ source /opt/nautobot/venv/bin/activate
(venv) $ pip3 install .
To ensure Nautobot UI plugin is automatically re-installed during future upgrades, create a file named local_requirements.txt
(if not already existing) in the Nautobot root directory (alongside requirements.txt
) and list the nautobot-ui-plugin
package:
# echo nautobot-ui-plugin >> local_requirements.txt
Enable the Plugin
In a global Nautobot configuration.py configuration file, update or add PLUGINS parameter:
PLUGINS = [
'nautobot_ui_plugin',
]
Optionally, update a PLUGINS_CONFIG parameter in configuration.py to rewrite default plugin behavior:
#PLUGINS_CONFIG = {
# 'nautobot_ui_plugin': {
# 'layers_sort_order': (
# ADD YOUR SETTINGS HERE
# layer_sort_order is a tuple
# ),
# 'icon_model_map': {
# ADD YOUR SETTINGS HERE
# icon_model_map is a dict
# },
# 'icon_role_map': {
# ADD YOUR SETTINGS HERE
# icon_role_map is a dict
# }
# 'undisplayed_role_ids': (
# # ADD YOUR SETTINGS HERE
# undisplayed_role_ids value is a list or a tuple
# Listed device role ids are hidden on initial view load,
# you may then hide/display any layer with a control button.
# ),
# 'undisplayed_device_tags': (
# ADD YOUR SETTINGS HERE
# undisplayed_device_tags value is a list or a tuple of regex strings.
# Devices with tags matching any of listed regular expressions are hidden
# on initial view load, you may then hide/display any layer with a control button.
# ),
# 'select_layers_list_include_device_tags': (
# ADD YOUR SETTINGS HERE
# select_layers_list_include_device_tags value is a list or a tuple of regex strings.
# Use this parameter to control tags listed in Select Layers menu.
# If specified, it works as allow list.
# ),
# 'select_layers_list_exclude_device_tags': (
# ADD YOUR SETTINGS HERE
# select_layers_list_exclude_device_tags value is a list or a tuple of regex strings.
# Use this parameter to control tags listed in Select Layers menu.
# If specified, it filters out matched tags from the list, except ones mathcing 'undisplayed_device_tags'.
# ),
# 'DISPLAY_PASSIVE_DEVICES': True|False,
# 'DISPLAY_LOGICAL_MULTICABLE_LINKS': True|False,
# 'DISPLAY_UNCONNECTED': True|False,
# 'INITIAL_LAYOUT': 'vertical'|'horizontal'|'auto'
# }
#}
By default, the Plugin orders devices on a visualized topology based their roles in Nautobot device attributes.
This order may be controlled by 'layers_sort_order' parameter. Default sort order includes most commonly used naming conventions:
(
'undefined',
'outside',
'border',
'edge',
'edge-switch',
'edge-router',
'core',
'core-router',
'core-switch',
'distribution',
'distribution-router',
'distribution-switch',
'leaf',
'spine',
'access',
'access-switch',
)
By default, the Plugin automatically tries to identify the device icon type based on following logic:
- 'icon_{icon_type}' tag in the Nautobot Device tags. Assign a tag to the device to manually control the displayed icon type (e.g. 'icon_router' or 'icon_switch'). Supported icon types:
{
'switch',
'router',
'firewall',
'wlc',
'unknown',
'server',
'phone',
'nexus5000',
'ipphone',
'host',
'camera',
'accesspoint',
'groups',
'groupm',
'groupl',
'cloud',
'unlinked',
'hostgroup',
'wirelesshost',
}
- If no valid 'icon_{icon_type}' tags found, the Plugin checks the default icon to device_type mapping. You can control this behavior with 'icon_model_map' dict. The Plugin checks for substring in a full device_type attribute. Default mapping:
{
'CSR1000V': 'router',
'Nexus': 'switch',
'IOSXRv': 'router',
'IOSv': 'switch',
'2901': 'router',
'2911': 'router',
'2921': 'router',
'2951': 'router',
'4321': 'router',
'4331': 'router',
'4351': 'router',
'4421': 'router',
'4431': 'router',
'4451': 'router',
'2960': 'switch',
'3750': 'switch',
'3850': 'switch',
'ASA': 'firewall',
}
Keys are searched substrings. Values should be valid icon types as listed above.
- If no match found on steps 1-2, the Plugin checks the Device Role id to Icon mapping.
This mapping may be defined within 'icon_role_map' dict in Plugin parameters.
Default mapping already contains some general categories:
{
'border': 'router',
'edge-switch': 'switch',
'edge-router': 'router',
'core-router': 'router',
'core-switch': 'switch',
'distribution': 'switch',
'distribution-router': 'router',
'distribution-switch': 'switch',
'leaf': 'switch',
'spine': 'switch',
'access': 'switch',
'access-switch': 'switch',
}
- Default value is 'unknown' (renders as a question mark icon).
The Plugin can control the visibility of the layers and/or specific nodes on the topology view.
The visibility control is currently implemented for specific device roles, device tags, unconnected devices, and passive devices:
-
Initial visibility behavior for specific device roles is controlled by 'undisplayed_role_ids' plugin parameter. Listed device role ids are hidden on initial view load, you may then hide/display any layer with a control button on the topology view page.
-
Initial visibility behavior for specific device tags is controlled by 'undisplayed_device_tags' plugin parameter. Devices with tags matching listed tag regular expressions are hidden on initial view load, you may then hide/display any layer with a control button on the topology view page.
By default, the plugin lists all discovered device tags in Select Layers menu. You can use 'select_layers_list_include_device_tags' and 'select_layers_list_exclude_device_tags' plugin parameters to filter the included tags.
All three tag visibility control parameters are optional lists of regular expressions. Tags matching 'undisplayed_device_tags' are always listed in Select Layers menu. Empty or unset 'select_layers_list_include_device_tags' allows all discovered tags to be listed in Select layers menu. If set, 'select_layers_list_include_device_tags' works as an allow list for matched tags. 'select_layers_list_exclude_device_tags' filters out matched tags from the list, excpept for ones matching 'undisplayed_device_tags'. -
Initial visibility behavior for unconnected nodes is controlled by DISPLAY_UNCONNECTED boolean plugin parameter.
By default, unconnected nodes are being displayed. Set DISPLAY_UNCONNECTED to False to hide them on initial topology view load.
A separate 'Hide/Display Unconnected' button may then be used to hide or display those nodes. -
Initial visibility for passive devices (patch panels, PDUs) is controlled by DISPLAY_PASSIVE_DEVICES boolean plugin parameter. A device is considered passive if it has cables connected to Front and Rear Ports only and not to Interfaces.
Passive devices are hidden by default. You can display them with 'Display Passive Devices' button on the topology view page.
Actual multi-cable connections between the end-devices a replaced by the direct logical connection once the passive devices are hidden. This logical direct link may be displayed regardless of the passive device visibility in addition to the cabling across patch panels if you set DISPLAY_LOGICAL_MULTICABLE_LINKS plugin parameter to True. DISPLAY_LOGICAL_MULTICABLE_LINKS is set to False by default. This parameter only affects the initial logical link visibility. With hidden passive devices, it is always being displayed.
Device layers are ordered automatically by default. You can control this behavior with INITIAL_LAYOUT plugin parameter. Valid options are 'vertical', 'horizontal', and 'auto'.
'auto' layout relies on NeXt UI dataprocessor best-effort algorithms. It spreads the Nodes across the view so they would be as distant from each other as possible. You may use it if the vertical and horizontal initial layout does not work properly in your browser (this is the issue to be fixed).
Collect Static Files
The Plugin contains static files for topology visualization. They should be served directly by the HTTP frontend. In order to collect them from the package to the Nautobot static root directory use the following command:
(venv) $ cd /opt/nautobot
(venv) $ nautobot-server collectstatic
Apply Database Migrations
For plugin version 0.8.0 and above.
Apply database migrations:
(venv) $ nautobot-server migrate
Restart Nautobot
Restart the WSGI service to apply changes:
sudo systemctl restart nautobot
Fixing Common Installation and Post-Upgrade Issues
If you are experiencing some unexpected errors or visual behaviors after the installation or upgrade, please make sure that you execute the following steps first:
- Clear your browser cache and reload the page.
- Re-collect static files:
(venv) $ python3 manage.py collectstatic --clear
. - Re-apply database migrations:
(venv) $ python3 manage.py migrate
.
Usage
Once installed and initialized, the Plugin runs on a backend.
The Plugin supports a topology visualization of arbitrary sets of Locations.
You can access Topology visualizations in different ways:
-
By clicking a custom plugin Topology button on a Location page. The Location topology visualization will open in a pop-up window:
Nodes are draggable and clickable:
You can switch between vertical and horizontal layers sort order back and forth. Default is vertical. -
Using Plugins dropdown menu item: Plugins -> Nautobot UI -> Topology Viewer.
Use Search form controls to pick desired Locations or Devices.
Visibility control
You can display or hide any specific device roles on the topology view with 'Select Layer' button:
The list of available device roles is generated automatically based on discovered devices for a visualized location.
'Display/Hide Unconnected' button hides or displays the devices with no links attached.
'Display/Hide Passive Devices' buttons hides or displays the passive devices (patch pannels, PDUs, etc).
In a samples below, edge-sw01 is connected with core-rtr01 and core-rtr02 through Patch Panel A and Patch Panel B with multiple cable hops:
Once you hide the passive devices (default state), a logical direct link shows up between the edge switch and the core routers:
If DISPLAY_LOGICAL_MULTICABLE_LINKS is set to True (default is False) this logical link is displayed initially:
Required Nautobot User Permissions
The Plugin requires the following user permissions to access the topology view:
- dcim | location | Can read location
- dcim | device | Can view device
- dcim | cable | Can view cable
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file nautobot_ui_plugin-1.0.0.tar.gz
.
File metadata
- Download URL: nautobot_ui_plugin-1.0.0.tar.gz
- Upload date:
- Size: 1.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2210e472330ad982a11303098b552984e7b66a9765b5bcae11b57f6e8a45ea37 |
|
MD5 | fa5b5f96da50e400e681af45602a8981 |
|
BLAKE2b-256 | 21a1342cb30980cd49674e00d7b51cfa5315979c9535a57f5a9ef72e9bdc6101 |