All checks were successful
Deploy with Docker Compose / deploy (push) Successful in 12m53s
92 lines
2.7 KiB
TypeScript
92 lines
2.7 KiB
TypeScript
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 }
|
|
);
|
|
}
|
|
}
|
|
|