CLI for managing and controlling Shelly devices
Project description
shelly
A fast CLI for discovering, monitoring, and controlling Shelly smart home devices.
Features
- Auto-discovery of Shelly devices on the local network (with subnet auto-detection)
- Unified Gen1 + Gen2/Gen3 support (transparent protocol handling)
- RGB / RGBW / CCT / dimmable light control (
shelly light, Gen2/Gen3) - Multi-channel device support, per-plug control via
--id(e.g., Shelly 2.5 dual relays, PowerStrip) - Interactive watch dashboard with live power, temperature, WiFi monitoring -- and switch control
- Energy consumption tracking (total kWh per device)
- Detailed device info view (model, firmware, uptime, WiFi, temperature)
- Device health checks (temperature, WiFi signal, firmware, uptime)
- Device authentication (
--passwordflag or config file) - Device groups with filter-based and name-based definitions
- Firmware check and update across all devices
- Config backup and restore with network-safe defaults
- Schedule and webhook inspection (Gen2/Gen3)
- Device renaming and configuration from the CLI
- Structured JSON output for scripting and AI agent integration
- Shell completions with dynamic device name suggestions (bash, zsh, fish)
- Fuzzy device name matching with "did you mean?" suggestions
- Color output with automatic detection
Install
uv (recommended)
uv tool install shelly-cli
Homebrew (macOS/Linux)
brew install rvben/tap/shelly-cli
pip
pip install shelly-cli
Cargo
cargo install shelly-cli
Pre-built binaries
Download from GitHub Releases.
Quick Start
# 1. Discover devices (auto-detects your subnet)
shelly discover
# 2. See what you found
shelly devices
# 3. Check device health
shelly health
Usage
Device control
shelly on "Kitchen Light" # Turn on
shelly off "Kitchen Light" # Turn off
shelly toggle -n "Living Room" # Toggle
shelly status -n "Kitchen Light" # Get status
For multi-channel devices (dual relays, power strips), select a specific plug/channel with --id (defaults to 0). The available switch IDs are listed by shelly info.
shelly info -n "Office Strip" # Lists Switch 0, Switch 1, ...
shelly on -n "Office Strip" --id 1 # Turn on plug 1
shelly off -n "Office Strip" --id 3 # Turn off plug 3
shelly switch status -n "Office Strip" --id 2 # Status of plug 2
Light control (Gen2/Gen3 RGB / RGBW / CCT / dimmable)
shelly light on -n "Desk Lamp" --color '#00ff88' # RGB color (hex)
shelly light on -n "Desk Lamp" --color warm # named color
shelly light on -n "Desk Lamp" --rgb 0,255,136 --brightness 80
shelly light set -n "Desk Lamp" --brightness 40 # change brightness, keep power state
shelly light on -n "Strip" --rgb 255,0,0 --white 0 # RGBW: color + white channel
shelly light on -n "Bulb" --temp 3000 --brightness 60 # CCT: color temperature (Kelvin)
shelly light off -n "Desk Lamp"
shelly light toggle -n "Desk Lamp"
shelly light status -n "Desk Lamp"
--id selects the component on multi-light devices (default 0). Brightness is 1-100 for RGB/RGBW and 0-100 for CCT/dimmable. --color accepts hex (#rrggbb) or a name (red, green, blue, white, warm, cyan, magenta, yellow, orange, purple, pink, off); --rgb takes r,g,b each 0-255.
Monitoring
shelly watch # Interactive dashboard
shelly health # Health check all devices
shelly power -a # Power usage for all devices
shelly energy -a # Total energy (kWh) per device
shelly info -n "Kitchen Light" # Detailed device info
Device management
shelly rename -n "old-name" "New Name" # Rename device
shelly firmware check -a # Check for updates
shelly firmware update -a # Update all firmware
shelly reboot -n "Kitchen Light" # Reboot device
Configuration
shelly config get -n "Kitchen" # Get device config (JSON)
shelly config get -a # Get config for all devices
shelly config set -n "Kitchen" eco_mode true # Set a config value
shelly config set -n "Kitchen" name "New Name" # Rename via config
Supported config keys: name, eco_mode, led_status_disable.
Backup and restore
shelly backup -n "Kitchen" # Backup single device
shelly backup -a # Backup all devices to shelly-backups/
shelly backup -a -o ~/backups # Custom output directory
shelly restore -n "Kitchen" shelly-backups/kitchen-2025-01-15.json
Restore skips network/WiFi/MQTT/cloud settings to avoid bricking devices.
Schedules and webhooks
shelly schedule list -n "Kitchen" # View device schedules (Gen2/Gen3)
shelly schedule list -a # View all device schedules
shelly webhook list -n "Kitchen" # View device webhooks
shelly webhook list -a # View all device webhooks
Groups
shelly group add lights "Kitchen" "Living Room" "Bedroom"
shelly group list
shelly group show lights
shelly -g lights off # Turn off all lights
shelly -g lights status # Status of all lights
shelly -g gen3 firmware check # Check firmware for Gen3 devices
Authentication
For devices with authentication enabled:
# Per-command
shelly --password "secret" status -a
# Or set in config file (~/.config/shelly-cli/config.toml)
# [auth]
# password = "secret"
Shell completions
# Generate completions (includes dynamic device name suggestions)
shelly completions zsh > ~/.zfunc/_shelly # zsh
shelly completions bash > /etc/bash_completion.d/shelly # bash
shelly completions fish > ~/.config/fish/completions/shelly.fish # fish
# After installing, tab-complete device names:
# shelly -n <TAB> → "Kitchen Light" "Living Room" "Bedroom Fan"
# shelly -g <TAB> → "lights" "gen1" "gen3"
Agent Integration
Designed for scripting and AI agent use with structured, machine-readable output.
# Structured JSON output (auto-enabled when piped)
shelly status -a | jq '.data'
# Consistent envelope: {"ok": true, "data": ...} or {"ok": false, "error": {...}}
shelly -n "nonexistent" status
# {"ok": false, "error": {"code": "DEVICE_NOT_FOUND", "message": "..."}}
# Machine-readable schema with types, targeting docs, and error codes
shelly schema
Error codes: DEVICE_NOT_FOUND, DEVICE_UNREACHABLE, AUTH_REQUIRED, NETWORK_ERROR, INVALID_INPUT, GROUP_NOT_FOUND, NO_CACHED_DEVICES, PARTIAL_FAILURE.
Groups Configuration
Groups are defined in a TOML file:
# ~/.config/shelly-cli/groups.toml (Linux)
# ~/Library/Application Support/shelly-cli/groups.toml (macOS)
[groups]
lights = ["Kitchen Light", "Living Room Light", "Bedroom Light"]
gen1 = { filter = "gen1" }
gen3 = { filter = "gen3" }
all = { filter = "all" }
Or manage via CLI: shelly group add, shelly group remove, shelly group show.
Supported Devices
| Generation | Examples | Status |
|---|---|---|
| Gen1 | Shelly 1, 1PM, 2.5, Plug S, Dimmer | Supported (switch, power, firmware, config) |
| Gen2 | Shelly Plus 1, Plus 1PM, Plus 2PM | Supported (switch, power, firmware, config, schedules, webhooks) |
| Gen3 | Shelly Mini 1PM G3, Plus series G3, PowerStrip 4 (S4PL) | Supported (switch, power, firmware, config, schedules, webhooks) |
License
MIT License -- see LICENSE file.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file shelly_cli-0.1.11.tar.gz.
File metadata
- Download URL: shelly_cli-0.1.11.tar.gz
- Upload date:
- Size: 81.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2dd2b0b8cc3aedb89b557a9a02fd4492340fc677725a07574855a684d7c5cc77
|
|
| MD5 |
f00843a115a1581609ac0d9ec693bea7
|
|
| BLAKE2b-256 |
cc325b34d9c5ee2690928ed9a594fb00d098edf0a9cd2ef315e9c20b3ebb2319
|
File details
Details for the file shelly_cli-0.1.11-py3-none-win_amd64.whl.
File metadata
- Download URL: shelly_cli-0.1.11-py3-none-win_amd64.whl
- Upload date:
- Size: 5.6 MB
- Tags: Python 3, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
968eddb083b1b7d52de296b5cd911f8e087459611ede1df0db38aca826737a7f
|
|
| MD5 |
3eb620a326ab91bd03e78d6b7a420571
|
|
| BLAKE2b-256 |
53bc09761e8f8a6524dc68195bf2bca3e91705dcf4a22c25c85ad036272f94e1
|
File details
Details for the file shelly_cli-0.1.11-py3-none-manylinux_2_28_x86_64.whl.
File metadata
- Download URL: shelly_cli-0.1.11-py3-none-manylinux_2_28_x86_64.whl
- Upload date:
- Size: 6.2 MB
- Tags: Python 3, manylinux: glibc 2.28+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1244bf9bf18cb69243d111f8d48f80ec70e06ea91bfd951cde2f9cf5af5389c6
|
|
| MD5 |
940532ce3f2c5abcbf6bc64ca6cddf64
|
|
| BLAKE2b-256 |
416c982d251f94948591aafcfb7a88843025436c96f6b917620ffb295fd8e2af
|
File details
Details for the file shelly_cli-0.1.11-py3-none-manylinux_2_28_aarch64.whl.
File metadata
- Download URL: shelly_cli-0.1.11-py3-none-manylinux_2_28_aarch64.whl
- Upload date:
- Size: 5.8 MB
- Tags: Python 3, manylinux: glibc 2.28+ ARM64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e34d7b2a717cdc37809233aa157db273a5908f6fcccc2537cfa72f5c6530ea33
|
|
| MD5 |
03dfdf8f1d5444a3e7aebaf325f48a64
|
|
| BLAKE2b-256 |
80e0edbed9b11109529471b5d9b27bff4031d14710ccd6a14881f5bac540cc62
|
File details
Details for the file shelly_cli-0.1.11-py3-none-macosx_11_0_arm64.whl.
File metadata
- Download URL: shelly_cli-0.1.11-py3-none-macosx_11_0_arm64.whl
- Upload date:
- Size: 5.2 MB
- Tags: Python 3, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ad9f3af0e8a5ed51b97dc530463b513acc8035df5ca863e8a57f12cf7dfa04b4
|
|
| MD5 |
042783ddbb4baaccce5a56bfc66078ff
|
|
| BLAKE2b-256 |
25526eb0573c4d5e90db3e7fdefa155d62581c5f979556b3221acb2f9ca45dab
|
File details
Details for the file shelly_cli-0.1.11-py3-none-macosx_10_12_x86_64.whl.
File metadata
- Download URL: shelly_cli-0.1.11-py3-none-macosx_10_12_x86_64.whl
- Upload date:
- Size: 5.5 MB
- Tags: Python 3, macOS 10.12+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cf893dc93cd618bb399847c5be2181384e11d055c9e04b88b8e15c1532f71f44
|
|
| MD5 |
479f20d5e6043800583bdaccc3ddfb92
|
|
| BLAKE2b-256 |
d055cffdc390168a71f7a452bee1a3c024e3f4fcae7640776f7a1732403ac11a
|