Control Home Assistant Music Assistant - browse library, search, play, manage preferences and moods.
Control Home Assistant with Music Assistant integration - browse your music library, search for tracks, manage playback, set preferences, and create mood-based playlists.
HA_URL - Your Home Assistant URL (e.g., https://ha.example.com)HA_TOKEN - Long-lived access token from Home Assistant# List available media player speakers
ha-ma speakers
# Show Music Assistant configuration
ha-ma ma-config [--cached] [--refresh]
# Browse by type: artists, albums, tracks, playlists, radio
ha-ma browse <type> [--parent <id>] [--limit <n>] [--offset <n>]
# Examples
ha-ma browse artists --limit 20
ha-ma browse albums --parent "artist:123"
ha-ma browse tracks --parent "album:456"
# Search for music
ha-ma search <query> [--limit <n>] [--type <media_type>]
# Examples
ha-ma search "Beatles" --limit 10
ha-ma search "jazz" --type artists
# Play media on a speaker
ha-ma play --speaker <entity_id> --uri <uri> [--enqueue <mode>]
# Pause/Stop/Navigation
ha-ma pause --speaker <entity_id>
ha-ma stop --speaker <entity_id>
ha-ma next --speaker <entity_id>
ha-ma prev --speaker <entity_id>
# Volume control (0-100)
ha-ma volume --speaker <entity_id> --level <0-100>
# Add to queue
ha-ma queue --speaker <entity_id> --uri <uri>
Enqueue modes: play, replace, next, add
# Set preference for user or household
ha-ma prefs set --user <slug> --<entity-type> <value> --score <score>
ha-ma prefs set --household <slug> --<entity-type> <value> --score <score>
# Get preferences
ha-ma prefs get --user <slug>
ha-ma prefs get --household <slug>
# Clear specific preference
ha-ma prefs clear --user <slug> --<entity-type> <value>
ha-ma prefs clear --household <slug> --<entity-type> <value>
Entity types: --artist, --album, --genre, --track
# Create or update a mood
ha-ma mood set --user <slug> --name <name> --genres <g1,g2> [--decades <d1,d2>] [--energy <low|medium|high>]
ha-ma mood set --household <slug> --name <name> --genres <g1,g2> [--energy <level>]
# List moods
ha-ma mood list --user <slug>
ha-ma mood list --household <slug>
# Get specific mood
ha-ma mood get --user <slug> --name <name>
# Delete mood
ha-ma mood delete --user <slug> --name <name>
# Recent play history
ha-ma history recent --user <slug> [--limit 20]
# List listening sessions
ha-ma history sessions --user <slug> [--limit 10]
# Avoid list management
ha-ma history avoid --user <slug> --uri <uri> [--reason <text>]
ha-ma history unavoid --user <slug> --uri <uri>
ha-ma history avoidlist --user <slug>
# Log a play event
ha-ma memory log --user <slug> --speaker-entity <entity_id> --uri <uri> [--title ...] [--artist ...] [--album ...]
# Recent play events
ha-ma memory recent --user <slug> [--limit 10]
Set environment variables in your OpenClaw config:
{
"skills": {
"entries": {
"music-assistant": {
"env": {
"HA_URL": "https://your-ha-instance.com",
"HA_TOKEN": "your-long-lived-access-token"
}
}
}
}
}
The skill uses SQLite with Prisma for storing:
Database is automatically initialized on first use.