/jftui

Jellyfin Terminal User Interface

Primary LanguageCThe UnlicenseUnlicense

jftui is a minimalistic, lightweight C99 command line client for the open source Jellyfin media server.

It is developed for the GNU/Linux OS only, although it may be possible to make it run on BSD's.

Installation

The program must be built from source.

For Arch Linux users, there is an AUR package.

Dependencies

Building

Make sure to checkout a release as the master branch is not guaranteed to work correctly or indeed compile at any time.

Then, simply run

make && sudo make install

Usage

Run jftui. You will be prompted for a minimal interactive configuration on first run.

BEWARE: jftui fetches https://github.com/Aanok/jftui/releases/latest on startup to check for newer versions. You can avoid this by passing the --no-check-updates argument. There is also a settings file entry.

The interface should be intuitive enough: select one or more entries by entering the corresponding index number. See below for a full description of the command syntax.

jftui will drop into a command line instance of mpv when starting playback. It will use mpv.conf and input.conf files found in $XDG_CONFIG_HOME/jftui (this location can be overridden with the --config-dir argument). It will also try and load scripts found in the same folder, but no guarantees are made about them actually working correctly.

It is recommended to consult the wiki page on configuring mpv commands to use jftui: a few special ones are required in particular to manipulate the playback playlist.

To safely run multiple instances of jftui concurrently, make sure to specify distinct --runtime-dir arguments to at least each one after the first. This requirement will be removed in the next release.

Jftui commands

The grammar defining jftui commands is as follows:

S ::= "q" (quits)
  | "h" (go to "home" root menu)
  | ".." (go to previous menu)
  | "f" ( "c" | [pufrld]+ ) (filters: clear or played, unplayed, favourite, resumable, liked, disliked)
  | Selector (opens a single directory entry or sends a sequence of items to playback)
Selector :: = '*' (everything in the current menu)
  | Items
Items ::= Atom "," Items (list)
  | Atom
Atom ::= n1 "-" n2 (range)
  | n (single item)

Whitespace may be scattered between tokens at will. Inexisting items are silently ignored. Both quit and stop mpv commands will drop you back to menu navigation.

There is one further command that will be parsed, but it is left undocumented because its implementation is barely more than a stub. Caveat.

Plans and TODO

  • Search;
  • Explicit command to recursively navigate folders to send items to playback;
  • Explicitly marking items played and unplayed;
  • Transcoding.