2025-06-10 12:54:22 +02:00
|
|
|
import { deleteInterest, getInterestById } from '~/server/utils/nocodb';
|
2025-06-09 23:19:52 +02:00
|
|
|
|
2025-06-04 19:51:51 +02:00
|
|
|
export default defineEventHandler(async (event) => {
|
2025-06-10 12:54:22 +02:00
|
|
|
const startTime = Date.now();
|
2025-06-05 14:56:05 +02:00
|
|
|
const xTagHeader = getRequestHeader(event, "x-tag");
|
2025-06-10 12:54:22 +02:00
|
|
|
console.log('[delete-interest] =========================');
|
|
|
|
|
console.log('[delete-interest] Request received at:', new Date().toISOString());
|
|
|
|
|
console.log('[delete-interest] x-tag:', xTagHeader);
|
2025-06-05 14:56:05 +02:00
|
|
|
|
2025-06-09 23:19:52 +02:00
|
|
|
if (!xTagHeader || (xTagHeader !== "094ut234" && xTagHeader !== "pjnvü1230")) {
|
|
|
|
|
console.error('[delete-interest] Authentication failed - invalid x-tag:', xTagHeader);
|
2025-06-10 12:54:22 +02:00
|
|
|
console.log('[delete-interest] Duration:', Date.now() - startTime, 'ms');
|
2025-06-05 14:56:05 +02:00
|
|
|
throw createError({ statusCode: 401, statusMessage: "unauthenticated" });
|
|
|
|
|
}
|
2025-06-04 19:51:51 +02:00
|
|
|
|
|
|
|
|
try {
|
2025-06-05 14:56:05 +02:00
|
|
|
const body = await readBody(event);
|
|
|
|
|
const { id } = body;
|
2025-06-10 12:54:22 +02:00
|
|
|
console.log('[delete-interest] Request body:', JSON.stringify(body, null, 2));
|
2025-06-05 14:56:05 +02:00
|
|
|
|
|
|
|
|
if (!id) {
|
2025-06-09 23:19:52 +02:00
|
|
|
console.error('[delete-interest] Missing ID in request');
|
2025-06-10 12:54:22 +02:00
|
|
|
console.log('[delete-interest] Duration:', Date.now() - startTime, 'ms');
|
2025-06-05 14:56:05 +02:00
|
|
|
throw createError({ statusCode: 400, statusMessage: "ID is required" });
|
|
|
|
|
}
|
|
|
|
|
|
2025-06-10 12:54:22 +02:00
|
|
|
// Pre-delete verification
|
|
|
|
|
console.log('[delete-interest] Pre-delete verification - checking if record exists...');
|
|
|
|
|
try {
|
|
|
|
|
const existingRecord = await getInterestById(id);
|
|
|
|
|
console.log('[delete-interest] Record found:', {
|
|
|
|
|
id: existingRecord.Id,
|
|
|
|
|
name: existingRecord['Full Name'],
|
|
|
|
|
email: existingRecord['Email Address']
|
|
|
|
|
});
|
|
|
|
|
} catch (verifyError: any) {
|
|
|
|
|
console.error('[delete-interest] Pre-delete verification failed:', verifyError);
|
|
|
|
|
if (verifyError.statusCode === 404 || verifyError.status === 404) {
|
|
|
|
|
console.error('[delete-interest] Record does not exist - cannot delete');
|
|
|
|
|
throw createError({ statusCode: 404, statusMessage: "Record not found" });
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.log('[delete-interest] Proceeding with deletion for ID:', id);
|
2025-06-05 16:04:12 +02:00
|
|
|
const result = await deleteInterest(id);
|
2025-06-10 12:54:22 +02:00
|
|
|
console.log('[delete-interest] Delete operation completed successfully');
|
|
|
|
|
console.log('[delete-interest] Result:', JSON.stringify(result, null, 2));
|
|
|
|
|
console.log('[delete-interest] Duration:', Date.now() - startTime, 'ms');
|
|
|
|
|
console.log('[delete-interest] =========================');
|
2025-06-09 23:19:52 +02:00
|
|
|
|
2025-06-05 16:04:12 +02:00
|
|
|
return result;
|
2025-06-10 12:54:22 +02:00
|
|
|
} catch (error: any) {
|
|
|
|
|
console.error('[delete-interest] =========================');
|
|
|
|
|
console.error('[delete-interest] ERROR OCCURRED');
|
|
|
|
|
console.error('[delete-interest] Error type:', error.constructor.name);
|
|
|
|
|
console.error('[delete-interest] Error message:', error.message);
|
|
|
|
|
console.error('[delete-interest] Error status:', error.statusCode || error.status || 'unknown');
|
|
|
|
|
console.error('[delete-interest] Error stack:', error.stack || 'No stack trace');
|
|
|
|
|
console.error('[delete-interest] Full error object:', JSON.stringify(error, null, 2));
|
|
|
|
|
console.error('[delete-interest] Duration:', Date.now() - startTime, 'ms');
|
|
|
|
|
console.error('[delete-interest] =========================');
|
2025-06-09 23:19:52 +02:00
|
|
|
|
2025-06-10 12:54:22 +02:00
|
|
|
if (error.statusCode || error.status) {
|
|
|
|
|
throw error; // Re-throw if it's already a proper error
|
|
|
|
|
} else if (error instanceof Error) {
|
2025-06-05 14:56:05 +02:00
|
|
|
throw createError({ statusCode: 500, statusMessage: error.message });
|
|
|
|
|
} else {
|
|
|
|
|
throw createError({
|
|
|
|
|
statusCode: 500,
|
|
|
|
|
statusMessage: "An unexpected error occurred",
|
|
|
|
|
});
|
|
|
|
|
}
|
2025-06-04 19:51:51 +02:00
|
|
|
}
|
|
|
|
|
});
|