import { NextResponse } from 'next/server'; import { auth } from '@/lib/auth'; import { getTeam, updateTeam, deleteTeam, isTeamAdmin, isTeamMember } from '@/services/teams'; import type { UpdateTeamInput } from '@/lib/types'; export async function GET(request: Request, { params }: { params: Promise<{ id: string }> }) { try { const { id } = await params; const session = await auth(); if (!session?.user?.id) { return NextResponse.json({ error: 'Non autorisé' }, { status: 401 }); } const team = await getTeam(id); if (!team) { return NextResponse.json({ error: 'Équipe non trouvée' }, { status: 404 }); } // Check if user is a member const isMember = await isTeamMember(id, session.user.id); if (!isMember) { return NextResponse.json({ error: 'Accès refusé' }, { status: 403 }); } return NextResponse.json(team); } catch (error) { console.error('Error fetching team:', error); return NextResponse.json( { error: 'Erreur lors de la récupération de l\'équipe' }, { status: 500 } ); } } export async function PATCH(request: Request, { params }: { params: Promise<{ id: string }> }) { try { const { id } = await params; const session = await auth(); if (!session?.user?.id) { return NextResponse.json({ error: 'Non autorisé' }, { status: 401 }); } // Check if user is admin const isAdmin = await isTeamAdmin(id, session.user.id); if (!isAdmin) { return NextResponse.json({ error: 'Seuls les administrateurs peuvent modifier l\'équipe' }, { status: 403 }); } const body: UpdateTeamInput = await request.json(); const team = await updateTeam(id, body); return NextResponse.json(team); } catch (error) { console.error('Error updating team:', error); return NextResponse.json( { error: 'Erreur lors de la mise à jour de l\'équipe' }, { status: 500 } ); } } export async function DELETE(request: Request, { params }: { params: Promise<{ id: string }> }) { try { const { id } = await params; const session = await auth(); if (!session?.user?.id) { return NextResponse.json({ error: 'Non autorisé' }, { status: 401 }); } // Check if user is admin const isAdmin = await isTeamAdmin(id, session.user.id); if (!isAdmin) { return NextResponse.json({ error: 'Seuls les administrateurs peuvent supprimer l\'équipe' }, { status: 403 }); } await deleteTeam(id); return NextResponse.json({ success: true }); } catch (error) { console.error('Error deleting team:', error); return NextResponse.json( { error: 'Erreur lors de la suppression de l\'équipe' }, { status: 500 } ); } }