Skip to main content

NetBox plugin for device maintenance management with comprehensive REST API and Portuguese-BR support

Project description

NetBox Maintenance Device Plugin

NetBox PyPI PyPI Downloads Language

A comprehensive NetBox plugin for managing device preventive and corrective maintenance with enhanced visual indicators, scheduling capabilities, and multi-language support.

Upcoming & Overdue Maintenance

Features

  • Maintenance Plans: Create and manage maintenance plans for devices and virtual machines with configurable frequency
  • Virtual Machine Support: Plans can target either a dcim.Device or a virtualization.VirtualMachine, with the same UX on both detail pages (#14)
  • Calendar-based Scheduling: Schedule every N days / weeks / months / quarters / years, with an optional calendar anchor to avoid drift — e.g. "1st day of every month" or "start of each quarter" stays aligned with the calendar regardless of when previous executions happened (#15)
  • Maintenance Executions: Record and track maintenance executions with status monitoring
  • Device & VM Integration: View maintenance history directly on device and VM pages with dedicated tabs
  • Quick Actions: Schedule and complete maintenance directly from the interface
  • Upcoming & Overdue Dashboard: Filter by status (Overdue / Due Soon / Upcoming / On Track), maintenance type, and target type (Device / VM)
  • REST API: Complete REST API for external integrations and automation
  • Advanced Filtering: Powerful filtering and search capabilities
  • Custom Actions: Schedule, complete, and cancel maintenance via API
  • Statistics: Get maintenance statistics and overdue/upcoming reports

Compatibility

NetBox Version Plugin Support Notes
4.6.x Tested & Supported Current target version
4.5.x Tested & Supported Fully compatible
4.4.x Tested & Supported Fully compatible
4.3.x Likely Compatible Not officially tested
4.2.x Likely Compatible Not officially tested
4.1.x Likely Compatible Not officially tested
4.0.x Likely Compatible Not officially tested
3.x Not Supported Breaking changes

Note: This version (v1.4.1) is specifically tested and certified for NetBox 4.4.x, 4.5.x, and 4.6.x. While it may work with other 4.x versions, we recommend testing in a development environment first.

Python Requirements: NetBox 4.5.x and 4.6.x require Python 3.12, 3.13, or 3.14. NetBox 4.6.x also runs on Django 6.0. If you're using NetBox 4.4.x or earlier, you can use Python 3.8+.

Installation

Method 1: PyPI Installation (Recommended)

Now officially available on PyPI!

# Install the latest version
pip install netbox-maintenance-device

# Or install a specific version
pip install netbox-maintenance-device==1.4.1

For Docker deployments, add to your plugin_requirements.txt:

echo "netbox-maintenance-device>=1.4.1" >> plugin_requirements.txt

Method 2: GitHub Installation

# Install from GitHub (development version)
pip install git+https://github.com/diegogodoy06/netbox-maintenance-device.git

Method 3: Docker Installation

For Docker-based NetBox installations using netbox-docker:

📋 For detailed Docker installation instructions in English and Portuguese, see DOCKER_INSTALL.md

Configuration

Basic Configuration

Add the plugin to your NetBox configuration.py:

# configuration.py

PLUGINS = [
    'netbox_maintenance_device',
    # ... other plugins
]

# Optional: Plugin-specific settings
PLUGINS_CONFIG = {
    'netbox_maintenance_device': {
        # Future configuration options will be added here
        # Currently, the plugin uses default settings
    }
}

Language Configuration (Optional)

To enable Portuguese-BR by default:

# configuration.py

# Enable internationalization
USE_I18N = True
USE_L10N = True

# Set default language
LANGUAGE_CODE = 'pt-br'
TIME_ZONE = 'America/Sao_Paulo'

# Available languages
LANGUAGES = [
    ('en', 'English'),
    ('pt-br', 'Português (Brasil)'),
]

Restart Services

Restart your NetBox services:

# For systemd
sudo systemctl restart netbox netbox-rq

# For Docker
docker compose restart netbox netbox-worker

Usage

For detailed usage instructions, please refer to the USAGE.md guide, which includes:

  • Creating and managing maintenance plans
  • Scheduling and completing maintenance
  • Monitoring maintenance status
  • Using the REST API
  • Troubleshooting common issues

Quick Start:

  1. Create maintenance plans for your devices
  2. View upcoming/overdue maintenance in the dashboard
  3. Use quick action buttons to schedule or complete maintenance
  4. Monitor device-specific maintenance on device pages

Screenshots

Device Maintenance Section

View maintenance plans and status directly on device pages

Device Maintenance

Upcoming Maintenance Dashboard

Monitor all upcoming and overdue maintenance across your infrastructure

Upcoming Maintenance

Maintenance Plan Management

Create and manage maintenance plans with flexible scheduling

Maintenance Plans


🤝 Contributing

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

📄 License

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

🙏 Acknowledgments

  • NetBox community for the excellent platform
  • Contributors and users providing feedback

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_maintenance_device-1.4.1.tar.gz (54.2 kB view details)

Uploaded Source

Built Distribution

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

netbox_maintenance_device-1.4.1-py3-none-any.whl (59.0 kB view details)

Uploaded Python 3

File details

Details for the file netbox_maintenance_device-1.4.1.tar.gz.

File metadata

File hashes

Hashes for netbox_maintenance_device-1.4.1.tar.gz
Algorithm Hash digest
SHA256 d18f676723f2492b0075a7d2584362210b573f0ae044df974d1091a391380530
MD5 4e0ea89d6c46e503d57de561c22af2d6
BLAKE2b-256 87811cd0ec25769a2b00e9bd2d88bcc8de84fcb65a91f55b714da86c959f9d35

See more details on using hashes here.

File details

Details for the file netbox_maintenance_device-1.4.1-py3-none-any.whl.

File metadata

File hashes

Hashes for netbox_maintenance_device-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1a519ca1c6139c8b7271e84aa9dfa1f956e465f67f11800f87c4b719fb7a3cfe
MD5 2ba8d697b7bcb990051c068cd541e7cf
BLAKE2b-256 c6be37633e6e0d2b1ffbb9195d847fb7f1dda6291896f463bd64fbaa8768d9f3

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