Skip to main content

Unified out-of-band management for NetBox: Redfish & IPMI inventory sync, power control, console access

Project description

netbox-bmc

NetBox Python License

日本語

Unified out-of-band management plugin for NetBox.
Inventory sync and power control via Redfish & IPMI.

Supported Protocols / Vendors

Protocol Vendors
Redfish Dell iDRAC, HPE iLO, Lenovo XCC, Supermicro, AMI, Generic
IPMI Fallback for any IPMI-capable BMC

Protocol is auto-detected: probes /redfish/v1 first, falls back to IPMI on failure.

Tested Hardware

Manufacturer Model Series BMC Protocol Status
Dell PowerEdge iDRAC 9 Redfish Expected to work
HPE ProLiant iLO 5 Redfish Expected to work
HPE ProLiant iLO 6 Redfish Expected to work
Lenovo ThinkSystem XCC2 / XCC3 Redfish Expected to work
Supermicro X12 / X13 BMC Redfish Expected to work
AMI ASMB-based servers AMI Redfish Server Redfish Expected to work
Generic Any IPMI-capable BMC IPMI Expected to work (fallback)

Features

  • Module Builder: Sync BMC hardware inventory to NetBox Modules
    • Scan via Redfish → preview detected components with diff badges (new / updated / unchanged / removed)
    • Select individual components before applying
    • Auto-create ModuleBays when missing (warned in preview)
    • Detect serial number changes after FRU replacement and apply diff updates
    • Only manages bmc-synced-tagged Modules; never touches manually created Modules
  • Collected components: CPU, Memory, Drive, PSU, Fan, Firmware, PCI devices
    • PSU and Fan collected via Chassis link; PCIe via PCIeDevices collection
  • Vendor auto-detection: Dispatches to Dell / HPE / Lenovo subclass drivers based on ServiceRoot Vendor / Oem keys
  • Power control: on / off / soft / cycle / reset (both protocols)

Install

Standard (non-Docker)

pip install netbox-bmc
python manage.py migrate

Add to configuration.py:

PLUGINS = ["netbox_bmc"]
PLUGINS_CONFIG = {
    "netbox_bmc": {
        "sync_interval_minutes": 0,
        "default_verify_ssl": False,
    },
}

Docker (netbox-docker)

Follow the official plugin installation guide.

plugin_requirements.txt

netbox-bmc

Dockerfile-Plugins

FROM netboxcommunity/netbox:latest

COPY ./plugin_requirements.txt /opt/netbox/
RUN /usr/local/bin/uv pip install -r /opt/netbox/plugin_requirements.txt

docker-compose.override.yml

services:
  netbox:
    image: netbox:latest-plugins
    pull_policy: never
    build:
      context: .
      dockerfile: Dockerfile-Plugins
  netbox-worker:
    image: netbox:latest-plugins
    pull_policy: never

configuration/plugins.py

PLUGINS = ["netbox_bmc"]
PLUGINS_CONFIG = {
    "netbox_bmc": {
        "sync_interval_minutes": 0,
        "default_verify_ssl": False,
    },
}

Build and start:

docker compose build --no-cache
docker compose up -d

Configure

Edit PLUGINS_CONFIG["netbox_bmc"] in configuration.py:

Key Default Description
sync_interval_minutes 0 Scheduled bulk sync interval in minutes. 0 disables.
default_verify_ssl False Default SSL verification for new BMC Endpoints.
service_account Service account name for background jobs (netbox-secrets).
service_private_key_path Path to private key for service account (netbox-secrets).

Use

  1. Open a Device in NetBox and click BMC EndpointsAdd
  2. Enter the BMC address and credentials, then save
  3. On the Endpoint detail page, click [Build Modules]
  4. Review the component preview (new / updated / unchanged / removed)
  5. Check the components to sync and click [Apply Selected]

ModuleBays, ModuleTypes, and Modules are created or updated automatically.

Module Naming

Vendor-specific names are normalized to a consistent format:

Raw name (Redfish) Normalized
CPU.Socket.1 / Processor 0 CPU 0
DIMM.A1 / Memory 0 Memory 0
Disk.Bay.0 Drive 0
NIC.Slot.1 (PCIe) PCI 0

