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
pub mod client;
mod error;
#[doc(inline)]
pub use crate::error::Error;
use futures::future::Future as _;
use rusoto_core::credential::AwsCredentials;
use rusoto_core::{DefaultCredentialsProvider, ProvideAwsCredentials};
pub fn get_aws_credentials() -> Result<AwsCredentials, Error> {
let provider = DefaultCredentialsProvider::new()?;
Ok(provider.credentials().wait()?)
}
#[cfg(test)]
mod tests {
use super::*;
use std::env;
#[test]
fn expected_aws_credentials() -> Result<(), crate::Error> {
let access_key = "test_key";
let secret_key = "test_secret";
env::set_var("AWS_ACCESS_KEY_ID", access_key);
env::set_var("AWS_SECRET_ACCESS_KEY", secret_key);
let credentials = get_aws_credentials()?;
assert_eq!(credentials.aws_access_key_id(), access_key);
assert_eq!(credentials.aws_secret_access_key(), secret_key);
Ok(())
}
}