A Ruby client library that provides a unified interface for managing servers via Redfish API, with automatic vendor detection and adaptation.
Radfish takes a minimal approach to data normalization to ensure consistency across different systems and avoid mismatches from varying formats:
- Manufacturer/Make: Returns simplified vendor names (e.g., "Dell" instead of "Dell Inc.", "Supermicro" instead of "Super Micro Computer")
- Model: Returns core model identifiers without marketing prefixes (e.g., "R640" instead of "PowerEdge R640")
- Consistent Fields: All adapters normalize their data to use the same field names and formats
This approach minimizes potential mismatches across older systems or spacing/hyphenation issues with multi-token descriptors.
Radfish provides a vendor-agnostic interface for server management through Redfish, automatically detecting and adapting to different hardware vendors. The architecture consists of:
radfish (core gem)
├── Core modules (define interfaces)
├── Vendor detection
├── Client (delegates to adapters)
└── Base classes
radfish-idrac (Dell adapter)
└── IdracAdapter → wraps idrac gem
radfish-supermicro (Supermicro adapter)  
└── SupermicroAdapter → wraps supermicro gem
Future adapters:
- radfish-hpe (HPE iLO)
- radfish-lenovo (Lenovo XCC)
- radfish-asrockrack
- Automatically identifies Dell, Supermicro, HPE, Lenovo, and ASRockRack servers
- Falls back to generic Redfish if vendor cannot be determined
- Can be overridden with explicit vendor specification
Regardless of vendor, all adapters provide:
- Power Management: on/off/restart/cycle
- System Inventory: CPUs, memory, NICs, storage
- Virtual Media: Mount/unmount ISOs
- Boot Configuration: Boot order, one-time boot
- Monitoring: Temperatures, fans, power consumption
- Event Logs: System event log management
- Jobs/Tasks: Long-running operation monitoring
Adapters can expose vendor-specific functionality while maintaining the common interface.
Add to your Gemfile:
gem 'radfish'
# Add vendor-specific adapters as needed
gem 'radfish-idrac'      # For Dell servers
gem 'radfish-supermicro'  # For Supermicro serversOr install directly:
gem install radfish
gem install radfish-idrac      # For Dell servers  
gem install radfish-supermicro  # For Supermicro serversThe adapters will be automatically detected and loaded when available.
Radfish includes a powerful command-line interface for server management:
# Check system status
radfish system --host 192.168.1.100 -u admin -p password
# Power operations
radfish power status --host 192.168.1.100 -u admin -p password
radfish power on --host 192.168.1.100 -u admin -p password
radfish power restart --host 192.168.1.100 -u admin -p password
# Virtual media operations
radfish media status --host 192.168.1.100 -u admin -p password
radfish media mount https://example.com/ubuntu.iso --host 192.168.1.100 -u admin -p password
radfish media unmount --host 192.168.1.100 -u admin -p password
# Boot configuration
radfish boot status --host 192.168.1.100 -u admin -p password
radfish boot cd --once --host 192.168.1.100 -u admin -p password
radfish boot pxe --uefi --host 192.168.1.100 -u admin -p passwordConfigure common settings via environment variables to avoid repetition:
export RADFISH_HOST=192.168.1.100
export RADFISH_USERNAME=admin
export RADFISH_PASSWORD=password
export RADFISH_VENDOR=supermicro  # Optional: auto-detects if not set
export RADFISH_PORT=443           # Optional: defaults to 443
# Now commands are simpler
radfish system
radfish power on
radfish media mount https://example.com/ubuntu.isoradfish system [OPTIONS]           # Display system information
radfish cpus [OPTIONS]             # List CPUs
radfish memory [OPTIONS]           # List memory modules
radfish nics [OPTIONS]             # List network interfaces
radfish storage controllers        # List storage controllers
radfish storage drives             # List drives across controllers
radfish storage volumes            # List volumes across controllers
radfish psus [OPTIONS]             # List power suppliesradfish power status [OPTIONS]     # Show current power state
radfish power on [OPTIONS]         # Power on the system
radfish power off [OPTIONS]        # Power off the system
radfish power restart [OPTIONS]    # Restart the system
radfish power cycle [OPTIONS]      # Power cycle the systemradfish media status [OPTIONS]     # Show virtual media status
radfish media mount URL [OPTIONS]  # Mount ISO from URL
radfish media unmount [OPTIONS]    # Unmount all virtual mediaradfish boot status [OPTIONS]      # Show boot configuration
radfish boot cd [OPTIONS]          # Boot from virtual CD
radfish boot pxe [OPTIONS]         # Boot from network (PXE)
radfish boot disk [OPTIONS]        # Boot from hard disk
radfish boot bios [OPTIONS]        # Boot to BIOS setup
# Boot options:
  --once        # Set boot override for next boot only
  --continuous  # Set boot override until manually cleared
  --uefi        # Use UEFI boot mode
  --legacy      # Use Legacy/BIOS boot moderadfish fans [OPTIONS]              # Show fan speeds
radfish temps [OPTIONS]             # Show temperatures
radfish power-consumption [OPTIONS] # Show power consumption
radfish sel [OPTIONS]               # Show system event log
radfish clear-sel [OPTIONS]         # Clear system event logAll commands support these options:
  --host, -h HOST          # BMC hostname or IP address
  --username, -u USER      # BMC username
  --password, -p PASS      # BMC password
  --vendor VENDOR          # Force specific vendor (dell, supermicro, etc.)
  --port PORT              # BMC port (default: 443)
  --json                   # Output in JSON format
  --verbose, -v            # Enable verbose output (repeat for more verbosity)
  --no-verify-ssl          # Skip SSL certificate verification$ radfish system
System Information:
  Manufacturer: Supermicro
  Model: X11SCL-F
  Serial: 0123456789
  Power State: On
  Health: OK$ radfish system --json
{
  "manufacturer": "Supermicro",
  "model": "X11SCL-F",
  "serial": "0123456789",
  "power_state": "On",
  "health": "OK"
}# Mount the ISO
radfish media mount https://releases.ubuntu.com/24.04/ubuntu-24.04-live-server-amd64.iso
# Configure one-time boot from CD with UEFI
radfish boot cd --once --uefi
# Restart the system
radfish power restart# Check current status
radfish power status
radfish temps
# Perform power cycle
radfish power cycle
# Monitor until back online
watch radfish power status#!/bin/bash
# Provision multiple servers
SERVERS="192.168.1.100 192.168.1.101 192.168.1.102"
ISO_URL="https://example.com/os-installer.iso"
for server in $SERVERS; do
  echo "Provisioning $server..."
  
  # Mount ISO
  radfish media mount $ISO_URL --host $server -u admin -p password
  
  # Set one-time boot from CD
  radfish boot cd --once --host $server -u admin -p password
  
  # Restart
  radfish power restart --host $server -u admin -p password
donerequire 'radfish'
# Auto-detect vendor and connect
Radfish.connect(
  host: '192.168.1.100',
  username: 'admin',
  password: 'password'
) do |client|
  puts "Connected to #{client.vendor_name} server"
  puts "Power state: #{client.power_status}"
  
  # Common operations work regardless of vendor
  client.power_on
  client.insert_virtual_media("http://example.com/os.iso")
  client.boot_to_cd
