MCP-HASS
Provides tools for controlling and monitoring Home Assistant entities, services, areas, devices, and camera snapshots.
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., "@MCP-HASSturn 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.
MCP-HASS
MCP-HASS connects AI assistants to Home Assistant through the Model Context Protocol (MCP). It exposes Home Assistant entities, services, areas, devices, and cameras as MCP tools that any compatible AI client can use to monitor and control a smart home.
Features
10 MCP tools covering entity discovery, service calls, area/device management, camera snapshots, and YAML config reload
Dual-API client: REST for entity states and service calls, WebSocket for area/device/entity registries
Self-healing connections with automatic reconnection and retry logic
Token-aware responses with configurable limits to avoid exceeding LLM context windows
Two deployment modes: stdio (Claude Desktop) and HTTP (Docker, any MCP client)
TLS certificate verification toggle for self-signed cert deployments (
HA_SSL_VERIFY)Launch script with MCP Inspector smoke tests for end-to-end validation
Related MCP server: Home Assistant MCP
Architecture
Modular dependency-injection architecture built on FastMCP. The server is a thin orchestrator that delegates to focused tool modules via ToolContext.
graph TB
subgraph "Entry Point"
CLI[CLI<br/>mcp-hass serve]
end
subgraph "Orchestration"
Server[server.py<br/>MCPHomeAssistantServer]
Config[ConfigurationManager]
end
subgraph "Dependency Injection"
Context[ToolContext]
end
subgraph "Tool Modules"
Entity[entity.py<br/>2 tools]
Service[service.py<br/>3 tools]
Spatial[spatial.py<br/>2 tools]
Device[device.py<br/>2 tools]
Bulk[bulk.py<br/>1 tool]
Camera[camera.py<br/>1 tool]
YAML[yaml_config.py<br/>1 tool]
end
subgraph "Home Assistant"
HAClient[HomeAssistantClient<br/>Dual REST + WebSocket]
REST[REST API]
WS[WebSocket API]
end
CLI --> Server
Server --> Config
Server --> Context
Context --> Entity & Service & Spatial & Device & Bulk & Camera & YAML
Entity & Service & Spatial & Device & Bulk & Camera & YAML --> HAClient
HAClient --> REST & WSsequenceDiagram
participant Client as AI Client
participant MCP as FastMCP
participant Tool as Tool Function
participant HAClient as HomeAssistantClient
participant HA as Home Assistant
Client->>MCP: MCP tool call
MCP->>Tool: Execute tool
Tool->>HAClient: API call (REST or WebSocket)
HAClient->>HA: HTTP/WS request
HA-->>HAClient: Response
HAClient-->>Tool: Parsed data
Tool->>Tool: Check token limit
Tool-->>MCP: JSON result
MCP-->>Client: MCP responseUsage
MCP Tools
Category | Tool | Description |
Entity |
| Discover entities with filtering (domain, area, state, attributes) |
Entity |
| Historical state data |
Service |
| Control devices |
Service |
| Bulk operations across multiple entities |
Service |
| List available services |
Service |
| Service schema details |
Spatial |
| Get all areas/zones |
Spatial |
| Devices in an area |
Device |
| Discover devices with filtering |
Device |
| Entities for a device |
Camera |
| Capture with intelligent downsampling |
Config |
| Validate and reload YAML config |
CLI
mcp-hass serve # Start stdio server (default)
mcp-hass serve --transport http # Start HTTP server
mcp-hass init # Create config file
mcp-hass validate # Validate configuration and HA connectivity
mcp-hass tools # List registered tools
mcp-hass config # Show active configurationGetting Started
Prerequisites
Python 3.10+
A running Home Assistant instance
A Home Assistant long-lived access token (create one here)
Option A: stdio (Claude Desktop)
Install:
pipx install mcp-hassInitialize config:
mcp-hass initEdit
~/.config/mcp-hass/configwith yourHA_BASE_URLandHA_TOKENValidate:
mcp-hass validateAdd to Claude Desktop config (
~/Library/Application Support/Claude/claude_desktop_config.json):{ "mcpServers": { "mcp-hass": { "command": "mcp-hass", "args": ["serve"] } } }
Option B: Docker (HTTP)
Configure environment:
cp .env.example .env # Edit .env with HA_BASE_URL, HA_TOKEN, and optionally MCP_HOST_PORTLaunch (builds, starts, and runs smoke tests):
./launch.shConnect via mcp-remote:
{ "mcpServers": { "mcp-hass": { "command": "npx", "args": ["mcp-remote", "http://127.0.0.1:3000/mcp"] } } }Adjust the port if you changed
MCP_HOST_PORTin.env.
Configuration Reference
# Home Assistant (required)
HA_BASE_URL=http://homeassistant.local:8123
HA_TOKEN=your_long_lived_access_token
HA_TIMEOUT=10
WS_RECONNECT_ATTEMPTS=5
HA_SSL_VERIFY=true # Set to false for self-signed certs
# MCP Server (required)
MCP_SERVER_NAME=MCP-HASS
LOG_LEVEL=INFO
DEBUG_MODE=false
# Docker (optional)
MCP_HOST_PORT=3000 # Host port for Docker composeThis server cannot be installed
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/max-rousseau/mcp-hass'
If you have feedback or need assistance with the MCP directory API, please join our Discord server