24 releases (13 breaking)

0.14.0 Jan 1, 2025
0.13.0 Sep 23, 2024
0.12.0 May 4, 2024
0.11.5 Sep 4, 2023
0.2.0 Dec 29, 2020

#27 in Video

Download history 409/week @ 2024-09-23 181/week @ 2024-09-30 263/week @ 2024-10-07 433/week @ 2024-10-14 210/week @ 2024-10-21 137/week @ 2024-10-28 260/week @ 2024-11-04 168/week @ 2024-11-11 103/week @ 2024-11-18 128/week @ 2024-11-25 86/week @ 2024-12-02 284/week @ 2024-12-09 248/week @ 2024-12-16 92/week @ 2024-12-23 239/week @ 2024-12-30 197/week @ 2025-01-06

801 downloads per month
Used in 3 crates

MIT license

310KB
6.5K SLoC

OBWS - The obws (obvious) remote control library for OBS

Build Status Repository Documentation Code Coverage

Remote control OBS with the obs-websocket plugin from Rust 🦀.

Usage

Add obws to your project with cargo add obws@0.14.0 or add it manually to your Cargo.toml:

[dependencies]
obws = "0.14.0"

In addition, you will need to use the latest tokio runtime to use this library as it makes heavy use of async/await and is bound to this runtime.

Example

Here we connect to a OBS instance, get some version information and log in to access the whole API and lastly print out a list of available scenes.

For more usage instructions see the docs or check out the examples.

use anyhow::Result;
use obws::Client;

#[tokio::main]
async fn main() -> Result<()> {
    // Connect to the OBS instance through obs-websocket.
    let client = Client::connect("localhost", 4455, Some("password")).await?;

    // Get and print out version information of OBS and obs-websocket.
    let version = client.general().version().await?;
    println!("{version:#?}");

    // Get a list of available scenes and print them out.
    let scene_list = client.scenes().list().await?;
    println!("{scene_list:#?}");

    Ok(())
}

License

This project is licensed under MIT License (or http://opensource.org/licenses/MIT).

Dependencies

~7–17MB
~214K SLoC