2 releases

0.7.2 May 30, 2024
0.7.1 Mar 10, 2024

#453 in Audio


Used in listenbrainz-cli-tools

MIT license

67KB
1.5K SLoC

DO NOT USE THIS

use listenbrainz-rs instead

This is just a temporary fork with some merged pull requests to allow the CI of listenbrainz-cli-tools to work. Concider it as a nighly version of https://github.com/InputUsername/listenbrainz-rs with selective feature merging.

I will break compatibility, and I wont care about your crates. listenbrainz-rs is still actively maintained, so use it instead.


lib.rs:

API bindings for ListenBrainz.

This crate aims to be an idiomatic wrapper of the ListenBrainz HTTP API (version 1). It contains functionality for direct access to the API in the [raw] module, as well as a more convenient ListenBrainz client which is easier to use.

Generally, using the raw functionality is more cumbersome, as its types and functions map one-to-one to the HTTP API's JSON input- and response data. Using the ListenBrainz type is therefore recommended.

Example

Submit a currently playing song to ListenBrainz.org:

#
let mut client = ListenBrainz::new();

client.authenticate("LISTENBRAINZ TOKEN")
    .expect("Could not authenticate with ListenBrainz");

client.playing_now("The Beatles", "Here Comes the Sun", Some("Abbey Road"))
    .expect("Could not submit 'playing now' request");

Use a custom API URL, for example to submit songs to Maloja:

#
let mut client = ListenBrainz::new_with_url("http://maloja.example.com/apis/listenbrainz");

client.authenticate("MALOJA API KEY")
    .expect("Could not authenticate with Maloja");

client.listen("Lymbyc Systym", "Split Stones", None)
    .expect("Could not submit listen");

Dependencies

~3–4.5MB
~84K SLoC