Skip to main content

Unofficial terminal music player for TIDAL — search, browse, queue, and stream lossless audio from your terminal. Not affiliated with TIDAL.

Project description

Ticli

An unofficial terminal music player for TIDAL. Search, browse, queue, and play music — all from your terminal. Not affiliated with TIDAL.

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     └───────────┘                  └───────────┘

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


Download files

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

Source Distribution

tidal_cli-1.0.2.tar.gz (18.9 kB view details)

Uploaded Source

Built Distribution

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

tidal_cli-1.0.2-py3-none-any.whl (17.7 kB view details)

Uploaded Python 3

File details

Details for the file tidal_cli-1.0.2.tar.gz.

File metadata

  • Download URL: tidal_cli-1.0.2.tar.gz
  • Upload date:
  • Size: 18.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tidal_cli-1.0.2.tar.gz
Algorithm Hash digest
SHA256 ce1df222890b4b5c6058efd63d64dd770c20d04eecb5a1b39ba43e014cf01a5a
MD5 0a7c251cc152b9eb6faeac38eea30371
BLAKE2b-256 18d4ff0a5b6422805be85f4f0f3a770426b1536633317bf3ff436c1e4842ac31

See more details on using hashes here.

Provenance

The following attestation bundles were made for tidal_cli-1.0.2.tar.gz:

Publisher: publish.yml on odonald/ticli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tidal_cli-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: tidal_cli-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 17.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tidal_cli-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fce5cceae593cabb6cd1ff7f7d898a2dd92f020b14f34c35ab37926ed6743e2f
MD5 3ced6768c41a9b62a4d17a219f9ecd6c
BLAKE2b-256 b742a3788ff1c9583e33c5f14834d66ee68c1bd935afa441a3be7722a6ab0d84

See more details on using hashes here.

Provenance

The following attestation bundles were made for tidal_cli-1.0.2-py3-none-any.whl:

Publisher: publish.yml on odonald/ticli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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