mirror of
https://github.com/pacnpal/thrilltrack-explorer.git
synced 2025-12-23 09:51:12 -05:00
Fix: Address HMR failures and Fast Refresh incompatibility
This commit is contained in:
@@ -7,7 +7,13 @@ const corsHeaders = {
|
||||
'Access-Control-Allow-Headers': 'authorization, x-client-info, apikey, content-type',
|
||||
};
|
||||
|
||||
// Simple request tracking
|
||||
const startRequest = () => ({ requestId: crypto.randomUUID(), start: Date.now() });
|
||||
const endRequest = (tracking: { start: number }) => Date.now() - tracking.start;
|
||||
|
||||
serve(async (req) => {
|
||||
const tracking = startRequest();
|
||||
|
||||
if (req.method === 'OPTIONS') {
|
||||
return new Response(null, { headers: corsHeaders });
|
||||
}
|
||||
@@ -19,7 +25,11 @@ serve(async (req) => {
|
||||
|
||||
const event = await req.json();
|
||||
|
||||
edgeLogger.info('Received Novu webhook event', { action: 'novu_webhook', eventType: event.type });
|
||||
edgeLogger.info('Received Novu webhook event', {
|
||||
action: 'novu_webhook',
|
||||
eventType: event.type,
|
||||
requestId: tracking.requestId
|
||||
});
|
||||
|
||||
// Handle different webhook events
|
||||
switch (event.type) {
|
||||
@@ -36,26 +46,47 @@ serve(async (req) => {
|
||||
await handleNotificationFailed(supabase, event);
|
||||
break;
|
||||
default:
|
||||
edgeLogger.warn('Unhandled Novu event type', { action: 'novu_webhook', eventType: event.type });
|
||||
edgeLogger.warn('Unhandled Novu event type', {
|
||||
action: 'novu_webhook',
|
||||
eventType: event.type,
|
||||
requestId: tracking.requestId
|
||||
});
|
||||
}
|
||||
|
||||
const duration = endRequest(tracking);
|
||||
|
||||
return new Response(
|
||||
JSON.stringify({ success: true }),
|
||||
JSON.stringify({ success: true, requestId: tracking.requestId }),
|
||||
{
|
||||
headers: { ...corsHeaders, 'Content-Type': 'application/json' },
|
||||
headers: {
|
||||
...corsHeaders,
|
||||
'Content-Type': 'application/json',
|
||||
'X-Request-ID': tracking.requestId
|
||||
},
|
||||
status: 200,
|
||||
}
|
||||
);
|
||||
} catch (error: any) {
|
||||
edgeLogger.error('Error processing webhook', { action: 'novu_webhook', error: error?.message });
|
||||
const duration = endRequest(tracking);
|
||||
edgeLogger.error('Error processing webhook', {
|
||||
action: 'novu_webhook',
|
||||
error: error?.message,
|
||||
requestId: tracking.requestId,
|
||||
duration
|
||||
});
|
||||
|
||||
return new Response(
|
||||
JSON.stringify({
|
||||
success: false,
|
||||
error: error.message,
|
||||
requestId: tracking.requestId
|
||||
}),
|
||||
{
|
||||
headers: { ...corsHeaders, 'Content-Type': 'application/json' },
|
||||
headers: {
|
||||
...corsHeaders,
|
||||
'Content-Type': 'application/json',
|
||||
'X-Request-ID': tracking.requestId
|
||||
},
|
||||
status: 500,
|
||||
}
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user