Files

57 lines
1.8 KiB
Rust
Raw Permalink Normal View History

2025-02-01 01:38:50 +01:00
use minio::s3::creds::StaticProvider;
use minio::s3::http::BaseUrl;
use minio::s3::response::BucketExistsResponse;
use minio::s3::types::S3Api;
2025-02-01 01:38:50 +01:00
use minio::s3::{Client, ClientBuilder};
#[allow(dead_code)]
pub fn create_client_on_play() -> Result<Client, Box<dyn std::error::Error + Send + Sync>> {
let base_url = "https://play.min.io".parse::<BaseUrl>()?;
log::info!("Trying to connect to MinIO at: `{base_url:?}`");
2025-02-01 01:38:50 +01:00
let static_provider = StaticProvider::new(
"Q3AM3UQ867SPQQA43P2F",
"zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG",
None,
);
let client = ClientBuilder::new(base_url.clone())
.provider(Some(static_provider))
2025-02-01 01:38:50 +01:00
.build()?;
Ok(client)
}
#[allow(dead_code)]
pub fn create_client_on_localhost() -> Result<Client, Box<dyn std::error::Error + Send + Sync>> {
let base_url = "http://localhost:9000/".parse::<BaseUrl>()?;
log::info!("Trying to connect to MinIO at: `{base_url:?}`");
let static_provider = StaticProvider::new("minioadmin", "minioadmin", None);
let client = ClientBuilder::new(base_url.clone())
.provider(Some(static_provider))
.build()?;
Ok(client)
}
2025-02-01 01:38:50 +01:00
pub async fn create_bucket_if_not_exists(
bucket_name: &str,
client: &Client,
) -> Result<(), Box<dyn std::error::Error + Send + Sync>> {
// Check 'bucket_name' bucket exist or not.
let resp: BucketExistsResponse = client.bucket_exists(bucket_name).send().await?;
2025-02-01 01:38:50 +01:00
// Make 'bucket_name' bucket if not exist.
if !resp.exists() {
client.create_bucket(bucket_name).send().await.unwrap();
2025-02-01 01:38:50 +01:00
};
Ok(())
}
#[allow(dead_code)]
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error + Send + Sync>> {
// dummy code just to prevent an error because files in examples need to have a main
Ok(())
}