Add detailed logging to API endpoints for debugging 500 errors

This commit is contained in:
Marco Gallegos
2026-01-18 08:49:16 -06:00
parent c0a9568e5c
commit 93366fc596
17 changed files with 2020 additions and 127 deletions

View File

@@ -6,8 +6,15 @@ import { supabase } from '@/lib/supabase/client'
*/
export async function GET(request: NextRequest) {
try {
console.log('Services API called with URL:', request.url)
const { searchParams } = new URL(request.url)
const locationId = searchParams.get('location_id')
console.log('Location ID filter:', locationId)
// Check Supabase connection
console.log('Supabase URL:', process.env.NEXT_PUBLIC_SUPABASE_URL)
console.log('Supabase key exists:', !!process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY)
let query = supabase
.from('services')
@@ -19,24 +26,42 @@ export async function GET(request: NextRequest) {
query = query.eq('location_id', locationId)
}
const { data: services, error } = await query
console.log('Executing query...')
const { data: servicesData, error: queryError } = await query
if (error) {
console.error('Services GET error:', error)
console.log('Query result - data:', !!servicesData, 'error:', !!queryError)
if (queryError) {
console.error('Services GET error details:', {
message: queryError.message,
code: queryError.code,
details: queryError.details,
hint: queryError.hint
})
return NextResponse.json(
{ error: error.message },
{
error: queryError.message,
code: queryError.code,
details: queryError.details
},
{ status: 500 }
)
}
console.log('Services found:', servicesData?.length || 0)
return NextResponse.json({
success: true,
services: services || []
services: servicesData || [],
count: servicesData?.length || 0
})
} catch (error) {
console.error('Services GET error:', error)
console.error('Services GET unexpected error:', error)
console.error('Error stack:', error instanceof Error ? error.stack : 'Unknown error')
return NextResponse.json(
{ error: 'Internal server error' },
{
error: 'Internal server error',
details: error instanceof Error ? error.message : 'Unknown error'
},
{ status: 500 }
)
}