end# Skip auto-detection if you know the vendor
client = Radfish::Client.new(
  host: '192.168.1.100',
  username: 'admin',
  password: 'password',
  vendor: 'dell'  # or 'supermicro', 'hpe', etc.
)
client.login
# ... operations ...
client.logout# Just detect the vendor without creating a client
vendor = Radfish.detect_vendor(
  host: '192.168.1.100',
  username: 'admin',
  password: 'password'
)
puts "Detected vendor: #{vendor}"
# => "dell", "supermicro", "hpe", etc.client = Radfish::Client.new(
  host: '192.168.1.100',
  username: 'admin',
  password: 'password'
)
# Check what this adapter supports
puts client.supported_features
# => [:power, :system, :storage, :virtual_media, :boot, :jobs, :utility]
# Get adapter info
puts client.info
# => {
#   vendor: "supermicro",
#   adapter: "Radfish::SupermicroAdapter",
#   features: [:power, :system, ...],
#   host: "192.168.1.100",
#   base_url: "https://192.168.1.100:443"
# }client.power_status      # => "On" or "Off"
client.power_on
client.power_off
client.power_restart
client.power_cycle# Basic system info
info = client.system_info
# => { "manufacturer" => "Dell", "model" => "PowerEdge R640", ... }
# Hardware inventory
client.cpus      # CPU information
client.memory    # Memory DIMMs
client.nics      # Network interfaces
client.controllers.each { |c| c.drives }   # Physical drives (per controller)
client.controllers.each { |c| c.volumes }  # RAID volumes (per controller)
client.psus      # Power supplies# Check current media
media = client.virtual_media_status
# Mount an ISO
client.insert_virtual_media("http://example.com/os.iso")
# Unmount all media
client.unmount_all_media
# Mount and configure boot
client.mount_iso_and_boot("http://example.com/os.iso")# Get boot options
options = client.boot_options
# Set one-time boot
client.set_boot_override("Pxe", persistent: false)
# Quick boot methods
client.boot_to_pxe
client.boot_to_disk
client.boot_to_cd
client.boot_to_bios_setup# Thermal monitoring
fans = client.fans
temps = client.temperatures
# Power monitoring
power = client.power_consumption
# Event logs
events = client.sel_summary(limit: 10)
client.clear_sel_logRadfish shines in environments with mixed hardware vendors:
servers = [
  { host: '192.168.1.100', vendor: 'dell' },
  { host: '192.168.1.101', vendor: 'supermicro' },
  { host: '192.168.1.102', vendor: nil }  # auto-detect
]
servers.each do |server_config|
  Radfish.connect(
    host: server_config[:host],
    username: 'admin',
    password: 'password',
    vendor: server_config[:vendor]
  ) do |client|
    # Same code works for all vendors
    puts "#{client.vendor_name}: #{client.power_status}"
    
    if client.power_status == "Off"
      client.power_on
    end
  end
endRadfish::Client.new(
  host: '192.168.1.100',
  username: 'admin',
  password: 'password',
  
  # Optional parameters
  vendor: 'dell',           # Skip auto-detection
  port: 443,                # BMC port
  use_ssl: true,            # Use HTTPS
  verify_ssl: false,        # Verify certificates
  direct_mode: false,       # Use Basic Auth instead of sessions
  retry_count: 3,           # Retry failed requests
  retry_delay: 1,           # Initial delay between retries
  verbosity: 0              # Debug output level (0-3)
)Enable verbose output:
client.verbosity = 1  # Basic debug info
client.verbosity = 2  # Include request/response details  
client.verbosity = 3  # Include stack tracesCurrently supported:
- Dell (via radfish-idrac)
- Supermicro (via radfish-supermicro)
Planned support:
- HPE (iLO)
- Lenovo (XCC)
- ASRockRack
- Generic Redfish (fallback)
To add support for a new vendor, create an adapter gem:
# radfish-myvendor/lib/radfish/myvendor_adapter.rb
module Radfish
  class MyvendorAdapter < Core::BaseClient
    include Core::Power
    include Core::System
    # ... include other modules
    
    def vendor
      'myvendor'
    end
    
    def power_status
      # Implement vendor-specific logic
    end
    
    # ... implement required methods
  end
  
  # Register the adapter
  Radfish.register_adapter('myvendor', MyvendorAdapter)
end- Single API: Learn once, use everywhere
- Vendor Flexibility: Switch hardware vendors without changing code
- Automatic Detection: No need to track which vendor each server uses
- Gradual Migration: Mix vendors during hardware transitions
- Simplified Testing: Mock one interface instead of many
- Future-Proof: New vendors can be added without changing existing code
If you're currently using the idrac or supermicro gems directly:
# Old way (vendor-specific)
require 'idrac'
client = IDRAC::Client.new(host: '...', ...)
# New way (unified)
require 'radfish'
require 'radfish/idrac_adapter'  # or let it auto-load
client = Radfish::Client.new(host: '...', vendor: 'dell')
# Or with auto-detection
client = Radfish::Client.new(host: '...') The same method names work, so migration is straightforward.
MIT