Custom Fields

The following custom fields are set automatically on each Module:

Field Content
bmc_redfish_path Source Redfish URI
bmc_firmware_version Firmware version string

Versions

netbox-bmc NetBox
0.4.x 4.5, 4.6

Vendor Notes

Dell iDRAC

iDRAC 9 (Redfish 1.x) is the primary target. URI traversal starts from ServiceRoot links — no hardcoded paths — so firmware variations should be absorbed automatically.

HPE iLO

iLO 5 and iLO 6 are supported via the HPE subclass driver. iLO 4 (Redfish 1.0 partial compliance) is not tested and may not work correctly.

Lenovo XCC

XCC2 and XCC3 are supported. Some older XCC firmware versions expose non-standard collection URIs; the link-traversal approach handles most variations.

Supermicro

Generic Redfish driver is used. Supermicro BMC firmware varies significantly; behaviour may differ across firmware versions.

AMI (American Megatrends)

AMI Redfish Server (detected via Vendor: "AMI" in ServiceRoot). PCIe devices are exposed under Chassis/PCIeDevices rather than Systems/PCIeDevices; the AMI subclass driver handles this automatically. Hardware inventory (CPU, Memory) populates only when the host is powered on.

Development

# Install dev dependencies
uv sync --extra dev

# Run tests
uv run pytest

Adding a New Vendor

  1. Add a subclass in netbox_bmc/drivers/redfish.py extending RedfishDriver
  2. Register it in detect_and_build() in netbox_bmc/drivers/base.py by matching ServiceRoot vendor keys
  3. Add unit tests in tests/test_redfish_extensions.py

Adding a New Protocol

Implement BaseDriver (netbox_bmc/drivers/base.py) and return InventoryResult from get_inventory().

Credentials

netbox-bmc resolves BMC credentials in the following order:

  1. netbox-secrets (preferred) — Secret with role bmc-credentials assigned to the Device.
    Secret.name = BMC username, Secret.plaintext = BMC password (RSA-encrypted).
  2. Plaintext fallbackusername / password fields on BMCEndpoint, used when netbox-secrets is not installed or no matching secret is found.

For background jobs (scheduled sync), set service_account and service_private_key_path in PLUGINS_CONFIG so the job can decrypt secrets without an HTTP session.

Known Limitations

  • REST API (serializers / viewsets) not yet implemented
  • Multi-node chassis (multiple Systems) not supported
  • Scheduled bulk sync (ScheduledInventorySyncJob) not yet implemented
  • KVM / SOL console not yet ported from the predecessor plugin
  • Old BMCs with low Redfish compliance (e.g. HPE iLO 4) not validated

License

Apache License 2.0 — see LICENSE.

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_bmc-0.4.1.tar.gz (41.5 kB view details)

Uploaded Source

Built Distribution

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

netbox_bmc-0.4.1-py3-none-any.whl (43.9 kB view details)

Uploaded Python 3

File details

Details for the file netbox_bmc-0.4.1.tar.gz.

File metadata

  • Download URL: netbox_bmc-0.4.1.tar.gz
  • Upload date:
  • Size: 41.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for netbox_bmc-0.4.1.tar.gz
Algorithm Hash digest
SHA256 548cb8f6343e177ec735dda5a6f4b772e56d38558ea3ea6d375287f421de1b67
MD5 e36499e6630b2df8805744f5bcb95f5b
BLAKE2b-256 32cb3a8228ac1315cefba3a201f8fd015e02650b609d9c54b86b8f3f9f19c9fb

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_bmc-0.4.1.tar.gz:

Publisher: publish-pypi.yaml on tak-labo/netbox-bmc

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file netbox_bmc-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: netbox_bmc-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 43.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for netbox_bmc-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 70a30a87faafeb603e3a4b39719ab52000ab74cf3f3dfb4317e06960c9b3917d
MD5 9f22f1fdb679e0d8070c599c75f10ddc
BLAKE2b-256 e6d3de83b8cf4e27022d7c217b546a6e738537289c751eda486c71c816cc61a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for netbox_bmc-0.4.1-py3-none-any.whl:

Publisher: publish-pypi.yaml on tak-labo/netbox-bmc

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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