9 stable releases (4 major)
new 5.1.1 | Dec 28, 2024 |
---|---|
5.0.0 | Nov 2, 2023 |
4.1.0 | Oct 26, 2023 |
3.0.0 | Oct 23, 2023 |
1.0.0 | Oct 23, 2023 |
#154 in #music
22KB
447 lines
odesli-rs
[UNOFFICIAL] Async Rust library to communicate with Odesli API
- Supports getting by URLs and IDs
Example
- In
Cargo.toml
[package]
name = "odesli-test"
version = "0.1.0"
edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
odesli-rs = "5.1.0"
strum = "0.25.0"
tokio = { version = "1.33.0", features = ["full"] }
- In
src/main.rs
use odesli_rs::{APIProvider, ClientBuilder, EntityType, Platform};
use strum::IntoEnumIterator;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
println!("Supported Platforms:");
for platform in Platform::iter() {
println!(" - {:?}", platform)
}
println!("");
println!("Supported API Providers:");
for provider in APIProvider::iter() {
println!(" - {:?}", provider)
}
println!("");
let client = ClientBuilder::default()
// .with_api_key(String::from("<INSERT_YOUR_API_KEY_HERE>")) // OPTIONAL
// .with_api_version(String::from(odesli_rs::API_VERSION)) // Will be useful if any new API versions are released
// .with_http_client(reqwest::Client::default()) // If you want to change your `reqwest::Client`'s settings
.build();
dbg!(
client
.get_by_url("https://music.youtube.com/watch?v=cnnOwLfAxn0")
.await
);
let result = client
.get_by_id(
"7CNUefGBVLn4cLoYv3ej8x",
&Platform::Spotify,
&EntityType::Song,
)
.await?;
dbg!(&result);
dbg!(result.get_platform_url(&Platform::YouTube));
dbg!(result.get_platform_entity(&Platform::YouTube));
Ok(())
}
Dependencies
~4–20MB
~227K SLoC