openhab-addons/bundles/org.openhab.binding.sonos
Holger Friedrich de74eb51e9 Prepare for OH 5.0.0 (#17906)
* Switch to 5.0.0-SNAPSHOT
* Fix spotless after unleash
* resolve itest runbundles

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>
Signed-off-by: Ciprian Pascu <contact@ciprianpascu.ro>
2025-01-02 09:49:34 +02:00
..
src Reduce log level (#17647) 2025-01-02 09:49:25 +02:00
NOTICE
pom.xml Prepare for OH 5.0.0 (#17906) 2025-01-02 09:49:34 +02:00
README.md [sonos] Add support for Move 2 (#15706) 2023-10-07 16:45:52 +02:00

Sonos Binding

This binding integrates the Sonos Multi-Room Audio system.

Attention: You might run into trouble if your control system (the binding) is in another subnet than your Sonos device. Sonos devices make use of multicast which in most cases needs additional router configuration outside of a single subnet. If you observe communication errors (COMMUNICATION_ERROR/not registered), you might need to configure your router to increase the TTL of the packets send by your Sonos device. This happens because of a TTL=1 for ALIVE packets send by Sonos devices, resulting in dropped packets after one hop.

Supported Things

All available Sonos (playback) devices are supported by this binding. This includes the One, One SL, Move, Move 2, Roam, Roam SL, Play:1, Play:3, Play:5, Five, Era 100, Era 300, Connect, Connect:Amp, Port, Amp, SYMFONISK, Playbar, Playbase, Beam, Arc, Arc SL and Sub. The Bridge and Boost are not supported, but these devices do only have an auxiliary role in the Sonos network and do not have any playback capability. All supported Sonos devices are registered as an audio sink in the framework.

When being defined in a *.things file, the specific thing types One, OneSL, Move, Move2, Roam, RoamSL, PLAY1, PLAY3, PLAY5, Five, Era100, Era300, SYMFONISK, PLAYBAR, PLAYBASE, Beam, Arc, ArcSL, CONNECT, CONNECTAMP, Port and Amp should be used.

Please note that these thing types are case sensitive (you need to define them exactly as stated above).

Discovery

The Sonos devices are discovered through UPnP in the local network and all devices are put in the Inbox. Beware that all Sonos devices have to be added to the local Sonos installation as described in the Sonos setup procedure, e.g. through the Sonos Controller software or smartphone app.

Binding Configuration

The binding has the following configuration options, which can be set for "binding:sonos":

Parameter Name Description Required
opmlUrl OPML Service URL URL for the OPML/tunein.com service no
callbackUrl Callback URL URL to use for playing notification sounds, e.g. http://192.168.0.2:8080 no

Thing Configuration

The Sonos Thing requires the UPnP UDN (Unique Device Name) as a configuration value in order for the binding to know how to access it. All the Sonos UDN have the "RINCON_000E58D8403A0XXXX" format (value to be found via Sonos item in the Inbox). Additionally, a refresh interval, used to poll the Sonos device, can be specified (in seconds). You can use the notificationVolume property for setting a default volume (in percent) to be used to play notifications. In the thing file, this looks e.g. like

Thing sonos:PLAY1:1 [udn="RINCON_000E58D8403A0XXXX", refresh=60, notificationVolume=25]

Channels

The devices support the following channels:

Channel Type ID Item Type Access Mode Description Thing types
add String W Add the given Zone Player to the group of this Zone Player all
alarm Switch W Set the first occurring alarm either ON or OFF. Alarms first have to be defined through the Sonos Controller app all
alarmproperties String R Properties of the alarm currently running all
alarmrunning Switch R Set to ON if the alarm was triggered all
bass Number RW Set or get the bass level adjustment (value in range -10 / 10) all
batterycharging Switch R Indicator set to ON when the battery is charging Move, Move2, Roam, RoamSL
batterylevel Number R Current battery level Move, Move2, Roam, RoamSL
clearqueue Switch W Suppress all songs from the current queue all
codec String R Name of codec currently being decoded Arc, ArcSL, PLAYBAR, PLAYBASE, Beam, Amp
control Player RW Control the Zone Player, e.g. PLAY/PAUSE/NEXT/PREVIOUS all
coordinator String R UDN of the coordinator for the current group all
currentalbum String R Name of the album currently playing all
currentalbumart Image R Cover art of the album currently playing all
currentalbumarturl String R Cover art URL of the album currently playing all
currentartist String R Name of the artist currently playing all
currenttitle String R Title of the song currently playing all
currenttrack String R Name of the current track or radio station currently playing all
currenttrackuri String R URI of the current track all
currenttransporturi String R URI of the current AV transport all
favorite String W Play the given favorite entry. The favorite entry has to be predefined in the Sonos Controller app all
heightlevel Number RW Set or get the height level adjustment (value in range -10 / 10) Arc, ArcSL
led Switch RW Set or get the status of the white LED on the front of the Zone Player all
linein Switch R Indicator set to ON when the line-in of the Zone Player is connected PLAY5, Five, Move 2, Era100, Era300, CONNECT, CONNECTAMP, PLAYBAR, PLAYBASE, Beam, Port
analoglinein Switch R Indicator set to ON when the analog line-in of the Zone Player is connected Amp
digitallinein Switch R Indicator set to ON when the digital line-in of the Zone Player is connected Amp
localcoordinator Switch R Indicator set to ON if the this Zone Player is the Zone Group Coordinator all
loudness Switch RW Enable or disable the loudness all
microphone Switch R Indicator set to ON when the microphone is enabled Arc, Beam, Move, Move2, One, Roam, Era100, Era300
mute Switch RW Set or get the mute state of the master volume of the Zone Player all
nightmode Switch RW Enable or disable the night mode feature PLAYBAR, PLAYBASE, Beam, Amp
notificationsound String W Play a notification sound by a given URI all
playlinein String W This channel supports playing the audio source connected to the line-in of the zoneplayer identified by the Thing UID or UPnP UDN provided by the String. All
playlist String W Play the given playlist. The playlist has to predefined in the Sonos Controller app all
playqueue Switch W Play the songs from the current queue all
playtrack Number W Play the given track number from the current queue all
playuri String W Play the given URI all
publicaddress Switch W Put all Zone Players in one group, and stream audio from the line-in from the Zone Player that triggered the command all except Amp
publicanalogaddress Switch W Put all Zone Players in one group, and stream audio from the analog line-in from the Zone Player that triggered the command Amp
publicdigitaladdress Switch W Put all Zone Players in one group, and stream audio from the digital line-in from the Zone Player that triggered the command Amp
radio String W Play the given radio station. The radio station has to be predefined in the Sonos Controller app all
remove String W Remove the given Zone Player from the group of this Zone Player all
repeat String RW Repeat the track or queue playback. The accepted values are OFF, ONE and ALL all
restore Switch W Restore the state of the Zone Player all
restoreall Switch W Restore the state of all the Zone Players all
save Switch W Save the state of the Zone Player all
saveall Switch W Save the state of all the Zone Players all
shuffle Switch RW Shuffle the queue playback all
sleeptimer Number RW Set/show the duration of the SleepTimer in seconds all
snooze Number W Snooze the running alarm, if any, with the given number of minutes all
speechenhancement Switch RW Enable or disable the speech enhancement feature PLAYBAR, PLAYBASE, Beam, One, Amp
standalone Switch W Make the Zone Player leave its Group and become a standalone Zone Player all
state String R The State channel contains state of the Zone Player, e.g. PLAYING, STOPPED, ... all
stop Switch W Write ON to this channel: Stops the Zone Player player. all
treble Number RW Set or get the treble level adjustment (value in range -10 / 10) all
subwoofer Switch RW Enable or disable the subwoofer Arc, ArcSL
subwoofergain Number RW Set or get the subwoofer gain adjustment (value in range -15 / 15) Arc, ArcSL
surround Switch RW Enable or disable the surround audio Arc, ArcSL
surroundmusicmode String RW Set or get the surround playback mode for music, either 0 for Ambient or 1 for full Arc, ArcSL
surroundmusiclevel Number RW Set or get the surround level adjustment for music (value in range -15 / 15) Arc, ArcSL
surroundtvlevel Number RW Set or get the surround level adjustment for TV (value in range -15 / 15) Arc, ArcSL
tuneinstationid String RW Provide the current TuneIn station id or play the TuneIn radio given by its station id all
volume Dimmer RW Set or get the master volume of the Zone Player all
zonegroupid String R Id of the Zone Group the Zone Player belongs to all
zonename String R Name of the Zone associated to the Zone Player all

The playline channel accepts as command either the thing UID or the UPnP UDN. Note that you can prefix your command value with "Analog," or "Digital," to distinguish the line-in of your Sonos device. This is useful for the Sonos Amp in particular.

Audio Support

All supported Sonos devices are registered as an audio sink in the framework. Audio streams are treated as notifications, i.e. they are fed into the notificationsound channel. The notificationsound channel change the volume of the audio sink to the value defined in the notificationVolume property of the thing and restores it after finished playing. Note that the Sonos binding has a limit of 20 seconds for notification sounds. Any sound that is longer than that will be cut off.

URL audio streams (e.g. an Internet radio stream) are an exception and do not get sent to the notificationsound channel. Instead, these will be sent to the playuri channel.

Full Example

demo.things:

Thing sonos:PLAY1:living [ udn="RINCON_000E58D8403A0XXXX", refresh=60]

demo.items:

Group Sonos <player>

Player Sonos_Controller   "Controller"                          (Sonos) {channel="sonos:PLAY1:living:control"}
Dimmer Sonos_Volume       "Volume [%.1f %%]" <soundvolume>      (Sonos) {channel="sonos:PLAY1:living:volume"}
Switch Sonos_Mute         "Mute"             <soundvolume_mute> (Sonos) {channel="sonos:PLAY1:living:mute"}
Switch Sonos_LED          "LED"              <switch>           (Sonos) {channel="sonos:PLAY1:living:led"}
String Sonos_CurrentTrack "Now playing [%s]" <text>             (Sonos) {channel="sonos:PLAY1:living:currenttrack"}
String Sonos_State        "Status [%s]"      <text>             (Sonos) {channel="sonos:PLAY1:living:state"}
String Sonos_PlayUri      "Playing URI [%s]" <text>             (Sonos) {channel="sonos:PLAY1:living:playuri"}
Switch PlayWebRadioUri

demo.sitemap:

sitemap demo label="Main Menu"
{
    Frame label="Sonos" {
        Default item=Sonos_Controller
        Slider  item=Sonos_Volume
        Switch  item=Sonos_Mute
        Switch  item=Sonos_LED
        Text    item=Sonos_CurrentTrack
        Text    item=Sonos_State
        Text    item=Sonos_PlayUri
        Switch  item=PlayWebRadioUri
    }
}

sonos.rules:

rule "Sonos Play Web Radio URI"
when Item PlayWebRadioUri changed to ON
then
    //Set URI to play
    Sonos_PlayUri.sendCommand("x-rincon-mp3radio://https://streams.egofm.de/egoFMBW-hq")
    //Set the Volume
    Sonos_Volume.sendCommand(40)
end