Skip to main content

A Spotizerr authentication utility for configuring Spotify credentials

Project description

Spotizerr Authentication Utility

A command-line tool to help you authenticate and register a Spotify account with your Spotizerr instance. This utility simplifies the process by programmatically capturing Spotify session credentials and posting them to your Spotizerr backend.

Features

  • Interactive Setup: Guides you through the process of connecting to your Spotizerr instance.
  • API Credential Check: Automatically checks if your Spotizerr instance has the required Spotify API client_id and client_secret and prompts you to add them if they are missing.
  • Spotify Connect Integration: Uses librespot-spotizerr to create a temporary Spotify Connect device, allowing you to capture credentials securely by simply playing a song.
  • Colored Output: Uses color-coded terminal output to highlight important information and make the process easier to follow.
  • Clean Exit: Gracefully handles interruptions and ensures a clean shutdown.

Prerequisites

Usage

Run the script from your terminal:

docker run --network=host --rm -it cooldockerizer93/spotizerr-auth

If docker doesn't work (it probably won't unless your on linux) you can still run it in bare metal.

Run the installer

Linux / macOS
python3 -m venv .venv && source .venv/bin/activate && pip install spotizerr-auth
Windows (PowerShell)
python -m venv .venv; .venv\Scripts\Activate.ps1; pip install spotizerr-auth
Windows (cmd.exe)
python -m venv .venv && .venv\Scripts\activate && pip install spotizerr-auth

And then run

spotizerr-auth

You will have to activate the virtual environment every time you want to use the tool.

The script will guide you through the following steps:

  1. Enter Spotizerr URL: You'll be prompted for the base URL of your Spotizerr instance. You can press Enter to use the default (http://localhost:7171).

  2. Configure API Credentials: The script checks if your Spotizerr instance is configured with a Spotify client_id and client_secret.

    • If they are missing, it will ask if you want to configure them.
    • Select y and enter your credentials when prompted. This is a one-time setup.
  3. Enter Account Details:

    • Provide a name for the account to identify it in Spotizerr.
    • Enter your two-letter Spotify region code (e.g., US, DE, MX).
  4. Authenticate via Spotify Connect:

    • The utility will start a Spotify Connect device on your network (e.g., librespot-spotizerr).
    • Open Spotify on any device (phone, desktop), start playing a track, and use the "Connect to a device" feature to transfer playback to the new device.
    • Once you transfer playback, the script captures the session, creates a credentials.json file, and shuts down the Connect server.
  5. Register with Spotizerr: The script automatically sends the captured credentials to your Spotizerr instance, creating or updating the account.

  6. Cleanup: Finally, it will ask if you want to delete the credentials.json file. It's recommended to do so for security.

After these steps, your Spotify account will be registered in Spotizerr and ready to use.

How It Works

The script uses librespot-spotizerr's Zeroconf implementation to advertise a Spotify Connect device on the local network. When you transfer playback to this device, librespot-spotizerr handles the authentication with Spotify's servers and stores the session details (including the necessary refresh token) in a local credentials.json file.

Once this file is created, the script reads it and makes a POST request to the Spotizerr API endpoint /api/credentials/spotify/{accountName}. The request body is a JSON object containing the user's region and the contents of credentials.json, which Spotizerr then stores for future use.

The initial check for client_id and client_secret ensures that Spotizerr has the necessary global API credentials to perform metadata lookups and other API-dependent tasks.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

spotizerr_auth_phoenix-0.0.11.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

spotizerr_auth_phoenix-0.0.11-py3-none-any.whl (8.6 kB view details)

Uploaded Python 3

File details

Details for the file spotizerr_auth_phoenix-0.0.11.tar.gz.

File metadata

  • Download URL: spotizerr_auth_phoenix-0.0.11.tar.gz
  • Upload date:
  • Size: 9.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for spotizerr_auth_phoenix-0.0.11.tar.gz
Algorithm Hash digest
SHA256 ef688cf7d30db1e9a4edda5d22c8e74d5c540d28be54ae58be7ed13b1b29806f
MD5 dd6c3d1520e9795e635118a8aea16259
BLAKE2b-256 bf2814ca18f84d9e26fcbe120bbda4c19b148f478d76e0fa53ed6f803d5c35fd

See more details on using hashes here.

File details

Details for the file spotizerr_auth_phoenix-0.0.11-py3-none-any.whl.

File metadata

File hashes

Hashes for spotizerr_auth_phoenix-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 34eb5d997b02fe2e15029c11bb335306449f6eaad3a756083ad72d3769aae152
MD5 eb2c6f726565b8b42adc595b5cf041c3
BLAKE2b-256 cdab1616348e364d65e2a175c91d72e2a4f54f987a4c4c21dd478cb99c71d4df

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page