Skip to main content

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.

Quickstart

uv sync
uv run musickit convert ./input ./output       # convert
uv run musickit library audit ./output         # audit
uv run musickit tui ./output                   # TUI
uv run musickit serve ./output                 # Subsonic server

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:

Status

v0.4.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


Download files

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

Source Distribution

musickit-0.4.0.tar.gz (150.1 kB view details)

Uploaded Source

Built Distribution

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

musickit-0.4.0-py3-none-any.whl (191.4 kB view details)

Uploaded Python 3

File details

Details for the file musickit-0.4.0.tar.gz.

File metadata

  • Download URL: musickit-0.4.0.tar.gz
  • Upload date:
  • Size: 150.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for musickit-0.4.0.tar.gz
Algorithm Hash digest
SHA256 7ca8b84cf03e7bdc8899e684d8302dc240607fe4a05dcd7b3f6ba56eda56cfd0
MD5 a3d4b2c2e303433a024a1242678f19db
BLAKE2b-256 f1a987c276336558bad77420689b77cb31ce1b69ae9fc65d7aa98752dd7ab12a

See more details on using hashes here.

File details

Details for the file musickit-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: musickit-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 191.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for musickit-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e88faa417b96b7245b74b3588d1d07ce2c34851ea96888cb85ba8927bfba4cbd
MD5 639bc2d2ece368187ec63431fa095546
BLAKE2b-256 ebd6f6f0b451eff6a440b7eca020232a8528ce965344e87d534d25607d1f4939

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