#[cfg(server)]
use super::admin_auth::AdminAuthenticatedUser;
use crate::adapters::{AdminDatabase, AdminRecord, AdminSite};
use crate::types::MutationResponse;
#[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::audit;
#[cfg(server)]
use super::error::{AdminAuth, MapServerFnError, ModelPermission};
#[cfg(server)]
use super::security::{require_csrf_token, sanitize_mutation_values};
#[cfg(server)]
use super::validation::validate_mutation_data;
#[server_fn]
pub async fn update_record(
model_name: String,
id: String,
request: crate::types::MutationRequest,
#[inject] site: Depends<AdminSite>,
#[inject] db: Depends<AdminDatabase>,
#[inject] http_request: ServerFnRequest,
#[inject] AdminAuthenticatedUser(user): AdminAuthenticatedUser,
) -> Result<crate::types::MutationResponse, ServerFnError> {
require_csrf_token(&request.csrf_token, &http_request.inner().headers)?;
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::Change)
.await?;
let table_name = model_admin.table_name();
let pk_field = model_admin.pk_field();
validate_mutation_data(&request.data, model_admin.as_ref(), true).map_server_fn_error()?;
let mut sanitized_data = request.data;
sanitize_mutation_values(&mut sanitized_data);
super::create::inject_auto_now_timestamps(&mut sanitized_data, table_name);
let user_id = auth.user_id().unwrap_or("unknown").to_string();
let result = db
.update::<AdminRecord>(table_name, pk_field, &id, sanitized_data.clone())
.await
.map_server_fn_error();
let affected = match result {
Err(e) => {
audit::log_update(&user_id, &model_name, &id, &sanitized_data, false);
return Err(e);
}
Ok(n) => n,
};
if affected == 0 {
audit::log_update(&user_id, &model_name, &id, &sanitized_data, false);
return Err(ServerFnError::server(
404,
format!("{} not found", model_name),
));
}
audit::log_update(&user_id, &model_name, &id, &sanitized_data, true);
Ok(MutationResponse {
success: true,
message: format!("{} updated successfully", model_name),
affected: Some(affected),
data: None,
})
}