Skip to main content

Dynamically reload NetBox plugins without server restart

Project description

NetBox Plugin Reloader

A NetBox plugin that dynamically reloads plugins without requiring a server restart. This plugin ensures that NetBox properly registers all plugin models and form fields that might have been missed during the initial application startup.

Features

  • Dynamically registers plugin models that were missed during server startup
  • Refreshes custom field form definitions to include newly registered models
  • Refreshes tag form definitions to include newly registered models
  • Prevents duplicate view tab registrations caused by dynamic model plugins
  • Helps solve integration issues between NetBox and other plugins
  • No configuration required - works out of the box

Compatibility Matrix

NetBox Version Plugin Version
4.2.x 0.0.2
4.3.x 4.3.x
4.4.x 4.4.x
4.5.0 - 4.5.3 4.5.0.1
4.5.4+ 4.5.4.x

Version Format: X.X.Y.Z where X.X = NetBox major.minor version (e.g., 4.5), Y = NetBox patch version (e.g., 0), and Z = plugin release increment

Installation

The plugin is available as a Python package on PyPI and can be installed with pip:

pip install netbox-plugin-reloader

To enable the plugin, add it to the PLUGINS list in your configuration.py:

PLUGINS = [
    'other_plugin',
    'another_plugin',
    'netbox_plugin_reloader',  # Always add netbox_plugin_reloader last!
]

After installing the plugin:

  1. Restart NetBox:

    sudo systemctl restart netbox
    
  2. Ensure that netbox-plugin-reloader is included in your local_requirements.txt if you're using the official NetBox installation method.

For more details, see the NetBox Documentation.

Important Note

netbox_plugin_reloader must be the last item in your PLUGINS list! This ensures that it can properly detect and register all models from other plugins that may have been missed during the initial startup process.

How It Works

When NetBox starts, Plugin Reloader:

  1. Scans all enabled plugins for models that aren't properly registered in NetBox's feature registry
  2. Registers any missed models with NetBox's registration system
  3. Deduplicates view registrations (e.g. Journal, Changelog tabs) that may have accumulated due to dynamic model plugins regenerating model classes during startup
  4. Refreshes custom field form definitions to ensure they include all registered models
  5. Refreshes tag form definitions to ensure they include all registered models

This helps resolve issues where plugins might not fully integrate with NetBox due to load order problems without requiring a server restart. The reloader specifically updates custom field choices and tag choices to include newly registered plugin models.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the Apache License 2.0 - see the LICENSE file for details.

Author

Jan Krupa jan.krupa@cesnet.cz

Links

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

netbox_plugin_reloader-4.5.4.1.tar.gz (7.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

netbox_plugin_reloader-4.5.4.1-py3-none-any.whl (8.2 kB view details)

Uploaded Python 3

File details

Details for the file netbox_plugin_reloader-4.5.4.1.tar.gz.

File metadata

  • Download URL: netbox_plugin_reloader-4.5.4.1.tar.gz
  • Upload date:
  • Size: 7.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for netbox_plugin_reloader-4.5.4.1.tar.gz
Algorithm Hash digest
SHA256 15ee04bab4f51e39d597da26976a6daf3295e9e56233af95360923e24885786a
MD5 bb4166e7042bce308fb57ba71ba34046
BLAKE2b-256 dc4ab59fbfedfa2145463036cbdc3f323c471c08f5d9a4311d267fb6a8ac2875

See more details on using hashes here.

File details

Details for the file netbox_plugin_reloader-4.5.4.1-py3-none-any.whl.

File metadata

File hashes

Hashes for netbox_plugin_reloader-4.5.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ae8cab8e6076d6b423251a55729c3f17a6b401f10b46dfe0424fe75ead3e8232
MD5 8a51af4867647bf7a7577c64f5e1e050
BLAKE2b-256 f61d91ec9562aaf57fd4c78e2001f384db8d23e12eb9b7aa541ef745559cb8ea

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page