Crates.io | sonor |
lib.rs | sonor |
version | 2.0.0 |
source | src |
created_at | 2020-04-28 13:34:24.445509 |
updated_at | 2023-09-16 14:09:07.895705 |
description | a library for controlling sonos speakers |
homepage | |
repository | https://github.com/jakobhellermann/sonor |
max_upload_size | |
id | 234994 |
size | 89,318 |
This crate is a Sonos controller library written in Rust. It operates asynchronously and aims for a simple to use yet powerful API.
let speaker = sonor::find("your room name", Duration::from_secs(2)).await?
.expect("room exists");
println!("The volume is currently at {}", speaker.volume().await?);
match speaker.track().await? {
Some(track_info) => println!("- Currently playing '{}", track_info.track()),
None => println!("- No track currently playing"),
}
speaker.clear_queue().await?;
speaker.join("some other room").await?;
For a full list of actions implemented, look at the Speaker docs.
If your use case isn't covered, this crate also exposes the raw UPnP Action API here. It can be used like this:
use sonor::URN;
let service = URN::service("schemas-upnp-org", "GroupRenderingControl", 1);
let args = "<InstanceID>0</InstanceID>";
let response = speaker.action(&service, "GetGroupMute", args).await?;
println!("{}", response["CurrentMute"]);