7 releases (4 breaking)

new 0.5.0 Apr 25, 2024
0.4.0 Dec 21, 2023
0.3.1 Oct 13, 2023
0.3.0 Jul 26, 2023
0.1.0 Jan 31, 2023

#119 in Authentication

Download history 839/week @ 2024-01-02 968/week @ 2024-01-09 1388/week @ 2024-01-16 1501/week @ 2024-01-23 1130/week @ 2024-01-30 1351/week @ 2024-02-06 1210/week @ 2024-02-13 1293/week @ 2024-02-20 1219/week @ 2024-02-27 1289/week @ 2024-03-05 1587/week @ 2024-03-12 1603/week @ 2024-03-19 987/week @ 2024-03-26 1545/week @ 2024-04-02 1295/week @ 2024-04-09 1988/week @ 2024-04-16

6,125 downloads per month
Used in bws

Custom license

2.5MB
51K SLoC

Bitwarden Secrets Manager SDK

A Rust client SDK to interact with the Bitwarden Secrets Manager. This is a beta release and might be missing some functionality.

Usage

[dependencies]
bitwarden = { "*", features = ["secrets"] }

Minimum Supported Rust Version

Rust 1.71 or higher.

Example

use bitwarden::{
    auth::login::AccessTokenLoginRequest,
    client::client_settings::{ClientSettings, DeviceType},
    error::Result,
    secrets_manager::secrets::SecretIdentifiersRequest,
    Client,
};
use uuid::Uuid;

async fn test() -> Result<()> {
    // Use the default values
    let mut client = Client::new(None);

    // Or set your own values
    let settings = ClientSettings {
        identity_url: "https://identity.bitwarden.com".to_string(),
        api_url: "https://api.bitwarden.com".to_string(),
        user_agent: "Bitwarden Rust-SDK".to_string(),
        device_type: DeviceType::SDK,
    };
    let mut client = Client::new(Some(settings));

    // Before we operate, we need to authenticate with a token
    let token = AccessTokenLoginRequest { access_token: String::from(""), state_file: None };
    client.auth().login_access_token(&token).await.unwrap();

    let org_id = SecretIdentifiersRequest { organization_id: Uuid::parse_str("00000000-0000-0000-0000-000000000000").unwrap() };
    println!("Stored secrets: {:#?}", client.secrets().list(&org_id).await.unwrap());
    Ok(())
}

Dependencies

~16–33MB
~532K SLoC