use axum::{ Extension, Json, extract::{Path, State}, }; use axum_extra::TypedHeader; use serde::Deserialize; use super::{device_id_header::DeviceIdHeader, requests::DeleteDocumentVersion}; use crate::{ app_state::{ AppState, database::models::{ DocumentId, DocumentVersionWithoutContent, StoredDocumentVersion, VaultId, }, }, config::user_config::User, errors::{SyncServerError, server_error}, utils::{normalize::normalize, sanitize_path::sanitize_path}, }; #[derive(Deserialize)] pub struct DeleteDocumentPathParams { #[serde(deserialize_with = "normalize")] vault_id: VaultId, document_id: DocumentId, } #[axum::debug_handler] pub async fn delete_document( Path(DeleteDocumentPathParams { vault_id, document_id, }): Path, Extension(user): Extension, TypedHeader(device_id): TypedHeader, State(state): State, Json(request): Json, ) -> Result, SyncServerError> { let mut transaction = state .database .create_write_transaction(&vault_id) .await .map_err(server_error)?; let last_update_id = state .database .get_max_update_id_in_vault(&vault_id, Some(&mut transaction)) .await .map_err(server_error)?; let latest_content = state .database .get_latest_document(&vault_id, &document_id, Some(&mut transaction)) .await .map_err(server_error)? .map_or_else(Vec::new, |version| version.content); // in case the document has never existed before deleting it let new_version = StoredDocumentVersion { vault_update_id: last_update_id + 1, document_id, relative_path: sanitize_path(&request.relative_path), content: latest_content, // copy the content from the latest version updated_date: chrono::Utc::now(), is_deleted: true, user_id: user.name, device_id: device_id.0, has_been_merged: false, }; state .database .insert_document_version(&vault_id, &new_version, Some(transaction)) .await .map_err(server_error)?; Ok(Json(new_version.into())) }