Skip to main content

Dell Rack & Asset Control System - CLI inventory tool for managing Dell bare-metal systems

Project description

DRACS — Dell Rack & Asset Control System

Run Tests Semantic Release Sync Back to Development PyPI version Python 3.13+ License: GPL v3

DRACS

Simple, portable, self-contained dynamic CLI inventory tool for managing Dell bare-metal systems inventory, warranty and lifecycle.

🚀 Features

  • Warranty Tracking: Automatically fetches expiration dates from the Dell API using Service Tags
  • Hardware Discovery: Uses SNMP to poll iDRAC and BIOS version information directly from the hardware
  • Data Refresh: Update both SNMP hardware data AND warranty information for existing systems
  • Version Comparison: List and filter systems based on version strings (e.g., find all hosts with BIOS version less than 2.1.0)
  • Flexible Output: View inventory in a formatted grid table or export to JSON for automation
  • Verbose Logging: Optional verbose (-v) and debug (-d) modes for detailed progress tracking
  • SQLite Backend: No heavy database setup required; everything is stored in a local .db file
  • Command Aliases: Short aliases for all commands (e.g., a for add, li for list, rf for refresh)

🛠️ Prerequisites

  • Python 3.12+
  • Dell TechDirect API Credentials: You must have a Client ID and Secret from Dell to access warranty data
  • SNMP Enabled: The target Dell systems must have SNMP enabled on their iDRACs (default community: public)
  • Network Access: Ability to reach Dell iDRAC interfaces via DNS (naming convention configured via DRACS_DNS_STRING and DRACS_DNS_MODE)

📦 Installation

1) Clone the repository:

git clone https://github.com/kambiz-aghaiepour/dracs.git
cd dracs

2) Install with uv:

uv sync

For development (includes pytest, black, etc.):

uv sync --group dev

Source the virtual environment

source .venv/bin/activate

3) Configure environment variables: Create a .env file in the root directory:

# Required: Dell TechDirect API credentials
CLIENT_ID=your_dell_client_id
CLIENT_SECRET=your_dell_client_secret

# Required: iDRAC DNS configuration
# DRACS_DNS_STRING: String to add to hostname for iDRAC FQDN
# DRACS_DNS_MODE: How to add the string ('prefix' or 'suffix')
#
# Examples:
# Prefix mode: "mgmt-" + "host01.example.com" = "mgmt-host01.example.com"
DRACS_DNS_STRING=mgmt-
DRACS_DNS_MODE=prefix
#
# Suffix mode: "host01" + "-mm" + ".example.com" = "host01-mm.example.com"
# DRACS_DNS_STRING=-mm
# DRACS_DNS_MODE=suffix

# Optional: SNMP community string (defaults to 'public')
SNMP_COMMUNITY=public

# Optional: Enable debug logging via environment (can also use -d flag)
DEBUG=false

Note: Obtain Dell API credentials from Dell TechDirect

📖 Usage

DRACS uses subcommands for different operations: add, discover, edit, lookup, list, refresh, and remove.

1. Add a New System

This polls the iDRAC for firmware/BIOS versions and the Dell API for warranty.

# Add a system (full command)
dracs add --svctag ABC1234 --target server01.example.com --model R660

# Using alias and verbose output
dracs -v a -s ABC1234 -t server01.example.com -m R660

# With custom database path
dracs -w /path/to/custom.db add -s ABC1234 -t server01 -m R650

2. Discover a System

Automatically discover service tag and model information via SNMP, then optionally add to database.

# Discover a system (prompts for confirmation)
dracs discover --target server01.example.com

# Using alias
dracs d -t server01.example.com

# Auto-add without prompting
dracs discover --target server01.example.com --add

# With verbose output
dracs -v discover -t server01.example.com

# Discover and auto-add using alias
dracs d -t server01.example.com --add

3. List Inventory

View all systems. You can filter by model, expiration, or version. Results are always sorted by hostname.

# List all systems
dracs list

# List all systems (using alias)
dracs li

# List systems by model
dracs list --model R660

# List systems expiring in the next 30 days (excludes already expired)
dracs list --expires_in 30

# List systems with expired warranties
dracs list --expired

# List systems with hostname matching a pattern
dracs list --regex "server%"

# Filter by BIOS version
dracs list --bios_lt 2.5.1        # BIOS less than 2.5.1
dracs list --bios_le 2.5.1        # BIOS less than or equal to 2.5.1
dracs list --bios_gt 2.5.1        # BIOS greater than 2.5.1
dracs list --bios_ge 2.5.1        # BIOS greater than or equal to 2.5.1
dracs list --bios_eq 2.5.1        # BIOS equal to 2.5.1

# Filter by iDRAC firmware version
dracs list --idrac_lt 6.10.30.00  # iDRAC less than 6.10.30.00
dracs list --idrac_ge 6.10.30.00  # iDRAC greater than or equal

# Output as JSON for automation
dracs list --json

# Output only hostnames (one per line) - useful for scripting
dracs list --host-only
dracs list --model R650 --host-only

# Complex filter: R660 systems with old BIOS expiring soon
dracs list --model R660 --bios_lt 2.5.0 --expires_in 60

# Lookup specific system in list format
dracs list --svctag ABC1234
dracs list --target server01.example.com

4. Lookup a Specific System

Retrieve detailed information about a single system.

# Lookup by service tag with all fields
dracs lookup --svctag ABC1234 --full

# Lookup by hostname
dracs lookup --target server01.example.com --full

# Show only BIOS version
dracs lookup --svctag ABC1234 --bios

# Show only iDRAC firmware version
dracs lookup -s ABC1234 --idrac

# Using alias
dracs l -t server01.example.com --full

5. Edit a System

Update specific fields in the database by re-polling hardware or changing model.

# Update both BIOS and iDRAC versions from SNMP
dracs edit --target server01.example.com --bios --idrac

# Update by service tag
dracs edit --svctag ABC1234 --bios --idrac

# Update only BIOS version
dracs edit -t server01 --bios

# Update only iDRAC firmware version
dracs edit -s ABC1234 --idrac

# Change model name
dracs edit -s ABC1234 --model R650

# Using alias with verbose output
dracs -v e -t server01 --bios --idrac

6. Refresh System Data

Refresh both SNMP data (BIOS/iDRAC versions) AND warranty information from Dell API. This is useful when service contracts are renewed or firmware is updated.

# Refresh by service tag
dracs refresh --svctag ABC1234

# Refresh by hostname
dracs refresh --target server01.example.com

# Using alias with verbose output to see progress
dracs -v rf -s ABC1234

# With debug output
dracs -d refresh -t server01

7. Remove a System

Delete a system from the database.

# Remove by service tag
dracs remove --svctag ABC1234

# Remove by hostname
dracs remove --target server01.example.com

# Using alias
dracs r -s ABC1234

Common Usage Patterns

# Initial setup: Add all your systems
dracs -v add -s ABC1234 -t server01.example.com -m R660
dracs -v add -s DEF5678 -t server02.example.com -m R650
dracs -v add -s GHI9012 -t server03.example.com -m R660

# Or discover and add systems automatically
dracs -v discover -t server04.example.com --add
dracs -v d -t server05.example.com --add

# Discover a system but confirm before adding
dracs discover -t server06.example.com

# Check what's expiring soon
dracs list --expires_in 30

# Check what has already expired
dracs list --expired

# Find systems that need firmware updates
dracs list --idrac_lt 6.10.30.00

# After updating firmware, refresh the data
dracs -v refresh -t server01.example.com

# After renewing support contracts, refresh warranty
dracs -v refresh -s ABC1234

# Generate JSON report for external tools
dracs list --json > inventory.json

# Get list of all hostnames for scripting (e.g., to feed to xargs or a loop)
dracs list --host-only > hostnames.txt
for host in $(dracs list --model R650 --host-only); do echo "Processing $host"; done

# Find all R660 models
dracs list --model R660

# Detailed troubleshooting with debug output
dracs -d add -s ABC1234 -t server01 -m R660

⚙️ Command Reference

Global Arguments (apply to all commands)

Argument Description
-h, --help Show help message and exit
-d, --debug Enable debug mode (most detailed output, includes SQL queries)
-v, --verbose Enable verbose output (shows INFO level progress messages)
-w, --warranty Path to a custom SQLite database file (defaults to warranty.db)

