#stream #media #player #command-line #query #authentication #http-header

app streamlib

Play your favorite live streams from command line

2 releases

0.6.4 Jan 31, 2020
0.6.1 Nov 19, 2019

#101 in #http-header

GPL-3.0 license

36KB
649 lines

Streamlib

Streamlib is a meta-player for media streams. The streamlib CLI works against a curated library of video and audio streams, and enables querying and playback through a standard media player, defaulting to mpv which is the recommended player.

The most important feature Streamlib provides is the ability to generate timestamped authentication tokens on streams that require some basic level of authentication to them. See the Queries section for more details.

Usage

Streamlib is still moving fast and has yet to been officially packaged, but the basic functionality works!

Running it requires checking out the git repository and then calling:

$ cargo run -- groove

The single argument will run a case-insensitive match against all known metadata and pick the first matching stream. Upcoming versions will include a console-based interactive interface.

Entire library can be dumped with the -L flag:

$ cargo run -- -L

Or filtered to show a specific query:

$ cargo run -- -L somafm

An alternate player can be set with the -p/--player flag:

$ cargo run -- -p vlc groove

But note that some features critical for playing streams (such as customizing HTTP headers) are unavailable and will cause some streams to fail.

Use the -l/--library flag to point streamlib to a local library directory for testing new additions:

$ cargo run -- --library /path/to/local/library groove

Testing

$ cargo test

Library

To add new content and test it you'll need to clone both repositories:

$ git clone https://github.com/streamlib/streamlib
$ git clone https://github.com/streamlib/library
# add any files you want to the library
$ cd streamlib
$ cargo run -- --library ../library groove

See https://github.com/streamlib/library for more details.

License

GPLv3

Dependencies

~31–42MB
~781K SLoC