6 releases
0.1.6 | Oct 7, 2024 |
---|---|
0.1.5 | Oct 6, 2024 |
#124 in Authentication
29KB
207 lines
spotify-quickauth
A simple CLI-based application for creating a credentials.json
file, used by librespot
derived applications, such as spotify-player, spotifyd, and raspotify.
- One command, no compilation, all platforms (Windows, Linux, MacOS), ARM included
- Automatically places configuration files
- No dependencies, no installation, no fuss
Quickstart
You can run this application without installing anything by using the following commands.
curl -sSL https://xevion.github.io/spotify-quickauth/run.sh | sh -s --
The default invocation is likely fine for most users, it will try to understand the available paths for credentials.json
to be written to, and allow you to select them.
Automatic detection is dependent on the related software being installed and/or relevant configuration files being present.
For Windows, you can paste this command into PowerShell:
iex (irm "https://xevion.github.io/spotify-quickauth/run.ps1")
Usage
This application is dead simple to use. Just run the command, and it'll tell you to connect to a fake 'device' in your Spotify interface.
You must be connected to the same network running
spotify-quickauth
, as thezeroconf
technology does not work across networks nor proxies.
Once you connect, the credentials file will be created, and you'll be prompted to select which location(s) to place it in. Even if none of the relevant librespot
applications are detected or installed, you can specify manual locations, or the current working directory.
Installation
Installation is not necessary to use this application, but if you're having trouble, want to compile it yourself, or are using it frequently, you might want to install it.
The scripts above can be given the
-K
or--keep
flag to keep the downloaded binary. This will prevent repeated API calls to GitHub if you're using the script frequently within a short period.
Pre-built Binaries
Binaries are always available for download from the releases page, and they're the same ones used by the shell scripts above.
Currently, the following targets are available for download:
- x64 Linux (MUSL)
x86_64-unknown-linux-musl
- ARM64 Linux (MUSL)
aarch64-unknown-linux-musl
- ARMv7 Linux
armv7-unknown-linux-musleabihf
- Intel MacOS
x86_64-apple-darwin
- Apple Silicon MacOS
aarch64-apple-darwin
- x64 Windows
x86_64-pc-windows-msvc
- ARM64 Windows
aarch64-pc-windows-msvc
Please file an issue if you are on a platform that is not supported, or if you encounter issues with the binaries.
Via cargo-binstall
If the package cannot be found for your target or fails to be downloaded for any reason,
cargo-binstall
will automatically fall back to building the package from source.
cargo-binstall
is a tool that allows you to install binaries from crates.io without needing to compile them yourself.
cargo binstall spotify-quickauth
If you're curious where the binary comes from, cargo-binstall
will likely pull the binary directly from the latest release by this repository, selecting the most appropriate target for your host.
Manual Installation
If you'd like to use the shell script above to install the binary, you can use the -S/--stop
flag to prevent the script from running the binary after downloading it. It implicitly applies the --keep
flag too.
You'll need to move the binary yourself though:
curl -sSL https://xevion.github.io/spotify-quickauth/run.sh | sh -s -- -S
mv spotify-quickauth /usr/local/bin
Make sure your directory of choice is in your $PATH though!
Building from Source
Don't want to run my funky shell script? No problem! You can build the application from source easily.
- You'll need
cargo
, the Rust build system and package manager. It's included with the Rust toolchain, which you can install from rustup.rs - This is an early project, so the minimum supported version of Rust is not known. I'm developing on 1.81.0 though.
git clone https://github.com/Xevion/spotify-quickauth.git
cd spotify-quickauth
cargo install --path .
spotify-quickauth --help
If you have any troubles building the project
- Make sure you're using a target that's supported by the project (see above).
- Certain targets may require specfic linkers. For example,
Dependencies
~15–26MB
~381K SLoC