Home Assistant custom component to start Spotify playback on an idle chromecast devics or a Spotify Connect device (thanks to @kleinc80) which means that you can target your automation for chromecast as well as connect devices.
This component is not meant to be a full Spotify chromecast media_player but only serves to start the playback. Controlling the chromcast device and the Spotify playback after the initial start is done in their respective components. Becasue starting playback using the API requires more powerful token the username and password used for browser login is used.
Used by https://github.com/custom-cards/spotify-card.
Community post: https://community.home-assistant.io/t/spotcast-custom-component-to-start-playback-on-an-idle-chromecast-device/114232
This component is easiest installed using HACS
Copy all files from custom_components/spotcast/ to custom_components/spotcast/ inside your config Home Assistant directory.
Spotcast uses two cookies to authenticate against Spotify in order to have access to the required services.
To obtain the cookies:
- Using Chrome
- Open url
chrome://settings/cookies/detail?site=spotify.com
- If no cookies appear go to
https://open.spotify.com
and sign-in- Copy content from
sp_dc
andsp_key
cookies
- Using another browser
- Use a browser extension like "Export cookies" and look for
sp_dc
andsp_key
cookies
or
- Open a new Incognito window at https://accounts.spotify.com/en/login?continue=https:%2F%2Fopen.spotify.com%2F
- Open Developer Tools in your browser (might require developer menu to be enabled in some browsers)
- Login to Spotify.
- Search/Filter for
get_access_token
in Developer tools under Network.- Under cookies for the request save the values for
sp_dc
andsp_key
.- Close the window without logging out (Otherwise the cookies are made invalid).
- Alternatively you can use a browser plugin like "Export cookies".
Add the following to your config
spotcast:
sp_dc: !secret sp_dc
sp_key: !secret sp_key
Add accounts
dict to the configuration and populate with a list of accounts to
be able to initiate playback using diffferent accounts than the default.
spotcast:
sp_dc: !secret primary_sp_dc
sp_key: !secret primary_sp_key
accounts:
niklas:
sp_dc: !secret niklas_sp_dc
sp_key: !secret niklas_sp_key
ming:
sp_dc: !secret ming_sp_dc
sp_key: !secret ming_sp_key
{
"spotify_device_id" : "Kök",
"uri" : "spotify:playlist:37i9dQZF1DX3yvAYDslnv8",
"random_song": true
}
{
"device_name" : "Kök",
"uri" : "spotify:playlist:37i9dQZF1DX3yvAYDslnv8",
"random_song": true
}
where
device_name
is the friendly name of the Chromecasturi
is the spotify uri, supports all uris including track (limit to one track)random_song
optional parameter that starts the playback at a random position in the playlistrepeat
optional parameter that repeats the playlist/trackshuffle
optional parameter to set shuffle mode for playback.offset
optional paramter to set offset mode for playback. 0 is the first song.
optionally you can specify the entity_id
of an existing home assistant chromecast mediaplayer like:
{
"entity_id" : "media_player.vardagsrum",
"uri" : "spotify:playlist:37i9dQZF1DX3yvAYDslnv8"
}
Omitting uri
will transfer the playback to the specified device.
{
"device_name" : "Högtalare uppe"
}
Use the parameter force_playback
to continue the user's playback even if nothing is currently playing.
{
"device_name" : "MultiRoom",
"force_playback" : true
}
where
device_name
is the friendly name of the Chromecastforce_playback
(optional) true or false, true to continue the user's playback even if nothing is currently playing
{
"account":"niklas",
"device_name" : "Kök",
"uri" : "spotify:playlist:37i9dQZF1DX3yvAYDslnv8"
}
where
account
is the name of account key in the accounts dictionary in the configurationdevice_name
is the friendly name of the Chromecasturi
is the spotify uri, supports all uris including track (limit to one track)
The sensor has the discovered chromecasts as both json and since v.2.1 as an array of objects. Since v3.4.0 it does not do its own discovery but relies on data from core cast. Add the following to the sensor section of the configuration:
sensor:
- platform: spotcast
Sensor name
sensor.chromecast_devices
Attributes
devices_json: [{"name": "Kök", "cast_type": "audio", "model_name": "Google Home", "uuid": "xxxxx", "manufacturer": "Google Inc."}, {"name": "Högtalare uppe", "cast_type": "group", "model_name": "Google Cast Group", "uuid": "xxxx", "manufacturer": "Google Inc."}, {"name": "Vardagsrum", "cast_type": "cast", "model_name": "HK Citation 300", "uuid": "xxxx", "manufacturer": "Harman Kardon"}]
last_update: 2019-05-01T15:27:49.828553+02:00
friendly_name: Chromecast Devices
The components websocket api. Example usage:
// Retrieve playlists
const res = await this.props.hass.callWS({
type: 'spotcast/playlists',
playlist_type: 'featured', // one of 'user', 'discover-weekly' and 'featured'
country_code: 'SV', // Optional country code used by featured playlists
limit: 20, // Optional limit, default is 10
account: 'ming' // optional account name
});
// Retrieve devices
const res = await this.props.hass.callWS({
type: 'spotcast/devices',
account: 'ming' // optional account name
});
// Retrieve player
const res = await this.props.hass.callWS({
type: 'spotcast/player',
account: 'ming' // optional account name
});
If you like what I do and want to support me then I love coffee
Please do
Apache 2.0