#[cfg(server)]
use super::admin_auth::AdminAuthenticatedUser;
use crate::adapters::{AdminDatabase, AdminRecord, AdminSite, DetailResponse};
#[cfg(server)]
use reinhardt_di::Depends;
#[cfg(server)]
use reinhardt_pages::server_fn::ServerFnRequest;
use reinhardt_pages::server_fn::{ServerFnError, server_fn};
#[cfg(server)]
use super::error::{AdminAuth, MapServerFnError, ModelPermission};
#[server_fn]
pub async fn get_detail(
model_name: String,
id: String,
#[inject] site: Depends<AdminSite>,
#[inject] db: Depends<AdminDatabase>,
#[inject] http_request: ServerFnRequest,
#[inject] AdminAuthenticatedUser(user): AdminAuthenticatedUser,
) -> Result<DetailResponse, ServerFnError> {
let auth = AdminAuth::from_request(&http_request);
let model_admin = site.get_model_admin(&model_name).map_server_fn_error()?;
auth.require_model_permission(model_admin.as_ref(), user.as_ref(), ModelPermission::View)
.await?;
let table_name = model_admin.table_name();
let pk_field = model_admin.pk_field();
let data = db
.get::<AdminRecord>(table_name, pk_field, &id)
.await
.map_server_fn_error()?
.ok_or_else(|| {
ServerFnError::server(404, format!("{} with id '{}' not found", model_name, id))
})?;
Ok(DetailResponse { model_name, data })
}