homebridge-sonos-player
TypeScript icon, indicating that this package has built-in type declarations

1.1.2 • Public • Published

Homebridge sonos play

I couldn't find a working integration for playing mp3 files via the home app, thus, I created a small plugin that are able to send tracks to Sonos.

I Use this for an alarm - the switch is easily automatable inside the app.

Features:

The plugin allows you to create switches that when toggled on starts playing any mp3(and other formats that sonos supports) files.

You can customize volume, delay and timeout for these tracks, as well as which sonos devices should play the track.

Installing:

Using the homebridge web UI, or:

npm i -g homebridge-sonos-player

Configuration:

Either configure the plugin using the homebridge web ui, or though json:

{
  "platform": "SonosPlayerJub",
  "discoverFrom": "192.168.1.1"
  "switches": [
    {
      "name": "Switch name goes here - this will be seen in the home app",
      "trackUri": "Location of the mp3 file - must be located somewhere the Sonos devices can find it",
      "volume": 10,
      "delay": 100,
      "timeout": 10,
      "sonosSpeakerNames": ["Sonos-1"],
      "notification": true
    },
    {
      "name": "Switch name goes here - this will be seen in the home app",
      "trackUri": "http://(...)",
      "volume": 10,
      "delay": 100,
      "timeout": 10,
      "sonosSpeakerNames": ["Sonos-1", "Sonos-2"],
      "notification": false
    }
  ]
}
  • platform required: must always be "SonosPlayerJub"
  • discoverFrom optional: If you have problems with auto discovery, try setting a sonos ip in here.

Switch object:

  • name required: Name of the switch
  • trackUri required: Url for the audio file location. This could be either on WAN or though the internet.
  • sonosSpeakerNames required: Array for defining which speakers should play when the switch is activated
  • volume optional: Volume (in procentage) the speaker(s) should change to. Reverts back to the volume it was before the switch getting activated. Defaults to 25%.
  • delay optional: Delay (in ms) between the toggle on, and the audio plays. Defaults to 100ms
  • timeout optional: When Sonos should return to the original track (in seconds). I recommend setting this to the audio length in seconds + 2
  • isNotification optional: When playing as a notification, the track and volume will return to what was playing before the plugin triggered a new track

Thanks to:

A big thanks to bencevans for creating a node package to detect and send api calls to Sonos, and to svrooij for creating a typescript port. Without these, this plugin wouldn't have been created!

Package Sidebar

Install

npm i homebridge-sonos-player

Weekly Downloads

4

Version

1.1.2

License

Apache-2.0

Unpacked Size

43.8 kB

Total Files

28

Last publish

Collaborators

  • jub-skipperbendt