use actix_web::{HttpRequest, HttpResponse, delete, web::Json};
use serde::Deserialize;
use serde_json::json;
use supabase_rs::SupabaseClient;
use crate::api::headers::x_athena_client::x_athena_client;
use crate::api::headers::x_company_id::get_x_company_id;
use crate::api::headers::x_organization_id::get_x_organization_id;
use crate::api::headers::x_publish_event::get_x_publish_event;
use crate::api::headers::x_user_id::get_x_user_id;
use crate::data::events::post_event;
use crate::data::suitsbooks_supabase;
use crate::utils::request_logging::log_request;
#[derive(Debug, Deserialize)]
struct DeleteRequest {
table_name: String,
resource_id: String,
}
#[delete("/gateway/delete")]
pub async fn delete_data(req: HttpRequest, body: Json<DeleteRequest>) -> HttpResponse {
log_request(req.clone());
let client_name: String = x_athena_client(&req.clone());
let _user_id: String = match get_x_user_id(&req) {
Some(id) => id,
None => {
return HttpResponse::BadRequest()
.json(json!({"error": "X-User-Id header not found in the request"}));
}
};
let _company_id: String = match get_x_company_id(&req) {
Some(id) => id,
None => {
return HttpResponse::BadRequest()
.json(json!({"error": "X-Company-Id header not found in the request"}));
}
};
let _organization_id: String = match get_x_organization_id(&req) {
Some(id) => id,
None => {
return HttpResponse::BadRequest()
.json(json!({"error": "X-Organization-Id header not found in the request"}));
}
};
let table_name: String = body.table_name.clone();
let resource_id: String = body.resource_id.clone();
let client: SupabaseClient = if x_athena_client(&req.clone()) == "custom_supabase" {
let supabase_url: Option<&str> = req
.headers()
.get("x-supabase-url")
.and_then(|v| v.to_str().ok());
let supabase_key = req
.headers()
.get("x-supabase-key")
.and_then(|v| v.to_str().ok());
match (supabase_url, supabase_key) {
(Some(url), Some(key)) => SupabaseClient::new(url.to_string(), key.to_string())
.unwrap_or_else(|_| futures::executor::block_on(suitsbooks_supabase())),
_ => suitsbooks_supabase().await,
}
} else {
suitsbooks_supabase().await
};
let result: Result<(), String> = client.delete(&table_name, &resource_id).await;
match result {
Ok(_) => {
if get_x_publish_event(&req) {
let event: serde_json::Value = json!({
"event": "DELETE",
"resource": table_name.clone(),
"resource_id": resource_id.clone(),
});
post_event(_company_id, event).await;
}
HttpResponse::Ok().json(json!({
"status": "success",
"success": true,
"message": "Data deleted successfully",
"table_name": table_name,
"resource_id": resource_id,
"client": client_name,
}))
}
Err(err) => HttpResponse::InternalServerError().json(json!({
"status": "error",
"success": false,
"message": format!("Failed to delete: {:?}", err),
"table_name": table_name,
"resource_id": resource_id,
})),
}
}