Terminal music player for TIDAL — search, browse, queue, and stream lossless audio from your terminal
Project description
Ticli
A terminal music player for TIDAL. Search, browse, queue, and play music — all from your terminal.
Ticli connects directly to TIDAL's API using your premium account. No desktop app needed. Just authenticate, search, and play.
Works on macOS and Linux.
╭──────────────────────── Ticli ────────────────────────╮
│ │
│ ▶ ♥ Arlo Parks - Sophie │
│ Super Sad Generation │
│ 1:47 ━━━━━━━━●━━━━━━━━━━━━━━━━━━━━━━━━━━━ 3:28 │
│ Queue: 3/12 LOSSLESS │
│ Next: Cola • Arlo Parks │
│ │
│ [space] play/pause [n/→] next [←] prev │
│ [s] search [q] queue [p] playlists │
│ [l] like [r] radio [t] mini [m] more │
│ │
╰────────────────────────────────────────────────────────╯
Features
- Search — Find tracks, albums, artists, and playlists
- Browse — Navigate album and playlist tracklists
- Queue — Manage your playback queue, reorder, remove tracks
- Playlists — Browse and play your saved playlists
- Likes — Toggle favorites on any track
- Radio — Generate a station from any track
- Mini mode — Condensed single-line display
- Session restore — Picks up where you left off
- Lossless & Hi-Res — Stream up to 24-bit/192kHz FLAC
- Secure auth — OAuth tokens stored in your OS keychain
Install
Requires Python 3.10+ and ffmpeg.
# macOS
brew install ffmpeg python3
pip install tidal-cli
# Ubuntu / Debian
sudo apt install ffmpeg python3-pip
pip install tidal-cli
For secure token storage in your OS keychain (recommended):
pip install "tidal-cli[keyring]"
Usage
ticli
On first run you'll get a URL to authorize with your TIDAL account. After that, your session is cached and you go straight to the player.
Quality
ticli --quality HIRES # 24-bit hi-res FLAC
ticli --quality LOSSLESS # 16-bit FLAC
ticli --quality HIGH # lossless FLAC (default)
ticli --quality LOW # 320kbps
Keybindings
Player
| Key | Action |
|---|---|
space |
Play / pause |
n → |
Next track |
← |
Previous track |
s |
Search |
q |
Queue |
p |
Playlists |
l |
Like / unlike track |
r |
Start radio from track |
t |
Toggle mini player |
m |
Show more controls |
esc |
Quit |
Search
| Key | Action |
|---|---|
↑ ↓ |
Navigate results |
enter → |
Play track / open album or artist |
backspace |
Delete character |
esc ← |
Back |
Queue
| Key | Action |
|---|---|
↑ ↓ |
Navigate |
enter |
Jump to track |
x |
Remove track |
esc ← |
Back |
How it works
Ticli uses tidalapi to authenticate and fetch audio stream URLs. Audio is played through ffplay. The TUI is built with Rich.
┌─────────┐ OAuth ┌───────────┐ stream URL ┌───────────┐
│ Ticli │ ──────────────► │ TIDAL │ ──────────────► │ ffplay │
│ (TUI) │ ◄────────────── │ API │ │ │
└─────────┘ metadata └───────────┘ └───────────┘
Auth & credentials
OAuth tokens are stored in your OS keychain (macOS Keychain or GNOME Keyring). Falls back to ~/.config/ticli/session.json with 0600 permissions if keyring is unavailable.
Requirements
- macOS or Linux
- Python 3.10+
- TIDAL Premium subscription
- ffmpeg
Support
If you enjoy Ticli, consider buying me a coffee.
License
MIT
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 tidal_cli-1.0.0.tar.gz.
File metadata
- Download URL: tidal_cli-1.0.0.tar.gz
- Upload date:
- Size: 19.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dc54edad3040bf262fcb741ac7087d40d64a0c5ab191819e8bdc929d04233860
|
|
| MD5 |
97b896c6beed8b62dfd658cba15cfb31
|
|
| BLAKE2b-256 |
6aa75686b0ce48fb5af0c1c261d8c35409b6fff0699d1acbf30a3621906dc91a
|
Provenance
The following attestation bundles were made for tidal_cli-1.0.0.tar.gz:
Publisher:
publish.yml on odonald/ticli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tidal_cli-1.0.0.tar.gz -
Subject digest:
dc54edad3040bf262fcb741ac7087d40d64a0c5ab191819e8bdc929d04233860 - Sigstore transparency entry: 1092546774
- Sigstore integration time:
-
Permalink:
odonald/ticli@d05f1f5e0aa8e60ce3e92e2489f14aae8e5f8cb6 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/odonald
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@d05f1f5e0aa8e60ce3e92e2489f14aae8e5f8cb6 -
Trigger Event:
release
-
Statement type:
File details
Details for the file tidal_cli-1.0.0-py3-none-any.whl.
File metadata
- Download URL: tidal_cli-1.0.0-py3-none-any.whl
- Upload date:
- Size: 17.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e15cce9d62afa40b00080389b74c7f677912df68fb92ffa5787adf1e0dca20fd
|
|
| MD5 |
2e76b3b530b4e46181bd08311fd5644b
|
|
| BLAKE2b-256 |
4b3c86dec3819ef9789940a0d158f8a5e02fa18344e81ad665d65580a5d8eb49
|
Provenance
The following attestation bundles were made for tidal_cli-1.0.0-py3-none-any.whl:
Publisher:
publish.yml on odonald/ticli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tidal_cli-1.0.0-py3-none-any.whl -
Subject digest:
e15cce9d62afa40b00080389b74c7f677912df68fb92ffa5787adf1e0dca20fd - Sigstore transparency entry: 1092546793
- Sigstore integration time:
-
Permalink:
odonald/ticli@d05f1f5e0aa8e60ce3e92e2489f14aae8e5f8cb6 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/odonald
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@d05f1f5e0aa8e60ce3e92e2489f14aae8e5f8cb6 -
Trigger Event:
release
-
Statement type: