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
use crate::errors::{Error::API, Result};
use aws_sdk_sts::{types::SdkError, Client};
use aws_types::SdkConfig as AwsSdkConfig;
use log::info;
use serde::{Deserialize, Serialize};
#[derive(Debug, Clone)]
pub struct Manager {
#[allow(dead_code)]
shared_config: AwsSdkConfig,
cli: Client,
}
impl Manager {
pub fn new(shared_config: &AwsSdkConfig) -> Self {
let cloned = shared_config.clone();
let cli = Client::new(shared_config);
Self {
shared_config: cloned,
cli,
}
}
pub async fn get_identity(&self) -> Result<Identity> {
info!("fetching caller identity");
let ret = self.cli.get_caller_identity().send().await;
let resp = match ret {
Ok(v) => v,
Err(e) => {
return Err(API {
message: format!("failed get_caller_identity {:?}", e),
is_retryable: is_error_retryable(&e),
});
}
};
Ok(Identity::new(
resp.account().unwrap_or(""),
resp.arn().unwrap_or(""),
resp.user_id().unwrap_or(""),
))
}
}
#[derive(Debug, Serialize, Deserialize, Eq, PartialEq, Clone)]
pub struct Identity {
pub account_id: String,
pub role_arn: String,
pub user_id: String,
}
impl Identity {
pub fn new(account_id: &str, role_arn: &str, user_id: &str) -> Self {
Self {
account_id: String::from(account_id),
role_arn: String::from(role_arn),
user_id: String::from(user_id),
}
}
}
#[inline]
pub fn is_error_retryable<E>(e: &SdkError<E>) -> bool {
match e {
SdkError::TimeoutError(_) | SdkError::ResponseError { .. } => true,
SdkError::DispatchFailure(e) => e.is_timeout() || e.is_io(),
_ => false,
}
}