use reqsign_core::Context;
use reqsign_core::ProvideCredential;
use reqsign_core::Result;
use super::super::credential::Credential;
#[derive(Debug, Clone)]
pub struct StaticCredentialProvider {
access_key_id: String,
access_key_secret: String,
security_token: Option<String>,
}
impl StaticCredentialProvider {
pub fn new(access_key_id: &str, access_key_secret: &str) -> Self {
Self {
access_key_id: access_key_id.to_string(),
access_key_secret: access_key_secret.to_string(),
security_token: None,
}
}
pub fn with_security_token(mut self, token: &str) -> Self {
self.security_token = Some(token.to_string());
self
}
}
impl ProvideCredential for StaticCredentialProvider {
type Credential = Credential;
async fn provide_credential(&self, _ctx: &Context) -> Result<Option<Self::Credential>> {
let mut cred = Credential::new(&self.access_key_id, &self.access_key_secret);
if let Some(token) = &self.security_token {
cred = cred.with_session_token(token);
}
Ok(Some(cred))
}
}
#[cfg(test)]
mod tests {
use super::*;
#[tokio::test]
async fn test_static_credential_provider() -> anyhow::Result<()> {
let ctx = Context::new();
let provider = StaticCredentialProvider::new("test_access_key", "test_secret_key");
let cred = provider.provide_credential(&ctx).await?;
assert!(cred.is_some());
let cred = cred.unwrap();
assert_eq!(cred.access_key_id, "test_access_key");
assert_eq!(cred.secret_access_key, "test_secret_key");
assert!(cred.session_token.is_none());
Ok(())
}
#[tokio::test]
async fn test_static_credential_provider_with_security_token() -> anyhow::Result<()> {
let ctx = Context::new();
let provider = StaticCredentialProvider::new("test_access_key", "test_secret_key")
.with_security_token("test_security_token");
let cred = provider.provide_credential(&ctx).await?;
assert!(cred.is_some());
let cred = cred.unwrap();
assert_eq!(cred.access_key_id, "test_access_key");
assert_eq!(cred.secret_access_key, "test_secret_key");
assert_eq!(cred.session_token, Some("test_security_token".to_string()));
Ok(())
}
}