A Jukebox to play music on speakers using 'CD' with NFC tag
Project description
Jukebox [gukebox]
Bring a physical experience back to music streaming with NFC tags.
Pick an album, place it on the reader, and the music starts playing. Remove it, and playback pauses automatically.
📋 Table of contents
Install • First steps • Usage • Readers • Players • The library file • Developer setup
Jukebox is an NFC-powered music player for connected speakers.
- 💿 Turn NFC tags into albums, playlists, or radio stations
- 🎵 Supports Spotify, Apple Music, and other music providers
- 🔊 Currently supports Sonos, with more speaker platforms planned
- 📡 Currently supports PN532-compatible NFC readers
💡 Inspired by
Install
Install the package from PyPI.
[!WARNING] The package name is
gukeboxwithginstead of aj(due to a name already taken).
[!NOTE] The
pn532extra is optional but required for NFC reading, check compatibility.
Recommended installation
Use pip in a virtual environment.
- If your Python version is 3.13 or newer and you want NFC support, install the system GPIO binding:
sudo apt update
sudo apt install python3-lgpio
- Create a virtual environment:
# Python < 3.13
python3 -m venv jukebox
# Python >= 3.13 for NFC: use the system Python and include system packages
python3 -m venv --system-site-packages jukebox
source jukebox/bin/activate
- Install
gukeboxinto the virtual environment:
pip install "gukebox[pn532,ui]"
[!IMPORTANT] For NFC on Python 3.13+, use the system Python that comes with your OS. A separately installed Python 3.13+ from
uv,pyenv, Homebrew, or similar may not be able to import the systemlgpiopackage, even when using--system-site-packages. If you already upgraded to a non-system Python 3.13+, use the system Python instead or use Python 3.12 or lower.
Alternative installations
pipxcan be used with--system-site-packages.uvx/uv tool installare not recommended for NFC on Python 3.13+ because they may select a non-system interpreter.- For non-system Python 3.13+, you can still install via pip/uv/poetry/etc. but you must build the
lgpiopackage from source and it may require other system packages. - All releases can be downloaded and installed from the GitHub releases page.
Installation for development
For development read the Developer setup section.
git clone https://github.com/Gudsfile/jukebox.git
uv sync
Python Compatibility
Jukebox 1.0+ requires Python 3.11 or newer.
| Python version | Compatible Jukebox versions | Notes |
|---|---|---|
| 3.7 | 0.4.0 – 0.4.1 | Legacy |
| 3.8 | 0.4.0 – 0.5.4 | Legacy |
| 3.9 – 3.10 | 0.4.0 – 0.9.0 (incl. 1.0.0.dev13) | Legacy |
| 3.11 – 3.12 | 0.4.0 – latest | Actively supported |
| 3.13 | 0.5.3 – latest | Actively supported (see installation notes) |
First steps
Initialize the library file with jukebox-admin or manually create it at ~/.config/jukebox/library.json.
Launch the web UI (requires the ui extra):
jukebox-admin ui
Usage
Start the jukebox with the jukebox command:
jukebox --player PLAYER --reader READER
🎉 With choosing the sonos player and pn532 reader, by approaching a NFC tag stored in the library.json file, you should hear the associated music begins.
Optional Parameters
| Parameter | Description |
|---|---|
--help |
Show help message. |
--player PLAYER |
Player to use (sonos, dryrun). |
--reader READER |
Reader to use (pn532, dryrun). |
--library |
Path to the library file, default: ~/.config/jukebox/library.json. |
--pause-delay SECONDS |
Grace period before pausing when the NFC tag is removed. Fractional values such as 0.5 or 0.2 are supported, with a minimum of 0.2 seconds to avoid pausing on brief missed reads. Default: 0.25 seconds. |
--pause-duration SECONDS |
Maximum duration of a pause before resetting the queue. Default: 900 seconds (15 minutes). |
--verbose |
Enable verbose logging. |
--version |
Show version. |
Readers
| Name | Description |
|---|---|
Dry Run (dryrun) |
Simulates NFC tag reading via stdin. Input format: tag_id or tag_id duration_seconds. |
Pn532 NFC (pn532) |
Reads physical NFC tags. Works with a PN532 reader and NTAG2xx tags. Requires the pn532 extra and SPI enabled on the Raspberry Pi. |
[!NOTE] See docs/readers.md for full setup, hardware requirements, and settings reference.
Players
[!NOTE] See docs/players.md for the full configuration reference.
Admin CLI
Use jukebox-admin for admin workflows such as settings inspection and the admin API/UI servers.
settings
jukebox-admin settings show
jukebox-admin settings show --effective
api and ui
To use the api and ui commands, additional packages are required. You can install the package[extra] syntax regardless of the package manager you use, for example:
uv tool install gukebox[api]
# ui includes the api extra
uv tool install gukebox[ui]
When running from this repository with uv, include the extra on the command as well:
uv run --extra api jukebox-admin api
uv run --extra ui jukebox-admin ui
library
The library command lets you manage the library through a CLI or an interactive CLI:
jukebox-admin library add tag_id --uri /path/to/media.mp3
or to pull the tag_id currently on the reader:
jukebox-admin library add --from-current --uri /path/to/media.mp3
Other commands are available, use --help to see them.
The library file
The library.json file is a JSON file that maps each NFC tag to what to play.
It is used by the jukebox command to find the corresponding metadata for each tag.
The jukebox-admin library command helps you manage this file with a CLI, an interactive CLI, an API or a UI (see jukebox-admin --help).
By default, this file should be placed at ~/.config/jukebox/library.json. But you can use another path by creating a JUKEBOX_LIBRARY_PATH environment variable or with the --library argument.
{
"discs": {
"a:tag:uid": {
"uri": "URI of a track, an album or a playlist on many providers",
"option": { "shuffle": true }
},
"another:tag:uid": {
"uri": "uri"
},
…
}
}
The discs part is a dictionary containing NFC tag UIDs.
Each UID is associated with an URI.
URIs are the URIs of the music providers (Spotify, Apple Music, etc.) and relate to tracks, albums, playlists, etc.
metadata is an optional section where the names of the artist, album, song, or playlist are entered:
"a:tag:uid": {
"uri": "uri",
"metadata": { "artist": "artist" }
}
It is also possible to use the shuffle key to play the album in shuffle mode:
"a:tag:uid": {
"uri": "uri",
"option": { "shuffle": true }
}
To summarize, for example, if you have the following ~/.config/jukebox/library.json file:
{
"discs": {
"ta:g1:id": {
"uri": "uri1",
"metadata": { "artist": "a", "album": "a" }
},
"ta:g2:id": {
"uri": "uri2",
"metadata": { "playlist": "b" },
"option": { "shuffle": true }
}
}
}
Then, the jukebox will find the metadata for the tag ta:g2:id and will send the uri2 to the speaker so that it plays playlist "b" in random order.
Developer setup
Install
Install the project by cloning it and using uv to install the dependencies:
git clone https://github.com/Gudsfile/jukebox.git
uv sync
To install dependencies for all extras (api, ui and pn532):
uv sync --extra api --extra ui # --extra pn532
[!NOTE] The
pn532extra requires compatible hardware and is intentionally excluded from this command.
If needed, you can use a .env file and uv run --env-file .env <command to run>.
A .env.example file is available, you can copy it and modify it to use it.
Create a library.json file and complete it with the desired NFC tags and CDs.
Take a look at library.example.json and the The library file section for more information.
Usage
Start the jukebox with uv and use --help to show help message
uv run jukebox --player PLAYER_TO_USE --reader READER_TO_USE
Use jukebox-admin for admin commands:
uv run jukebox-admin settings show
For the server-backed admin commands, include the matching extra:
uv run --extra api jukebox-admin api
uv run --extra ui jukebox-admin ui
Development commands
| Command | Description |
|---|---|
uv run ruff format |
Format the code. |
uv run ruff check |
Check the code. |
uv run ruff check --fix |
Fix the code. |
uv run pytest |
Run the tests. |
Pre-commit
prek is configured; you can install it to automatically run validations on each commit.
uv tool install prek
prek install
Contributing
Contributions are welcome! Feel free to open an issue or a pull request.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gukebox-1.4.0.dev1.tar.gz.
File metadata
- Download URL: gukebox-1.4.0.dev1.tar.gz
- Upload date:
- Size: 77.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.23 {"installer":{"name":"uv","version":"0.11.23","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
506e0239b536c643002d812586b243bd76143dba9b21db23815d5fa3311a0f9e
|
|
| MD5 |
3e8451e6cb714ae47abde50dae5510a2
|
|
| BLAKE2b-256 |
6df23c5f42b9ba2c155cb1e958c0c47c0f48d0f8032cc092cb2a7dc519afbb14
|
File details
Details for the file gukebox-1.4.0.dev1-py3-none-any.whl.
File metadata
- Download URL: gukebox-1.4.0.dev1-py3-none-any.whl
- Upload date:
- Size: 117.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.23 {"installer":{"name":"uv","version":"0.11.23","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3e6269932520b8e6b48eb4b06651ae51f1e4e392a3e1871fecc034c9c9968796
|
|
| MD5 |
288156b223cc71fa6155ba8a2202866d
|
|
| BLAKE2b-256 |
839faa5c236705f9e45041c1676de22301f8f050b927fa7fdc9ee0a0d8d39d67
|