Self-hosted music toolkit: convert / audit / retag rips into a clean tagged library, browse + play via a Textual TUI (local / internet radio / Subsonic-client / AirPlay), and stream over Tailscale via a Subsonic-compatible HTTP server.
Project description
musickit
Python 3.13 CLI for converting audio rips into a clean tagged library, browsing and playing it via a Textual TUI, and streaming it over Tailscale via a Subsonic-compatible HTTP server.
Install
The lowest-friction way is uvx — it downloads, caches, and runs the latest published musickit in one step. No install step required:
uvx musickit --help
For daily / persistent use (PATH-installed, no per-run network check):
uv tool install musickit
musickit --help
You'll also need ffmpeg and ffprobe on $PATH for the convert pipeline:
brew install ffmpeg # macOS
sudo apt install ffmpeg # Debian / Ubuntu
Quickstart
uvx musickit convert ./input ./output # convert
uvx musickit library audit ./output # audit
uvx musickit tui ./output # TUI
uvx musickit serve ./output # Subsonic server
Screenshots
The TUI: artist browser on the left, drilled into an album, 48-band visualizer at the top.
Fullscreen visualizer (f):
More screenshots in the TUI guide.
Documentation
Full docs are at docs/ — built with MkDocs Material. Run them locally:
make docs-serve # http://127.0.0.1:8000
Or jump straight to:
- Architecture — how all the pieces fit together (process model, data flow, audio subprocess, SQLite index, FFT visualizer)
- Quickstart — end-to-end walkthrough including iPhone + Tailscale + Amperfy
- musickit convert — codec / bitrate / enrichment matrix
- musickit library — audit rules + auto-fix + SQLite index
- musickit tui — TUI: local + radio + Subsonic-client + AirPlay
- musickit serve — Subsonic API + Tailscale + clients
- Edge cases — every weirdness encountered on real rips
- Roadmap — what's next
- Development — directory layout + test patterns + commit style
Status
v0.5.0 · ruff + mypy + pyright clean, full pytest suite green. Five top-level commands — convert, library, inspect, tui, serve — with library carrying the read / mutate / manage subcommands (tree, audit, fix, cover, cover-pick, retag, index). The TUI ships local-library playback, internet radio, Subsonic-client mode, AirPlay output (incl. pause + volume routing), mDNS discovery, ReplayGain normalisation, an incremental /-filter, in-place tag editing (e for track / album-wide), a 48-band FFT visualiser, and click-to-seek on the progress bar. Audio decoder + sounddevice callback run in a separate process so UI work in the main interpreter can't stall playback. The server is OpenSubsonic-compatible (multipleGenres, transcodeOffset, songLyrics extensions) and tested against Symfonium / Amperfy / play:Sub / Feishin clients on iOS / Android / desktop. A persistent SQLite library index at <root>/.musickit/index.db makes cold starts skip the filesystem walk + tag read; the filesystem watcher does per-album incremental rescans.
License
See LICENSE in the repo root.
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 musickit-0.6.0.tar.gz.
File metadata
- Download URL: musickit-0.6.0.tar.gz
- Upload date:
- Size: 158.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.9 {"installer":{"name":"uv","version":"0.11.9","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 |
58fe485536d8a93ee26d65aabe8ac76d44cd968160bdb94e57b02efbda9c96a2
|
|
| MD5 |
0928c5d8953020778ef5c14c5e92d947
|
|
| BLAKE2b-256 |
0d2a2698d224e363757dae0c0ae6243d087e7be298cd3b4d4aad20f8351a7690
|
File details
Details for the file musickit-0.6.0-py3-none-any.whl.
File metadata
- Download URL: musickit-0.6.0-py3-none-any.whl
- Upload date:
- Size: 202.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.9 {"installer":{"name":"uv","version":"0.11.9","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 |
4ea494fa4ecb76868ec5c2d6f054d0a33875182d78c97ecbcf67938ad7084659
|
|
| MD5 |
b4c4d032690929030aa90b9d118fb2ff
|
|
| BLAKE2b-256 |
7a3f0c0582f584b7293c1f5193eee8e1c994423765d5900ed7f3a10876ae03d9
|