Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Control Home Assistant smart home devices, run automations, and receive webhook events. Use when controlling lights, switches, climate, scenes, scripts, or any HA entity. Supports bidirectional communication via REST API (outbound) and webhooks (inbound triggers from HA automations).
Control Home Assistant smart home devices, run automations, and receive webhook events. Use when controlling lights, switches, climate, scenes, scripts, or any HA entity. Supports bidirectional communication via REST API (outbound) and webhooks (inbound triggers from HA automations).
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
Control your smart home via Home Assistant's REST API and webhooks.
Create ~/.config/home-assistant/config.json: { "url": "https://your-ha-instance.duckdns.org", "token": "your-long-lived-access-token" }
export HA_URL="http://homeassistant.local:8123" export HA_TOKEN="your-long-lived-access-token"
Open Home Assistant โ Profile (bottom left) Scroll to "Long-Lived Access Tokens" Click "Create Token", name it (e.g., "Clawdbot") Copy the token immediately (shown only once)
curl -s -H "Authorization: Bearer $HA_TOKEN" "$HA_URL/api/states" | jq '.[].entity_id'
curl -s -H "Authorization: Bearer $HA_TOKEN" "$HA_URL/api/states/light.living_room"
# Turn on curl -X POST -H "Authorization: Bearer $HA_TOKEN" -H "Content-Type: application/json" \ "$HA_URL/api/services/light/turn_on" -d '{"entity_id": "light.living_room"}' # Turn off curl -X POST -H "Authorization: Bearer $HA_TOKEN" -H "Content-Type: application/json" \ "$HA_URL/api/services/light/turn_off" -d '{"entity_id": "light.living_room"}' # Set brightness (0-255) curl -X POST -H "Authorization: Bearer $HA_TOKEN" -H "Content-Type: application/json" \ "$HA_URL/api/services/light/turn_on" -d '{"entity_id": "light.living_room", "brightness": 128}'
# Trigger script curl -X POST -H "Authorization: Bearer $HA_TOKEN" "$HA_URL/api/services/script/turn_on" \ -H "Content-Type: application/json" -d '{"entity_id": "script.goodnight"}' # Trigger automation curl -X POST -H "Authorization: Bearer $HA_TOKEN" "$HA_URL/api/services/automation/trigger" \ -H "Content-Type: application/json" -d '{"entity_id": "automation.motion_lights"}'
curl -X POST -H "Authorization: Bearer $HA_TOKEN" "$HA_URL/api/services/scene/turn_on" \ -H "Content-Type: application/json" -d '{"entity_id": "scene.movie_night"}'
DomainServiceExample entity_idlightturn_on, turn_off, togglelight.kitchenswitchturn_on, turn_off, toggleswitch.fanclimateset_temperature, set_hvac_modeclimate.thermostatcoveropen_cover, close_cover, stop_covercover.garagemedia_playerplay_media, media_pause, volume_setmedia_player.tvsceneturn_onscene.relaxscriptturn_onscript.welcome_homeautomationtrigger, turn_on, turn_offautomation.sunrise
To receive events from Home Assistant automations:
# In HA automation action: - service: rest_command.notify_clawdbot data: event: motion_detected area: living_room
# configuration.yaml rest_command: notify_clawdbot: url: "https://your-clawdbot-url/webhook/home-assistant" method: POST headers: Authorization: "Bearer {{ webhook_secret }}" Content-Type: "application/json" payload: '{"event": "{{ event }}", "area": "{{ area }}"}'
Clawdbot receives the webhook and can notify you or take action based on the event.
The scripts/ha.sh CLI provides easy access to all HA functions: # Test connection ha.sh info # List entities ha.sh list all # all entities ha.sh list lights # just lights ha.sh list switch # just switches # Search entities ha.sh search kitchen # find entities by name # Get/set state ha.sh state light.living_room ha.sh states light.living_room # full details with attributes ha.sh on light.living_room ha.sh on light.living_room 200 # with brightness (0-255) ha.sh off light.living_room ha.sh toggle switch.fan # Scenes & scripts ha.sh scene movie_night ha.sh script goodnight # Climate ha.sh climate climate.thermostat 22 # Call any service ha.sh call light turn_on '{"entity_id":"light.room","brightness":200}'
401 Unauthorized: Token expired or invalid. Generate a new one. Connection refused: Check HA_URL, ensure HA is running and accessible. Entity not found: List entities to find the correct entity_id.
For advanced usage, see references/api.md.
Code helpers, APIs, CLIs, browser automation, testing, and developer operations.
Largest current source with strong distribution and engagement signals.