A library for interacting with the [VTube Studio API].
The example below creates a Client
using the provided builder, which:
ws://localhost:8001
using tokio_tungstenite
```rust,no_run use vtubestudio::data::StatisticsRequest; use vtubestudio::{Client, ClientEvent, Error};
async fn main() -> Result<(), Error> { // An auth token from a previous successful authentication request let storedtoken = Some("...".tostring());
let (mut client, mut events) = Client::builder()
.auth_token(stored_token)
.authentication("Plugin name", "Developer name", None)
.build_tungstenite();
tokio::spawn(async move {
while let Some(event) = events.next().await {
match event {
ClientEvent::NewAuthToken(new_token) => {
// This returns whenever the authentication middleware receives a new auth
// token. We can handle it by saving it somewhere, etc.
println!("Got new auth token: {new_token}");
}
_ => {
// Other events, such as connections/disconnections, API events, etc
println!("Got event: {:?}", event);
}
}
}
});
// Use the client to send a `StatisticsRequest`, handling authentication if necessary.
// The return type is inferred from the input type to be `StatisticsResponse`.
let resp = client.send(&StatisticsRequest {}).await?;
println!("VTube Studio has been running for {}ms", resp.uptime);
Ok(())
} ```
For more details, please check the documentation on docs.rs.