use std::{fmt, sync};
use crate::token::TokenCache;
mod bucket;
mod bucket_access_control;
mod default_object_access_control;
mod hmac_key;
mod object;
mod object_access_control;
pub use bucket::BucketClient;
pub use bucket_access_control::BucketAccessControlClient;
pub use default_object_access_control::DefaultObjectAccessControlClient;
pub use hmac_key::HmacKeyClient;
pub use object::ObjectClient;
pub use object_access_control::ObjectAccessControlClient;
pub struct Client {
client: reqwest::Client,
token_cache: sync::Arc<dyn crate::TokenCache + Send>,
}
impl fmt::Debug for Client {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_struct("Client")
.field("client", &self.client)
.field("token_cache", &"<opaque>")
.finish()
}
}
impl Default for Client {
fn default() -> Self {
Self {
client: Default::default(),
token_cache: sync::Arc::new(crate::Token::default()),
}
}
}
impl Client {
pub fn new() -> Self {
Default::default()
}
pub fn with_cache(token: impl TokenCache + Send + 'static) -> Self {
Self {
client: Default::default(),
token_cache: sync::Arc::new(token),
}
}
pub fn bucket(&self) -> BucketClient<'_> {
BucketClient(self)
}
pub fn bucket_access_control(&self) -> BucketAccessControlClient<'_> {
BucketAccessControlClient(self)
}
pub fn default_object_access_control(&self) -> DefaultObjectAccessControlClient<'_> {
DefaultObjectAccessControlClient(self)
}
pub fn hmac_key(&self) -> HmacKeyClient<'_> {
HmacKeyClient(self)
}
pub fn object(&self) -> ObjectClient<'_> {
ObjectClient(self)
}
pub fn object_access_control(&self) -> ObjectAccessControlClient<'_> {
ObjectAccessControlClient(self)
}
async fn get_headers(&self) -> crate::Result<reqwest::header::HeaderMap> {
let mut result = reqwest::header::HeaderMap::new();
let token = self.token_cache.get(&self.client).await?;
result.insert(
reqwest::header::AUTHORIZATION,
format!("Bearer {}", token).parse().unwrap(),
);
Ok(result)
}
}