- Fix Wyoming satellite crash on wake word: convert macOS .aiff chimes to .wav (Python wave module only reads RIFF format, not AIFF) - Fix OpenClaw HTTP bridge: increase subprocess timeout 30s → 120s, add SO_REUSEADDR - Fix HA conversation component: use HTTP agent (not CLI) since HA runs in Docker on a different machine; update default host to Mac Mini IP, timeout to 120s - Rewrite character manager as Vite+React app with schema validation - Add Wyoming satellite wake word command, ElevenLabs TTS server, wakeword monitor - Add Phase 5 development plan - Update TODO.md: mark voice pipeline and agent tasks complete Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
OpenClaw Conversation - Home Assistant Custom Component
A custom conversation agent for Home Assistant that routes all voice/text queries to OpenClaw for processing.
Features
- Direct OpenClaw Integration: Routes all conversation requests to OpenClaw
- CLI-based Communication: Uses the
openclawCLI command (fallback if HTTP API unavailable) - Configurable: Set host, port, agent name, and timeout via UI
- Voice Pipeline Compatible: Works with Home Assistant's voice assistant pipeline
Installation
Method 1: Manual Copy
-
Copy the entire
openclaw_conversationfolder to your Home Assistantcustom_componentsdirectory:# On the HA host (if using HA OS or Container, use the File Editor add-on) cp -r homeai-agent/custom_components/openclaw_conversation \ /config/custom_components/ -
Restart Home Assistant
-
Go to Settings → Devices & Services → Add Integration
-
Search for "OpenClaw Conversation"
-
Configure the settings:
- OpenClaw Host:
localhost(or IP of Mac Mini) - OpenClaw Port:
8081(HTTP Bridge) - Agent Name:
main(or your configured agent) - Timeout:
30seconds
- OpenClaw Host:
Method 2: Using HACS (if available)
- Add this repository to HACS as a custom repository
- Install "OpenClaw Conversation"
- Restart Home Assistant
Configuration
Via UI (Recommended)
After installation, configure via Settings → Devices & Services → OpenClaw Conversation → Configure.
Via YAML (Alternative)
Add to your configuration.yaml:
openclaw_conversation:
openclaw_host: localhost
openclaw_port: 8081
agent_name: main
timeout: 30
Usage
Once configured, the OpenClaw agent will be available as a conversation agent in Home Assistant.
Setting as Default Agent
- Go to Settings → Voice Assistants
- Edit your voice assistant pipeline
- Set Conversation Agent to "OpenClaw Conversation"
- Save
Testing
- Open the Assist panel in Home Assistant
- Type a query like: "Turn on the reading lamp"
- OpenClaw will process the request and return a response
Architecture
[Voice Input] → [HA Voice Pipeline] → [OpenClaw Conversation Agent]
↓
[OpenClaw CLI/API]
↓
[Ollama LLM + Skills]
↓
[HA Actions + TTS Response]
Troubleshooting
Agent Not Responding
- Check OpenClaw is running:
pgrep -f openclaw - Test CLI directly:
openclaw agent --message "Hello" --agent main - Check HA logs: Settings → System → Logs
Connection Errors
- Verify OpenClaw host/port settings
- Ensure OpenClaw is accessible from HA container/host
- Check network connectivity:
curl http://localhost:8081/status
Files
| File | Purpose |
|---|---|
manifest.json |
Component metadata |
__init__.py |
Component setup and registration |
config_flow.py |
Configuration UI flow |
const.py |
Constants and defaults |
conversation.py |
Conversation agent implementation |
strings.json |
UI translations |