use crate::dtos::MyceliumProfileData;
use actix_web::{post, web, HttpResponse, Responder};
use myc_core::{
domain::dtos::guest_role::GuestRole,
use_cases::super_users::managers::create_system_roles,
};
use myc_diesel::repositories::SqlAppModule;
use myc_http_tools::{
utils::HttpJsonResponse,
wrappers::default_response_to_http_response::handle_mapped_error,
};
use shaku::HasComponent;
pub fn configure(config: &mut web::ServiceConfig) {
config.service(web::scope("/guest-roles").service(create_system_roles_url));
}
#[utoipa::path(
post,
operation_id = "create_system_level_guest_roles",
responses(
(
status = 500,
description = "Unknown internal server error.",
body = HttpJsonResponse,
),
(
status = 403,
description = "Forbidden.",
body = HttpJsonResponse,
),
(
status = 401,
description = "Unauthorized.",
body = HttpJsonResponse,
),
(
status = 201,
description = "Guest roles created.",
body = [GuestRole],
),
),
)]
#[post("")]
pub async fn create_system_roles_url(
profile: MyceliumProfileData,
app_module: web::Data<SqlAppModule>,
) -> impl Responder {
match create_system_roles(
profile.to_profile(),
Box::new(&*app_module.resolve_ref()),
)
.await
{
Ok(res) => HttpResponse::Created().json(res),
Err(err) => handle_mapped_error(err),
}
}