Bang & Olufsen
The Bang & Olufsen integration enables control of some of the features of certain Bang & Olufsen
Compatible devices
Devices that have been tested and should work without any trouble are:
- Beoconnect Core
- Beolab 8
- Beolab 28
- Beosound 2 3rd gen
- Beosound A5
- Beosound A9 5th gen
- Beosound Balance
- Beosound Emerge
- Beosound Level
- Beosound Theatre
and any other Mozart
Configuration
To add the Bang & Olufsen device to your Home Assistant instance, use this My button:
Bang & Olufsen 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.
-
In the bottom right corner, select the
Add Integration button. -
From the list, select Bang & Olufsen.
-
Follow the instructions on screen to complete the setup.
The IP address of your device. Can be found by navigating to the device on the Bang & Olufsen appSettings
→ About
→ IP address
.
Data updates
The Bang & Olufsen integration uses the Mozart API
Supported features
Currently, a single device with a media_player
entity is created for each added physical device. For advanced automations, events are fired in Home Assistant.
Media player
A number of features are available through the media player entity:
- See current metadata, progress, volume, etc.
- Control next/previous, play/pause, shuffle/repeat settings, volume, sound mode, audio and video sources, and more.
- Play various media through play_media actions.
- Control multiroom audio through Beolink
: - Control with Home Assistant media_player grouping.
- Monitor current Beolink state through media player properties.
- For more advanced usage, custom Beolink services have been defined:
- Connect or expand to ASE
products not available in Home Assistant. - Expand sessions to all discovered devices.
- Connect to, expand to or unexpand devices.
- Set all connected Beolink devices to standby.
- Connect or expand to ASE
Limitations
Currently, some features of the Mozart platform such as:
- Creating timers and alarms
- Retrieving detailed alarm and timer information
And more advanced app-centric features such as:
- Creating presets
- Creating listening positions
- Creating sound modes
- Creating stereo pairs
- Adjusting specific sound settings
- Pairing remotes
These features are not available through the API. Some may become available at a later point, but until then the Bang & Olufsen App
Actions
play_media actions
The Bang & Olufsen integration supports different playback types in the media_player.play_media
action: playback from URL, activating a favorite, playback from a local file, playing a radio station, activating a Deezer flow and Deezer playlists, albums, tracks, and playing files and text-to-speech (TTS) as an overlay.
play_media examples
Playing DR P1
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: url
media_content_id: http://live-icy.dr.dk/A/A03H.mp3
Activating the first favourite:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: favourite
media_content_id: 1
Playing a local file:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_id: media-source://media_source/local/example.mp3
media_content_type: music
Playing a radio station:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_id: 1234567890123456
media_content_type: radio
Playing a Deezer flow. Optionally define a Deezer user ID:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: deezer
media_content_id: flow
extra:
id: 1234567890
Playing a Deezer playlist. Optionally define starting position for the playlist:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: deezer
media_content_id: playlist:1234567890
extra:
start_from: 123
Playing a Deezer album. Optionally define starting position for the album:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: deezer
media_content_id: album:1234567890
extra:
start_from: 123
Playing a Deezer track:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: deezer
media_content_id: 1234567890
Playing a Tidal playlist. Optionally define starting position for the playlist:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: tidal
media_content_id: playlist:01234567-89ab-cdfe-0123-456789abcdef
extra:
start_from: 123
Playing a Tidal album. Optionally define starting position for the album:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: tidal
media_content_id: album:123456789
extra:
start_from: 123
Playing a Tidal track:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: tidal
media_content_id: 123456789
Overlay
Interrupts currently playing media to play an audio message.
To use the Bang & Olufsen Cloud TTS, use overlay_tts
as the media_content_type
and enter a message into the media_content_id
field.
Bang & Olufsen Cloud TTS messages are limited to 100 unique messages a day and are cached for 24 hours.
Extra keys available:
Data attribute | Optional | Description |
---|---|---|
overlay_absolute_volume |
yes | Specify an absolute volume for the overlay. |
overlay_offset_volume |
yes | Specify a volume offset to be added to the current volume level. |
overlay_tts_language |
yes | Specify the language used for text-to-speech. Uses the BCP 47 standard. Default value is “en-us”. |
Examples:
Playing a local file with an absolute volume as an overlay:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: music
media_content_id: media-source://media_source/local/doorbell.mp3
announce: true
extra:
overlay_absolute_volume: 60
Playing a Bang & Olufsen Cloud TTS message with an offset volume (as TTS messages can be quiet):
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: overlay_tts
media_content_id: This is a test
announce: true
extra:
overlay_offset_volume: 10
Playing a Bang & Olufsen Cloud TTS message with a local language:
action: media_player.play_media
target:
entity_id: media_player.beosound_balance_12345678
data:
media_content_type: overlay_tts
media_content_id: Dette er en test
announce: true
extra:
overlay_tts_language: da-dk
Custom actions
The Bang & Olufsen integration additionally supports different custom actions
bang_olufsen.beolink_join
Join a Beolink experience.
Action data attribute | Optional | Description |
---|---|---|
beolink_jid |
yes | Manually specify Beolink JID to join. |
bang_olufsen.beolink_expand
Expand current Beolink experience.
Action data attribute | Optional | Description |
---|---|---|
all_discovered |
yes | Expand Beolink experience to all discovered devices. |
beolink_jids |
yes | Specify which Beolink JIDs will join current Beolink experience. |
bang_olufsen.beolink_unexpand
Unexpand from current Beolink experience.
Action data attribute | Optional | Description |
---|---|---|
beolink_jids |
no | Specify which Beolink JIDs will leave from current Beolink experience. |
bang_olufsen.beolink_leave
Leave a Beolink experience.
bang_olufsen.beolink_allstandby
Set all connected Beolink devices to standby.
Automations
WebSocket notifications received from the device are fired as events in Home Assistant. These can be received by listening to bang_olufsen_websocket_event
event types, where device_id
or serial_number
can be used to differentiate devices.
Getting Deezer URIs
To find Deezer playlist, album URIs, and user IDs for Deezer flows, the Deezer website has to be accessed. When navigating to an album, the URL will look something like: https://www.deezer.com/en/album/ALBUM_IDalbum:ALBUM_ID
and the same applies to playlists, which have the format: playlist:PLAYLIST_ID
.
Additionally a Deezer user ID can be found at https://www.deezer.com/en/profile/USER_ID
Getting Tidal URIs
Tidal playlists, album URIs and track IDs are available via the Tidal website. When navigating to an album, the URL will look something like https://listen.tidal.com/album/ALBUM_ID/album:ALBUM_ID
. The same applies to playlists, which have the format playlist:PLAYLIST_ID
. Individual tracks can be found by sharing the track and selecting the Copy track link
method, which should yield a link of the format https://tidal.com/browse/track/TRACK_ID?uTRACK_ID
.
Beolink
Discovered devices and devices in an active Beolink experience are available in the properties of the media_player entity. A device is represented by its friendly name and JID, used for connecting devices.
beolink:
self: The current device
leader: Beolink leader (if available)
listeners: Beolink listeners (if available)
peers: Beolink peers (if available)
Diagnostics and troubleshooting
The Bang & Olufsen integration supports Home Assistant debug logs and diagnostics. Where all received WebSocket events are provided through debug logs and the WebSocket connection state, config entry and media player state is provided through diagnostics.
Removing the integration
This integration follows standard integration removal. No extra steps are required.
To remove an integration instance from Home Assistant
- Go to Settings > Devices & services and select the integration card.
- From the list of devices, select the integration instance you want to remove.
- Next to the entry, select the three-dot
menu. Then, select Delete.