Skip to main content

NetBox plugin for synchronizing Proxmox inventory data

Project description

Proxmox2NetBox

NetBox plugin for synchronizing Proxmox inventory data into NetBox (NetBox v4).

Compatibility

  • NetBox: >=4.2.0, <5.0.0
  • Python: >=3.8
  • Plugin package version in this repository: 1.1.4

What Works (Current Runtime)

Out-of-the-box sync requires only a configured Proxmox Endpoint in NetBox.

Implemented sync flows:

  • Proxmox nodes -> NetBox dcim.Device
  • Proxmox QEMU/LXC VMs -> NetBox virtualization.VirtualMachine
  • VM interfaces from Proxmox config -> NetBox virtualization.VMInterface
  • Endpoint metadata refresh (mode, version, repoid, cluster name)
  • Sync process tracking in SyncProcess

Runtime Architecture (Source of Truth)

Core sync logic is consolidated in:

  • proxmox2netbox/services/proxmox_sync.py

Backward-compatible import shim (kept intentionally):

  • proxmox2netbox/proxmox_sync.py

Primary runtime entrypoints:

  • UI endpoints: proxmox2netbox/views/sync.py
  • Connection/status badge: proxmox2netbox/views/keepalive_status.py
  • Proxmox card data: proxmox2netbox/views/cards.py
  • Job wrapper: proxmox2netbox/jobs.py (Proxmox2NetBoxSyncJob)

Installation (NetBox v4)

1. Install plugin package

Inside NetBox environment:

pip install proxmox2netbox

If you run netbox-docker, also pin the package in your Docker requirements file so it survives rebuilds/redeploys:

# local_requirements.txt
proxmox2netbox==1.1.4

2. Enable plugin

In NetBox configuration.py:

PLUGINS = ["proxmox2netbox"]

3. Run migrations/static

python manage.py migrate
python manage.py collectstatic --no-input

Configure and Run Sync

Configure Proxmox Endpoint

In NetBox UI:

  • Plugins -> Proxmox2NetBox -> Endpoints -> Proxmox Endpoints
  • Create at least one endpoint with:
    • username
    • either password or (token_name + token_value)
    • host via domain and/or ip_address

Run sync from UI

  • Plugins -> Proxmox2NetBox -> Full Update
  • Available actions:
    • Sync Nodes
    • Sync Virtual Machines
    • Full Update Sync

Run sync as NetBox Job (wrapper)

jobs.py provides a queue-compatible wrapper around the existing service layer.

Example from NetBox shell:

from proxmox2netbox.jobs import Proxmox2NetBoxSyncJob
from proxmox2netbox.choices import SyncTypeChoices

# Full sync
Proxmox2NetBoxSyncJob.enqueue(sync_type=SyncTypeChoices.ALL)

# Devices only
Proxmox2NetBoxSyncJob.enqueue(sync_type=SyncTypeChoices.DEVICES)

# Virtual machines only
Proxmox2NetBoxSyncJob.enqueue(sync_type=SyncTypeChoices.VIRTUAL_MACHINES)

Behavior note:

  • Job class is an orchestrator only.
  • Sync mapping, payloads, and upsert logic remain in services/proxmox_sync.py.

Development & Validation

Static checks

ruff check proxmox2netbox --select F401,F403,F811,F821,F841,E712
python -m compileall -q proxmox2netbox

Django checks (inside NetBox runtime)

python manage.py check
python manage.py makemigrations --check --dry-run

Tests

Current repository state contains no active pytest test modules.

pytest
# expected: no tests ran

Publish to PyPI

Prerequisites

  • You must have access to the proxmox2netbox project on PyPI.
  • If the name is unavailable for your account, change project.name in pyproject.toml to a unique name before publishing.
  • Configure one of these publish methods:
  • Add PYPI_API_TOKEN as a repository secret in GitHub, or
  • Configure a matching Trusted Publisher in PyPI for this GitHub repository/workflow:
  • Owner: patricklind
  • Repository: Proxmox2Netbox
  • Workflow file: .github/workflows/publish-python-package.yml
  • Environment name: pypi

Local preflight

python -m build
twine check dist/*

Publish via GitHub Actions

  • Bump version in pyproject.toml and plugin config version in source.
  • Create and push a tag:
git tag -a vX.Y.Z -m "Release vX.Y.Z"
git push origin vX.Y.Z
  • release.yml creates the GitHub Release from the tag and dispatches package publish.
  • publish-python-package.yml publishes to PyPI (release event and manual/dispatch supported).
  • After publish:
pip install proxmox2netbox

Repository Layout (Relevant Runtime Files)

proxmox2netbox/
  __init__.py
  jobs.py
  models/
  services/
    proxmox_sync.py
  proxmox_sync.py          # compatibility shim
  views/
    sync.py
    keepalive_status.py
    cards.py
  urls.py
  forms/
  filtersets.py
  tables/

Scope

This repository ships a NetBox plugin runtime only.
Legacy FastAPI/backend-service components are removed from runtime, docs, and packaging scope.

Wiki

  • GitHub Wiki URL: https://github.com/patricklind/Proxmox2Netbox/wiki
  • Wiki source files in this repository: wiki/

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

proxmox2netbox-1.2.5.tar.gz (3.1 MB view details)

Uploaded Source

Built Distribution

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

proxmox2netbox-1.2.5-py3-none-any.whl (3.1 MB view details)

Uploaded Python 3

File details

Details for the file proxmox2netbox-1.2.5.tar.gz.

File metadata

  • Download URL: proxmox2netbox-1.2.5.tar.gz
  • Upload date:
  • Size: 3.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for proxmox2netbox-1.2.5.tar.gz
Algorithm Hash digest
SHA256 ebd206df4f1a1acb014c4557c6f78324400ccbbb2e477b52e6ebb20d97339bc3
MD5 8c54a3e7d742d189fb6910d38ce7108a
BLAKE2b-256 d1134a8a633bf29956d8536479a7dd76a25ef3ec9931fa46f0a8df7a633bc9b1

See more details on using hashes here.

Provenance

The following attestation bundles were made for proxmox2netbox-1.2.5.tar.gz:

Publisher: publish-python-package.yml on patricklind/Proxmox2Netbox

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

File details

Details for the file proxmox2netbox-1.2.5-py3-none-any.whl.

File metadata

  • Download URL: proxmox2netbox-1.2.5-py3-none-any.whl
  • Upload date:
  • Size: 3.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for proxmox2netbox-1.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 2e47d7ecf8a9199b65b0353760060e31d1f1897efaa7f69d23c6f64b5654dc7b
MD5 0b7fc49bb1932587821f3efe81aaf9e3
BLAKE2b-256 59375a963dff6a43e902a10f7cef95dbd3c0a6316786cd28cc42ef5f230a07d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for proxmox2netbox-1.2.5-py3-none-any.whl:

Publisher: publish-python-package.yml on patricklind/Proxmox2Netbox

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