A tool to connect a Spotify account to a Spotify Connect device via command line on the local lan.
My issue was that when spotifyd (base on librespot) would reset, spotify forgets it and I'm unable to cast music to it with spotcast from Home Assistant. Also, I don't want to log in permanently with spotifyd to let others on the local net to use the device to play music.
The tool encrypts the given username and password and sends it to the Spotify Connect device. Other authentication options are not provided.
Install zerospot with pip
python3 -m pip install zerospot
Read the help: zeroconf -h
a) From the command line:
zerospot <hostname-or-IP>:<port><path> --username my_username --password my_password
or
zerospot --host <hostname-or-IP> --port <port> --path <path> \
--username my_username --password my_password
b) Using a config file at a different location than ~/.config/zerospot/config.json
:
zerospot --config-file /path/to/config.json
c) or if you have a config file at the default location or environment variables set up simply use:
zerospot
Use it as a library
from zerospot import ZeroSpot
uri = 'http://<hostname-or-IP>:<port><path>'
username = 'my_username'
password = 'my_password'
zc = zerospot.ZeroSpot(uri, username, password)
zc.connect()
On Linux use:
avahi-browse --resolve _spotify-connect._tcp
and find the relevant fields: hostname
, port
and CPath=...
It possible to configure the tool using a json file. Default location: ~/.config/zerospot/config.json
Check config.json.example
for format.
All of the parameters can be set via environment variables using ZEROSPOT_<paramname>
convention.
These are the following:
ZEROSPOT_URI
ZEROSPOT_HOST
ZEROSPOT_PORT
ZEROSPOT_PATH
ZEROSPOT_USERNAME
ZEROSPOT_PASSWORD
There's an option to use FILE__ZEROSPOT_PASSWORD
to mark the location of a secret file that contains the password, perhaps to use it with Docker secrets.
The command line parameters have priority over environment variables.
Copy or clone the git repository under /config/custom_components/zerospot
There's no way to expand secrets in shell command, so the simplest way is to just put the whole shell command in secrets.yaml
:
zs_cmd: /config/custom_components/zerospot/bin/zerospot <host>:<port> --username <username> --password <password>
and in configuration.yaml
add:
shell_command:
zerospot: !secret zs_cmd
Link coming soon ...
-
Create pypi package out of this repo in order to use it in HACS integrations
-
Create HACS integration
-
Maybe support more types of login, but there are plenty of options to achieve this.
Many thanks to TimotheeGerber whose work I used extensively and to the librespot and the librespot-python guys for the awesome work.