12 releases (7 breaking)

0.8.1 Dec 27, 2024
0.8.0 Jul 28, 2024
0.7.0 Feb 12, 2023
0.5.0 Dec 4, 2022
0.2.0 Jan 20, 2021

#173 in HTTP client

Download history 145/week @ 2024-09-25 105/week @ 2024-10-02 109/week @ 2024-10-09 33/week @ 2024-10-16 5/week @ 2024-10-23 35/week @ 2024-10-30 37/week @ 2024-11-06 18/week @ 2024-11-13 99/week @ 2024-11-20 84/week @ 2024-11-27 55/week @ 2024-12-04 89/week @ 2024-12-11 58/week @ 2024-12-18 133/week @ 2024-12-25 74/week @ 2025-01-01 100/week @ 2025-01-08

379 downloads per month
Used in rescrobbled

MIT license

66KB
1.5K SLoC

listenbrainz

Crate Documentation CI builder License

ListenBrainz API bindings for Rust.

There is also listenbrainz-rust. However, that crate only supports single listens, imports and now playing requests, and is also not maintained anymore. This crate, on the other hand, aims to be a complete API wrapper for the ListenBrainz API, version 1.


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
~83K SLoC