forked from microsoft/azure-devops-rust-api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
graph_query.rs
58 lines (49 loc) · 1.73 KB
/
graph_query.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT License.
// graph_query.rs
// Graph example.
use anyhow::Result;
use azure_devops_rust_api::graph;
use azure_devops_rust_api::graph::models::GraphSubjectQuery;
use azure_devops_rust_api::Credential;
use std::env;
use std::sync::Arc;
#[tokio::main]
async fn main() -> Result<()> {
// Initialize logging
env_logger::init();
// Get authentication credential either from a PAT ("ADO_TOKEN") or via the az cli.
let credential = match env::var("ADO_TOKEN") {
Ok(token) => {
println!("Authenticate using PAT provided via $ADO_TOKEN");
Credential::from_pat(token)
}
Err(_) => {
println!("Authenticate using Azure CLI");
Credential::from_token_credential(Arc::new(azure_identity::AzureCliCredential::new()))
}
};
// Get ADO configuration via environment variables
let organization = env::var("ADO_ORGANIZATION").expect("Must define ADO_ORGANIZATION");
let name = env::args().nth(1).expect("Usage: graph_query <name>");
// Create a "graph" client
let graph_client = graph::ClientBuilder::new(credential).build();
// Create a query for a user with the specified name
let query = GraphSubjectQuery {
query: Some(name.to_string()),
scope_descriptor: None,
subject_kind: vec!["User".to_string()],
};
// Query the specified user
let subjects = graph_client
.subject_query_client()
.query(&organization, query)
.into_future()
.await?
.value;
println!("Found {} subjects", subjects.len());
if let Some(subject) = subjects.iter().next() {
println!("subject: {:#?}", subject);
}
Ok(())
}