port-nimara-client-portal/server/api/get-interest-by-id.ts

47 lines
1.7 KiB
TypeScript

export default defineEventHandler(async (event) => {
const xTagHeader = getRequestHeader(event, "x-tag");
console.log('[get-interest-by-id] Request received with x-tag:', xTagHeader);
if (!xTagHeader || (xTagHeader !== "094ut234" && xTagHeader !== "pjnvü1230")) {
console.error('[get-interest-by-id] Authentication failed - invalid x-tag:', xTagHeader);
throw createError({ statusCode: 401, statusMessage: "unauthenticated" });
}
const query = getQuery(event);
const { id } = query;
console.log('[get-interest-by-id] Request for ID:', id);
if (!id) {
console.error('[get-interest-by-id] Missing ID in request');
throw createError({ statusCode: 400, statusMessage: "ID is required" });
}
try {
console.log('[get-interest-by-id] Fetching interest:', id);
const interest = await getInterestById(id as string);
console.log('[get-interest-by-id] Successfully fetched interest:', id);
return interest;
} catch (error: any) {
console.error('[get-interest-by-id] Error occurred:', error);
console.error('[get-interest-by-id] Error details:', error instanceof Error ? error.message : 'Unknown error');
// Check if it's a 404 error
if (error.statusCode === 404 || error.status === 404) {
console.error('[get-interest-by-id] Interest not found with ID:', id);
throw createError({
statusCode: 404,
statusMessage: `Interest not found with ID: ${id}. It may have been deleted or not yet synchronized.`
});
}
if (error instanceof Error) {
throw createError({ statusCode: 500, statusMessage: error.message });
} else {
throw createError({
statusCode: 500,
statusMessage: "An unexpected error occurred",
});
}
}
});