72 lines
2.0 KiB
TypeScript
72 lines
2.0 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
import { NextRequest, NextResponse } from 'next/server'
|
|
import { createAdminClient } from '@/lib/supabase/server'
|
|
|
|
export async function POST(request: NextRequest) {
|
|
try {
|
|
const db = createAdminClient() as any
|
|
|
|
const body = await request.json()
|
|
const { participation_id, question_id, answer_id } = body
|
|
|
|
if (!participation_id || !question_id) {
|
|
return NextResponse.json(
|
|
{ error: 'participation_id et question_id sont requis' },
|
|
{ status: 400 }
|
|
)
|
|
}
|
|
|
|
const { data: participation, error: partError } = await db
|
|
.from('student_participations')
|
|
.select('id, status, session_id')
|
|
.eq('id', participation_id)
|
|
.single()
|
|
|
|
if (partError || !participation) {
|
|
return NextResponse.json({ error: 'Participation introuvable' }, { status: 404 })
|
|
}
|
|
|
|
if (participation.status === 'completed') {
|
|
return NextResponse.json({ error: 'Ce quiz est déjà terminé' }, { status: 400 })
|
|
}
|
|
|
|
const { data: session } = await db
|
|
.from('sessions')
|
|
.select('is_active')
|
|
.eq('id', participation.session_id)
|
|
.single()
|
|
|
|
if (!session?.is_active) {
|
|
return NextResponse.json(
|
|
{ error: 'Ce quiz est terminé', code: 'SESSION_INACTIVE' },
|
|
{ status: 403 }
|
|
)
|
|
}
|
|
|
|
const { data: studentAnswer, error: answerError } = await db
|
|
.from('student_answers')
|
|
.upsert(
|
|
{
|
|
participation_id,
|
|
question_id,
|
|
answer_id: answer_id ?? null,
|
|
},
|
|
{ onConflict: 'participation_id,question_id' }
|
|
)
|
|
.select()
|
|
.single()
|
|
|
|
if (answerError) {
|
|
return NextResponse.json(
|
|
{ error: 'Erreur enregistrement de la réponse', details: answerError.message },
|
|
{ status: 500 }
|
|
)
|
|
}
|
|
|
|
return NextResponse.json({ success: true, answer: studentAnswer })
|
|
} catch (error) {
|
|
console.error('[student/submit-answer]', error)
|
|
return NextResponse.json({ error: 'Erreur serveur interne' }, { status: 500 })
|
|
}
|
|
}
|