corenthin-lebreton 28aa3b0e10 initial project
2026-02-26 20:10:14 +01:00

73 lines
2.1 KiB
TypeScript

/* eslint-disable @typescript-eslint/no-explicit-any */
import { NextRequest, NextResponse } from 'next/server'
import { createClient } from '@/lib/supabase/server'
export async function POST(request: NextRequest) {
try {
const supabase = await createClient()
const db = supabase 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 })
}
}