A simple device map plugin with filtering criteria for NetBox
Go to file
Seb Harrington edada1df35
Update helpers.py to use netbox long / lat fields.
updated helper function get_device_location to use netbox's native location fields
2024-04-20 21:25:38 +01:00
docs/images Initial commit 2022-05-26 09:53:13 +03:00
netbox_device_map Update helpers.py to use netbox long / lat fields. 2024-04-20 21:25:38 +01:00
.gitignore Initial commit 2022-05-26 09:53:13 +03:00
LICENSE Added license 2022-08-18 11:43:39 +03:00
MANIFEST.in Initial commit 2022-05-26 09:53:13 +03:00
README.md README.md: updated documentation URL for Leaflet, added requirements information. 2023-06-08 12:59:48 +03:00
requirements.txt NetBox v3.3 support 2022-08-26 15:07:35 +03:00
setup.py Release version 0.1.3. 2023-06-08 13:02:53 +03:00

NetBox device map

A simple device map plugin with filtering criteria for NetBox

Map screenshot Map filters screenshot

Installation

Requirements

The plugin has been tested and confirmed works on NetBox versions from 3.2 to 3.5 and Python versions from 3.10 to 3.11.

Steps

  1. If your NetBox installation uses virtualenv, activate it like this:
source /opt/netbox/venv/bin/activate
  1. Install the plugin.

To ensure plugin is automatically re-installed during future NetBox upgrades, create a file named local_requirements.txt (if not already existing) in the NetBox root directory and list the nextbox-plugin-device-map package:

  • Option A: if you want to install it from PyPI:
echo netbox-plugin-device-map | sudo tee -a /opt/netbox/local_requirements.txt
  • Option B: if you manually downloaded the plugin distribution from releases:
echo "/path/to/netbox-plugin-device-map.tar.gz" | sudo tee -a /opt/netbox/local_requirements.txt

Then run:

sudo pip install -U -r /opt/netbox/local_requirements.txt

to install the plugin.

  1. Collect static files:
sudo python /opt/netbox/netbox/manage.py collectstatic
  1. To enable plugin, add the plugin's name to the PLUGINS list in configuration.py (it's usually located in /opt/netbox/netbox/netbox/) like so:
PLUGINS = [
    'netbox_device_map'
]
  1. Restart NetBox WSGI service to apply changes:
sudo systemctl restart netbox

Configuration

You can customize plugin behavior according to your needs. For example, change the custom field that contains device coordinates or install custom map tiles. Update PLUGINS_CONFIG parameter in the configuration.py like this:

PLUGINS_CONFIG = {
    'netbox_device_map': {
        'device_geolocation_cf': 'coordinates',
        'cpe_device_role': 'CPE',
        'geomap_settings': {
            'attribution': '<a href="https://osm.yourdomain.net">Your company</a> | © <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors',
            'tiles': {
                'url_template': 'https://osm.yourdomain.net/hot/{z}/{x}/{y}.png',
                'options': {
                    'maxZoom': 19
                }
            }
        }
    }
}

Settings

Setting Default value Description
device_geolocation_cf geolocation NetBox custom field for storing geographical location of devices (in the "<latitude>,<longitude>" format)
cpe_device_role CPE Name of the NetBox device role that contains CPE devices
geomap_settings Geographical map settings

Geographical map settings

Setting Default value Description
attribution Data by &copy; <a href="https://openstreetmap.org">OpenStreetMap</a> Attribution text in the lower right corner of the map
crs EPSG3857 Coordinate reference system
tiles Tiles layer settings

Custom tiles layer settings:

Setting Example value Description
url_template https://{s}.somedomain.com/blabla/{z}/{x}/{y}{r}.png {s} means one of the available subdomains (used sequentially to help with browser parallel requests per domain limitation; subdomain values are specified in options; a, b or c by default, can be omitted), {z} — zoom level, {x} and {y} — tile coordinates. {r} can be used to add "@2x" to the URL to load retina tiles.
options {'subdomains' : ['a', 'b', 'c'], 'minZoom': 0, 'maxZoom': 18} Leaflet TileLayer options

Acknowledgements

Leaflet plugins