86 lines
2.4 KiB
TypeScript
86 lines
2.4 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
import { NextRequest, NextResponse } from 'next/server'
|
|
import { createClient } from '@/lib/supabase/server'
|
|
import { nanoid } from 'nanoid'
|
|
|
|
const MAX_RETRIES = 10
|
|
|
|
async function generateUniqueCode(supabase: any): Promise<string> {
|
|
for (let i = 0; i < MAX_RETRIES; i++) {
|
|
const code = nanoid(6).toUpperCase()
|
|
const { data } = await supabase
|
|
.from('sessions')
|
|
.select('id')
|
|
.eq('short_code', code)
|
|
.maybeSingle()
|
|
|
|
if (!data) return code
|
|
}
|
|
throw new Error('Impossible de générer un code unique après plusieurs tentatives')
|
|
}
|
|
|
|
export async function POST(request: NextRequest) {
|
|
try {
|
|
const supabase = await createClient()
|
|
const db = supabase as any
|
|
|
|
const { data: { user }, error: authError } = await supabase.auth.getUser()
|
|
if (authError || !user) {
|
|
return NextResponse.json({ error: 'Non autorisé' }, { status: 401 })
|
|
}
|
|
|
|
const body = await request.json()
|
|
const { quiz_id, school_name, class_name, total_participants } = body
|
|
|
|
if (!quiz_id) {
|
|
return NextResponse.json({ error: 'quiz_id est requis' }, { status: 400 })
|
|
}
|
|
|
|
const { data: quiz, error: quizError } = await db
|
|
.from('quizzes')
|
|
.select('id')
|
|
.eq('id', quiz_id)
|
|
.eq('author_id', user.id)
|
|
.single()
|
|
|
|
if (quizError || !quiz) {
|
|
return NextResponse.json({ error: 'Quiz introuvable ou accès refusé' }, { status: 404 })
|
|
}
|
|
|
|
const shortCode = await generateUniqueCode(db)
|
|
|
|
const { data: session, error: sessionError } = await db
|
|
.from('sessions')
|
|
.insert({
|
|
short_code: shortCode,
|
|
quiz_id,
|
|
trainer_id: user.id,
|
|
school_name: school_name ?? null,
|
|
class_name: class_name ?? null,
|
|
total_participants: total_participants ?? 0,
|
|
is_active: true,
|
|
})
|
|
.select()
|
|
.single()
|
|
|
|
if (sessionError || !session) {
|
|
return NextResponse.json(
|
|
{ error: 'Erreur création de la session', details: sessionError?.message },
|
|
{ status: 500 }
|
|
)
|
|
}
|
|
|
|
return NextResponse.json({
|
|
success: true,
|
|
session: {
|
|
id: session.id,
|
|
short_code: session.short_code,
|
|
is_active: session.is_active,
|
|
},
|
|
})
|
|
} catch (error) {
|
|
console.error('[sessions/create]', error)
|
|
return NextResponse.json({ error: 'Erreur serveur interne' }, { status: 500 })
|
|
}
|
|
}
|