-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathupdate_policy.rs
88 lines (80 loc) · 2.64 KB
/
update_policy.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
use async_trait::async_trait;
use dfns_sdk_rs::{
DfnsApiClient,
api::policies::types::{
ActionKind, ActivityKindEnum, RuleKind, UpdatePolicyBody, UpdatePolicyBodyAction,
UpdatePolicyBodyRule, UpdatePolicyRequest,
},
error::DfnsError,
models::generic::DfnsBaseApiOptions,
signer::{
CredentialSigner, FirstFactorAssertion, FirstFactorAssertionKind, UserActionChallenge,
},
};
use std::sync::Arc;
struct ExampleSigner {
cred_id: String,
signature: String,
}
impl ExampleSigner {
fn new(cred_id: String, signature: String) -> Self {
Self { cred_id, signature }
}
}
#[async_trait]
impl CredentialSigner for ExampleSigner {
async fn sign(
&self,
_challenge: UserActionChallenge,
) -> Result<FirstFactorAssertion, DfnsError> {
Ok(FirstFactorAssertion {
credential_assertion: None,
kind: FirstFactorAssertionKind::Key,
password: Some(self.signature.clone()),
})
}
}
#[tokio::main]
async fn main() {
let signer = Arc::new(ExampleSigner::new(
"example-cred-id".to_string(),
"example-signature".to_string(),
));
let base_options = DfnsBaseApiOptions {
app_id: "your-app-id".to_string(),
auth_token: Some("your-auth-token".to_string()),
base_url: Some("https://api.dfns.ninja".to_string()),
app_secret: None,
};
let client = DfnsApiClient::new(base_options, Some(signer));
let policy_id = "example-policy-id";
let request = UpdatePolicyRequest {
policy_id: policy_id.to_string(),
body: UpdatePolicyBody {
name: "Updated Example Policy".to_string(),
activity_kind: ActivityKindEnum::WalletsSign,
action: UpdatePolicyBodyAction {
kind: ActionKind::RequestApproval,
approval_groups: None,
auto_reject_timeout: Some(7200.0),
},
filters: None,
rule: UpdatePolicyBodyRule {
kind: RuleKind::AlwaysTrigger,
configuration: None,
},
},
};
match client.policies().update_policy(request).await {
Ok(response) => {
println!("Successfully updated policy:");
println!(" ID: {}", response.id);
println!(" Name: {}", response.name);
println!(" Status: {}", response.status);
println!(" Activity Kind: {:?}", response.activity_kind);
println!(" Action Kind: {:?}", response.action.kind);
println!(" Rule Kind: {:?}", response.rule.kind);
}
Err(e) => eprintln!("Error: {:?}", e),
}
}