dagger-rs/crates/dagger-sdk
2023-02-19 22:43:12 +01:00
..
examples feat(sdk,core): Use async runtime instead of blocking. 2023-02-19 21:47:40 +01:00
src feat(sdk): add documentation strings 2023-02-19 22:43:12 +01:00
tests feat(sdk,core): Use async runtime instead of blocking. 2023-02-19 21:47:40 +01:00
.gitignore add dagger-sdk 2023-01-29 11:38:13 +01:00
Cargo.toml Release dagger-sdk v0.2.7 2023-02-19 21:48:55 +01:00
CHANGELOG.md Release dagger-sdk v0.2.7 2023-02-19 21:48:55 +01:00
LICENSE.MIT add dagger-sdk 2023-01-29 11:38:13 +01:00
README.md docs(sdk): change to await syntax 2023-02-19 21:47:40 +01:00

dagger-sdk

A dagger sdk written in rust for rust.

Examples

See examples

Run them like so

cargo run --example first-pipeline

The examples match the folder name in each directory in examples

Install

Simply install like:

cargo add dagger-sdk

Usage

#[tokio::main]
async fn main() -> eyre::Result<()> {
    let client = dagger_sdk::connect()?;

    let version = client
        .container()
        .from("golang:1.19")
        .with_exec(vec!["go", "version"])
        .stdout().await?;

    println!("Hello from Dagger and {}", version.trim());

    Ok(())
}

And run it like a normal application:

cargo run

Disclaimer

You are free to use something else than tokio, I haven't tested it with anything else, but it should work with any other runtime. We don't rely on it specifically. That might change in the future though.