mod bucket;
mod bucket_access_control;
mod default_object_access_control;
mod hmac_key;
mod object;
mod object_access_control;
mod helpers;
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;
#[derive(Debug)]
pub struct Client {
runtime: tokio::runtime::Runtime,
client: crate::client::Client,
}
impl Client {
pub fn new() -> crate::Result<Self> {
Ok(Self {
runtime: crate::runtime()?,
client: crate::Client::default(),
})
}
pub fn with_cache(token_cache: impl crate::TokenCache + Send + 'static) -> crate::Result<Self> {
Ok(Self {
runtime: crate::runtime()?,
client: crate::Client::with_cache(token_cache),
})
}
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)
}
}