Azure DevOps Rust API

Overview

azure_devops_rust_api implements a Rust interface to the Azure DevOps REST API (version 7.1).

The crate is autogenerated from the Azure DevOps OpenAPI spec.

Usage

Usage overview

The crate has many features/modules, but the general approach is similar for all:

Code example

Example usage (from examples/gitrepolist.rs):

```rust // Get authentication credential either from a PAT ("ADOTOKEN") // or via the az cli. let credential = match env::var("ADOTOKEN") { Ok(token) => { println!("Authenticate using PAT provided via $ADOTOKEN"); Credential::frompat(token) } Err() => { println!("Authenticate using Azure CLI"); Credential::fromtokencredential( Arc::new(azureidentity::AzureCliCredential::new()) ) } };

// Get ADO configuration via environment variables
let organization = env::var("ADO_ORGANIZATION")
    .expect("Must define ADO_ORGANIZATION");
let project = env::var("ADO_PROJECT")
    .expect("Must define ADO_PROJECT");

// Create a git client
let git_client = git::ClientBuilder::new(credential).build();

// Get all repositories in the specified organization/project
let repos = git_client
    .repositories_client()
    .list(organization, project)
    .into_future()
    .await?
    .value;

// Output repo names
for repo in repos.iter() {
    println!("{}", repo.name);
}
println!("{} repos found", repos.len());

```

Individual components in the API are enabled via Rust features.

See the features section of Cargo.toml for the full list of features.

Example application Cargo.toml dependency spec showing how to specify desired features:

toml [dependencies] ... azure_devops_rust_api = { version = "0.5.0", features = ["git", "pipelines"] }

Examples

See examples directory.

Define environment variables:

sh export ADO_ORGANIZATION=<organization-name> export ADO_PROJECT=<project-name>

To run the examples you need to provide authentication credentials either via:

Run the example via cargo run --example. You will need to enable the features required by the example. If you don't specify the necessary features you do get a helpful error message.

Example:

sh cargo run --example git_repo_get --features="git" <repo-name>

Issue reporting

This crate is in early development and only a subset of function has been tested, so there will be issues and breaking changes.

If you find any issues then please raise them via Github.

Useful links