Music Assistant

The Music Assistant (MA) integrationIntegrations connect and integrate Home Assistant with your devices, services, and more. [Learn more] allows you to connect Home Assistant to a Music Assistant Server. Once configured, all MA Players show up as Home Assistant media player entities. Media players will allow you to control media playback and see the currently playing item.

There is currently support for the following Home Assistant Platforms:

All of the Home Assistant Media Player Control Actions are supported.

Configuration

To add the Music Assistant integration to your Home Assistant instance, use this My button:

Music Assistant can be auto-discovered by Home Assistant. If an instance was found, it will be shown as Discovered. You can then set it up right away.

Manual configuration steps

If it wasn’t discovered automatically, don’t worry! You can set up a manual integration entry:

  • Browse to your Home Assistant instance.

  • Go to Settings > Devices & Services.

  • In the bottom right corner, select the Add Integration button.

  • From the list, select Music Assistant.

  • Follow the instructions on screen to complete the setup.

Manual configuration

Under normal circumstances, Home Assistant automatically discovers your running Music Assistant Server. If there is something special about the HA or MA setup (for example, the MA server is running as a remote Docker container) or discovery is not working, you can manually specify the URL to your Music Assistant server. If the Music Assistant Server is not installed then follow these installation instructions.

Media player

The Music Assistant integration creates media player entities for all players available in MA including those imported from Home Assistant. This is needed to provide the full functionality Music Assistant has to offer. These entities will display media information, playback progress, and playback controls.

Action media_player.play_media

Play media hosted on a Music Assistant server on a Music Assistant player. The action configuration is as described in the media player documentation

The media_content_id payload can be any of the following:

  • The name of a track, artist or album. (for example, “Queen”)
  • A track or album combined with the artist name (for example, “Queen - Innuendo”)
  • A streaming provider URI (for example, spotify://artist/12345)

Examples

Play Adele’s album 25

entity_id: media_player.music_assistant_player
media_content_type: album
media_content_id: 'Adele - 25'

Play all tracks from Stevie Wonder in random order

entity_id: media_player.music_assistant_player
media_content_type: artist
media_content_id: 'Stevie Wonder'

Play the playlist The Best of Disco

entity_id: media_player.music_assistant_player
media_content_type: playlist
media_content_id: 'The Best of Disco'

Additional actions

Action music_assistant.play_media

Play media on a Music Assistant player with more fine-grained control options.

  • Data attribute: media_id
    • Optional: No.
    • Description: URI or name of the item to be played. Specify a list if it is desired to play/enqueue multiple items.
    • Example: spotify://playlist/aabbccddeeff
  • Data attribute: media_type
    • Optional: Yes.
    • Description: The type of content to play. Select from artist, album, track, playlist or radio. Will be auto-determined if omitted.
    • Example: playlist
  • Data attribute: artist
    • Optional: Yes.
    • Description: When specifying a track or album by name in the Media ID field, you can optionally restrict results by this artist name.
    • Example: Queen
  • Data attribute: album
    • Optional: Yes.
    • Description: When specifying a track by name in the Media ID field, you can optionally restrict results by this album name.
    • Example: News of the world
  • Data attribute: enqueue
    • Optional: Yes.
    • Description: If the content should be played now or be added to the queue. Options are:
      • play: Play now
      • replace: Replace the existing queue and play now
      • next: Add to the current queue after the currently playing item
      • replace_next: Replace the current queue after the currently playing item
      • add: Add to the end of the queue
    • Example: replace
  • Data attribute: radio_mode
    • Optional: Yes.
    • Description: Enable radio mode to auto-generate a playlist based on the selection.
    • Example: true

Action music_assistant.play_announcement

Play announcement on a Music Assistant player with more fine-grained control options.

  • Data attribute: url
    • Optional: No.
    • Description: URL to the notification sound.
    • Example: https://someremotesite.com/doorbell.mp3
  • Data attribute: use_pre_announce
    • Optional: Yes.
    • Description: Use pre-announcement sound. Omit to use the player default.
    • Example: true
  • Data attribute: announce_volume
    • Optional: Yes.
    • Description: Use a forced volume level for the announcement. Omit to use the player default.
    • Example: 75

Action music_assistant.transfer_queue

Transfer the player’s queue to another player.

  • Data attribute: source_player
    • Optional: Yes.
    • Description: The source media player which has the queue to be transferred. When omitted, the first playing player will be used.
    • Example: media_player.kitchen_speaker
  • Data attribute: auto_play
    • Optional: Yes.
    • Description: Start playing the queue on the target player. Omit to use the default behavior.
    • Example: true

Action music_assistant.search

Perform a global search on the Music Assistant library and all providers.

  • Data attribute: config_entry_id
    • Optional: No.
    • Description: The Music Assistant instance that the search will be performed upon. Allows for multiple servers to be running.
    • Example: Music Assistant
  • Data attribute: name
    • Optional: No.
    • Description: The name/title to search for.
    • Example: We Are The Champions
  • Data attribute: media_type
    • Optional: Yes.
    • Description: The type(s) of content to search for. Select from artist, album, track, radio, or playlist. All types if omitted.
    • Example: playlist
  • Data attribute: artist
    • Optional: Yes.
    • Description: When specifying a track or album in the name field, you can optionally restrict results by this artist name.
    • Example: Queen
  • Data attribute: album
    • Optional: Yes.
    • Description: When specifying a track in the name field, you can optionally restrict results by this album name.
    • Example: News of the world
  • Data attribute: limit
    • Optional: Yes.
    • Description: Maximum number of items to return (per media type).
    • Example: 10
  • Data attribute: library_only
    • Optional: Yes.
    • Description: Only include results that are in the library.
    • Example: true

Action music_assistant.get_library

Perform a local search on the Music Assistant library.

  • Data attribute: config_entry_id
    • Optional: No.
    • Description: The Music Assistant instance that the search will be performed upon. Allows for multiple servers to be running.
    • Example: Music Assistant
  • Data attribute: media_type
    • Optional: No.
    • Description: The type of content to search for. Select from artist, album, track, radio, or playlist.
    • Example: artist
  • Data attribute: favorite
    • Optional: Yes.
    • Description: When selected, only items marked as favorites will be returned.
    • Example: false
  • Data attribute: limit
    • Optional: Yes.
    • Description: Maximum number of items to return.
    • Example: 25
  • Data attribute: offset
    • Optional: Yes.
    • Description: From what point in the list should results be returned.
    • Example: 10
  • Data attribute: search
    • Optional: Yes.
    • Description: A string that will further filter the results.
    • Example: Home
  • Data attribute: order_by
    • Optional: Yes.
    • Description: Sort the list by this field. View available sorting options in the Developer Tools > Actions > music_assistant.get_library action.
    • Example: year
  • Data attribute: album_artists_only
    • Optional: Yes.
    • Description: When artist is the media_type then this option will restrict the result to album artists only.
    • Example: true
  • Data attribute: album_type
    • Optional: Yes.
    • Description: When album is the media_type then this option will restrict the result according to the selection of either album, single, compilation, EP or unknown.
    • Example: album

Action music_assistant.get_queue

Get the queue details of a Music Assistant player queue.

  • Data attribute: entity_id
    • Optional: No.
    • Description: The entity_id of the player holding the queue to be retrieved.
    • Example: media_player.kitchen_speaker

Notes

  • Any Home Assistant players added to Music Assistant will appear duplicated as the MA version of the player is created. The original HA player can be hidden if desired.