2 releases
0.6.4 | Jan 31, 2020 |
---|---|
0.6.1 | Nov 19, 2019 |
#87 in #http-header
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
Dependencies
~29–40MB
~740K SLoC