Homey-Wan-Kenobi-MCP
Provides tools for Zigbee mesh network diagnostics, including controller health, node status, and issue remediation.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Homey-Wan-Kenobi-MCPturn on the living room lights"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Homey-Wan-Kenobi MCP
MCP server for controlling Homey Pro smart home systems through the Model Context Protocol.
The name nods to Obi-Wan Kenobi, your home's only hope for natural-language control.
60 tools and 3 knowledge prompts for device control, flow authoring, automation, monitoring, troubleshooting, network diagnostics, and self-hosted deployment.
Why Homey-Wan-Kenobi
Athom ships an official Homey MCP Server: a cloud-brokered remote connector you add to a paid Claude or ChatGPT plan and sign into with your Homey account. It covers device status and control, renaming and moving devices, creating, updating and starting Flows and Advanced Flows, and setting Moods.
This server differs in two ways. It is self-hosted, so you run it yourself over stdio or streamable-HTTP with no third-party broker and no paid AI-plan requirement. And it adds operational depth for power users that is not part of the official server's described capabilities.
The table reflects Athom's publicly described capabilities as of June 2026. Athom does not publish a formal tool list, so the right-hand gaps are inferred from their documentation, not stated by Athom.
Capability | Official Homey MCP ( | Homey-Wan-Kenobi |
Hosting | Cloud-brokered remote connector | Self-hosted, stdio or HTTP, no broker |
Access | Paid Claude/ChatGPT connector plan | Any MCP client, no plan requirement |
Devices, zones, control, rename, move | Yes | Yes |
Flow and Advanced Flow authoring | Yes | Yes |
Moods | Yes | Yes |
Flow-card schema discovery (build flows from scratch) | Not described | Yes |
Energy: live power and day/week/month/year reports | Not described | Yes |
Insights: historical sensor and meter data | Not described | Yes |
Z-Wave and Zigbee mesh diagnostics with remediations | Not described | Yes |
App memory and usage analysis (removal candidates) | Not described | Yes |
Infrastructure ops: backups, reboot, updates, memory, storage | Not described | Yes |
Raw Homey Web API passthrough | Not described | Yes |
Listed in the public MCP Registry | No | Yes |
The depth, in practice
Network diagnostics that the official server does not describe.
diagnose_zwave_networkanddiagnose_zigbee_networkread controller health, grade each node by last-seen age (battery-sleep aware), group transmit failures, correlate them with unavailable devices, and return severity-ranked remediations.get_zwave_logexposes the raw network log.Energy and Insights analysis. Live power by zone and device, day/week/month/year energy reports, and timestamped historical sensor and meter data, so the model can answer "what is using power right now" or "how has the bedroom temperature trended this week".
App memory and usage analysis.
analyze_app_usagecross-references every app against RAM, device counts and flow references to flag safe removal candidates and estimate savings. Read-only and advisory.Build automations from scratch. A flow-card discovery engine (
list_flow_cards,get_flow_card) returns each card's full argument schema, and full standard and Advanced Flow CRUD (including delete) lets an AI author and tear down the whole cards graph by UUID.Infrastructure operations from one interface. Backups, reboot, update checks, memory and storage usage, drivers, LED ring, session and location info.
A future-proof escape hatch.
homey_api_callreaches any Homey Web API endpoint directly, so new firmware features work without waiting for a tool update.
It runs on a hardened, non-root node:22-alpine image whose every build and release is gated on a Trivy scan, and it is published to Docker Hub, GHCR and the public MCP Registry. See the tool reference below for the full list.
When the official server is the better fit
This server is local-first and self-hosted, which is both its strength and its trade-off. The official Homey MCP is the easier choice when you want:
Zero setup and managed hosting. Add one URL and sign in with your Homey account. There is no container to run, expose, or maintain, and there is a one-click ChatGPT app.
Secure remote access from anywhere. Athom brokers the connection through its cloud, so it works away from home without exposing anything on your LAN. This server's HTTP mode is intended for a trusted local network; remote use is your own VPN or authenticated reverse proxy.
Every Homey model. The official endpoint reaches Homey Cloud, Pro, Pro mini and Self-Hosted Server, including cloud-only setups that have no local API. This server targets a Homey reachable over its local API or your Athom token, so it is happiest with a Homey Pro.
First-party support. It is maintained by Athom, kept in step with firmware, and officially tested with Claude and the ChatGPT app. This project is independent and best-effort.
The two are complementary. Many people use the official connector for quick remote control and this server for the deep local diagnostics, energy analysis, and infrastructure work. Athom does not publish a formal tool list, so the official server may also include capabilities not reflected above.
Related MCP server: hass-mcp-server
Quick Start
git clone https://github.com/Ringosystems/Homey-Wan-Kenobi-MCP.git
cd Homey-Wan-Kenobi-MCP
npm install
npm run buildAuthenticate with your Homey:
npx homey login
npx homey selectAdd to your MCP client config (Kiro, Claude Desktop, Cline, etc.):
{
"mcpServers": {
"homey": {
"command": "node",
"args": ["/path/to/Homey-Wan-Kenobi-MCP/dist/index.js"]
}
}
}Authentication
The server supports two authentication methods:
Homey CLI (recommended) runs npx homey login and npx homey select. The server reads the stored OAuth token from ~/.athom-cli/settings.json automatically.
Local API Key is created at my.homey.app. Set environment variables:
export HOMEY_ADDRESS=http://192.168.1.x
export HOMEY_TOKEN=your-api-keyThe local API key method is the recommended choice when running self-hosted in a container, since it does not depend on a mounted CLI settings file.
Self-Hosted (Docker / HTTP)
The image is published at ringosystems/homey-wan-kenobi (mirrored to ghcr.io/ringosystems/homey-wan-kenobi), and the server is listed in the MCP Registry as io.github.Ringosystems/homey-wan-kenobi-mcp. It is built on node:22-alpine, runs as a non-root user, and ships no baked-in secrets. See SECURITY.md for the audit details.
It defaults to the stdio transport so an MCP client can launch it directly, and exposes a long-lived streamable-HTTP service (via supergateway at /mcp, health at /healthz) when you set MCP_TRANSPORT=streamable-http.
Run as an MCP client (stdio)
docker run -i --rm \
-e HOMEY_ADDRESS=http://192.168.1.x \
-e HOMEY_TOKEN=your-local-api-key \
ringosystems/homey-wan-kenobi:latestRun as an HTTP service
docker run -d -p 8000:8000 \
-e MCP_TRANSPORT=streamable-http \
-e HOMEY_ADDRESS=http://192.168.1.x \
-e HOMEY_TOKEN=your-local-api-key \
--restart unless-stopped \
ringosystems/homey-wan-kenobi:latestDocker Compose
Supply your Homey credentials via a .env file next to docker-compose.yml:
cat > .env <<'EOF'
HOMEY_ADDRESS=http://192.168.1.x
HOMEY_TOKEN=your-local-api-key
EOF
# Pull the published image, or add --build to build locally instead
docker compose up -dThe provided docker-compose.yml references the published image (with build: . as a local-build fallback) and applies container hardening (read-only root filesystem, dropped Linux capabilities, no-new-privileges, and memory/PID limits):
services:
homey-wan-kenobi:
image: ringosystems/homey-wan-kenobi:latest
build: .
container_name: homey-wan-kenobi
ports:
- "8000:8000"
environment:
MCP_TRANSPORT: streamable-http
HOMEY_ADDRESS: "${HOMEY_ADDRESS:-http://192.168.1.x}"
HOMEY_TOKEN: "${HOMEY_TOKEN:-}"
restart: unless-stopped
read_only: true
tmpfs:
- /tmp
security_opt:
- no-new-privileges:true
cap_drop:
- ALL
mem_limit: 256m
pids_limit: 128
healthcheck:
test: ["CMD", "node", "-e", "fetch('http://localhost:8000/healthz').then(r=>process.exit(r.ok?0:1)).catch(()=>process.exit(1))"]
interval: 30s
timeout: 5s
retries: 3
start_period: 20sBuild locally
docker build -t ringosystems/homey-wan-kenobi .
docker run -d -p 8000:8000 \
-e MCP_TRANSPORT=streamable-http \
-e HOMEY_ADDRESS=http://192.168.1.x \
-e HOMEY_TOKEN=your-local-api-key \
--restart unless-stopped \
ringosystems/homey-wan-kenobiConnecting a client
Point an MCP client at the streamable-HTTP endpoint:
{
"mcpServers": {
"homey": {
"type": "streamable-http",
"url": "http://your-host:8000/mcp"
}
}
}Check health with curl http://your-host:8000/healthz.
Tools
Devices
Tool | Description |
| List devices with live capability values, filter by zone or class |
| Get full device details and all capability values by ID |
| Search devices by name, class, or capability |
| Control a device (onoff, dim, target_temperature, volume_set, etc.) |
Device & Zone Management
Tool | Description |
| Rename a device |
| Move a device to a different zone (room) |
| Create a new zone, optionally nested under a parent |
Zones
Tool | Description |
| List all zones (rooms/areas) with their hierarchy |
Flows
Tool | Description |
| List simple and advanced flows with enabled/broken status |
| Run a flow immediately |
| Enable or disable a flow |
Flow Authoring
Tool | Description |
| Get a standard WHEN/AND/THEN flow definition by ID |
| Create a standard flow from trigger/conditions/actions |
| Update fields of a standard flow |
| Permanently delete a standard flow |
| Get an Advanced Flow definition (cards, args, connections) |
| Create an Advanced Flow from a cards graph |
| Update an Advanced Flow (replaces the cards graph) |
| Permanently delete an Advanced Flow |
Flow Card Discovery
Tool | Description |
| List trigger/condition/action cards, filtered by substring |
| Get one flow card's full definition and argument schema |
Logic & Apps
Tool | Description |
| List logic variables with current values |
| Set a logic variable value |
| List installed apps with version, status, and origin |
| Restart a Homey app |
| Enable or disable an app |
| Uninstall an app and remove its devices |
Insights & Energy
Tool | Description |
| List available insight logs |
| Get historical sensor/meter data over a time range |
| Live power consumption by zone and device |
| Energy report for day/week/month/year |
Weather, Presence & Location
Tool | Description |
| Current weather at Homey's location |
| Hourly weather forecast |
| Home/away and awake/asleep status for all users |
| Set your own presence or sleep state |
| Homey's configured geographic location |
Alarms & Moods
Tool | Description |
| List all alarms and timers |
| Create or update an alarm |
| Delete an alarm |
| List moods (scenes) per zone |
| Activate a mood in a zone |
Notifications
Tool | Description |
| List the 50 most recent notifications |
| Send a notification to the Homey timeline |
Network Diagnostics
Tool | Description |
| Zigbee mesh health, per-node last-seen, issues and remediations |
| Z-Wave health, transmit failures, unavailable nodes, remediations |
| Raw recent Z-Wave network log for troubleshooting |
App Usage Analysis
Tool | Description |
| Cross-reference apps against RAM, devices, and flow references to flag removal candidates (advisory, read-only) |
System & Infrastructure
Tool | Description |
| System info (version, wifi, hostname, hardware) |
| List all available device drivers |
| Backup config and last backup time |
| Schedule a new backup |
| LED ring screensaver options and current setting |
| Set the LED ring screensaver |
| Check for system updates and update settings |
| Current API session info (user, role, scopes) |
| Reboot the Homey Pro |
| Memory usage by app and component |
| Storage usage breakdown |
| Set the Homey system name |
Advanced
Tool | Description |
| Raw escape hatch to call any Homey Web API endpoint directly |
Prompts
Built-in knowledge prompts accessible via the MCP prompts API:
Prompt | Description |
| Zone architecture, device naming, protocol tips, energy management, security |
| Diagnosing offline devices, Z-Wave/Zigbee issues, flow debugging, performance |
| Automation patterns, naming conventions, anti-patterns to avoid |
Development
npm run dev # Run with tsx (no build step)
npm run build # Compile TypeScript
npm run lint # ESLint
npm run typecheck # TypeScript strict check
npm start # Run compiled versionTech Stack
TypeScript + Node.js (>=20)
homey-api v3, the official Homey Web API client
@modelcontextprotocol/sdk v1.29, MCP server (
registerToolwithToolAnnotations)zod for parameter validation
supergateway for the self-hosted streamable-HTTP transport
Security
The dependency tree, base image, and container configuration are audited with Trivy and npm audit. The published image runs as a non-root user on node:22-alpine with no baked-in secrets, and the production dependencies ship with 0 high or critical advisories. See SECURITY.md for the full audit, accepted residual risks, and how to reproduce the scans.
License
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Ringosystems/Homey-Wan-Kenobi-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server