Command Aliases

Full Command Alias Required Arguments Optional Arguments
add a -s/--svctag -t/--target -m/--model None
discover d -t/--target --add
edit e -s/--svctag OR -t/--target --bios --idrac --model
lookup l -s/--svctag OR -t/--target --full --bios --idrac
list li None --model --regex --expires_in --expired --svctag --target --bios_* --idrac_* --json --host-only
refresh rf -s/--svctag OR -t/--target None
remove r -s/--svctag OR -t/--target None

Filter Options for list Command

BIOS Version Filters:

  • --bios_lt VERSION - BIOS less than VERSION
  • --bios_le VERSION - BIOS less than or equal to VERSION
  • --bios_gt VERSION - BIOS greater than VERSION
  • --bios_ge VERSION - BIOS greater than or equal to VERSION
  • --bios_eq VERSION - BIOS equal to VERSION

iDRAC Firmware Filters:

  • --idrac_lt VERSION - iDRAC less than VERSION
  • --idrac_le VERSION - iDRAC less than or equal to VERSION
  • --idrac_gt VERSION - iDRAC greater than or equal to VERSION
  • --idrac_ge VERSION - iDRAC greater than VERSION
  • --idrac_eq VERSION - iDRAC equal to VERSION

Other Filters:

  • --model MODEL - Filter by server model (e.g., R650, R660)
  • --regex PATTERN - Filter hostname by SQL LIKE pattern
  • --expires_in DAYS - Systems with warranty expiring in N days (excludes already expired systems)
  • --expired - Systems with warranties that have already expired

Output Options:

  • --json - Output results as JSON instead of table
  • --host-only - Output only hostnames, one per line (useful for scripting)

📝 Tips & Troubleshooting

Using Verbose Output: Always use -v when running commands interactively to see progress:

dracs -v add -s ABC1234 -t server01 -m R660

SNMP Connectivity:

  • Ensure the iDRAC interface is reachable using the DNS naming configured in DRACS_DNS_STRING and DRACS_DNS_MODE
  • Default SNMP community is public (configure via SNMP_COMMUNITY env var)
  • Port 161 must be accessible

Dell API Issues:

  • Verify credentials in .env file
  • Check service tag is valid (5-7 alphanumeric characters)
  • Ensure system has an active Dell warranty/support contract

Database Location:

  • Default: warranty.db in the current working directory
  • Custom: Use -w /path/to/custom.db flag
  • The database is created automatically on first use

Debug Mode: Use -d flag to see detailed debugging including:

  • SQL queries and parameters
  • SNMP OID requests and responses
  • Dell API request/response details
  • Internal data structures
dracs -d add -s ABC1234 -t server01 -m R660

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

dracs-1.2.0.tar.gz (81.0 kB view details)

Uploaded Source

Built Distribution

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

dracs-1.2.0-py3-none-any.whl (66.8 kB view details)

Uploaded Python 3

File details

Details for the file dracs-1.2.0.tar.gz.

File metadata

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

File hashes

Hashes for dracs-1.2.0.tar.gz
Algorithm Hash digest
SHA256 77ac2495e3d3dbbbd4a18e87394a94b519634e8c194aadfb4bdfadc881549b85
MD5 03e3ef8facf704589552037fced583e8
BLAKE2b-256 3a26660947949bd7910f5a776d369c896dd74f59a5dfab7ed7d02f5642d77d04

See more details on using hashes here.

Provenance

The following attestation bundles were made for dracs-1.2.0.tar.gz:

Publisher: semantic-release.yml on kambiz-aghaiepour/dracs

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

File details

Details for the file dracs-1.2.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for dracs-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 39c7622c3990de83881a4d663da0dd1983c5612fa4f7e65ce371db30080948d4
MD5 d238b34c4093f887ffe4248b580550ef
BLAKE2b-256 a84e423cb68797e24627b5701cdf883ae09ad984bac97b1987703a3ce18683d2

See more details on using hashes here.

Provenance

The following attestation bundles were made for dracs-1.2.0-py3-none-any.whl:

Publisher: semantic-release.yml on kambiz-aghaiepour/dracs

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