use crate::api::http::bucket::BucketSettingsAxum;
use crate::api::http::HttpError;
use crate::api::http::StateKeeper;
use crate::auth::policy::FullAccessPolicy;
use axum::extract::{Path, State};
use axum_extra::headers::HeaderMap;
use std::sync::Arc;
pub(super) async fn create_bucket(
State(keeper): State<Arc<StateKeeper>>,
Path(bucket_name): Path<String>,
headers: HeaderMap,
settings: BucketSettingsAxum,
) -> Result<(), HttpError> {
let components = keeper
.get_with_permissions(&headers, FullAccessPolicy {})
.await?;
components
.storage
.create_bucket(&bucket_name, settings.into())
.await?;
Ok(())
}
#[cfg(test)]
mod tests {
use super::*;
use crate::api::http::tests::{headers, keeper};
use reduct_base::error::ErrorCode;
use rstest::rstest;
use std::sync::Arc;
#[rstest]
#[tokio::test]
async fn test_create_bucket(#[future] keeper: Arc<StateKeeper>, headers: HeaderMap) {
create_bucket(
State(keeper.await),
Path("bucket-3".to_string()),
headers,
BucketSettingsAxum::default(),
)
.await
.unwrap();
}
#[rstest]
#[tokio::test]
async fn test_create_bucket_already_exists(
#[future] keeper: Arc<StateKeeper>,
headers: HeaderMap,
) {
let err = create_bucket(
State(keeper.await),
Path("bucket-1".to_string()),
headers,
BucketSettingsAxum::default(),
)
.await
.err()
.unwrap();
assert_eq!(
err,
HttpError::new(ErrorCode::Conflict, "Bucket 'bucket-1' already exists",)
)
}
}