import { Controller, Get, Post, Body, Patch, Param, Delete, UseGuards, } from '@nestjs/common'; import { AssistantesMaternellesService } from './assistantes_maternelles.service'; import { ApiBearerAuth, ApiBody, ApiOperation, ApiParam, ApiResponse, ApiTags } from '@nestjs/swagger'; import { AssistanteMaternelle } from 'src/entities/assistantes_maternelles.entity'; import { Roles } from 'src/common/decorators/roles.decorator'; import { RoleType } from 'src/entities/users.entity'; import { CreateAssistanteDto } from '../user/dto/create_assistante.dto'; import { UpdateAssistanteDto } from '../user/dto/update_assistante.dto'; import { RolesGuard } from 'src/common/guards/roles.guard'; import { AuthGuard } from 'src/common/guards/auth.guard'; @ApiTags("Assistantes Maternelles") @ApiBearerAuth('access-token') @UseGuards(AuthGuard, RolesGuard) @Controller('assistantes-maternelles') export class AssistantesMaternellesController { constructor(private readonly assistantesMaternellesService: AssistantesMaternellesService) { } @Roles(RoleType.SUPER_ADMIN, RoleType.GESTIONNAIRE) @ApiOperation({ summary: 'Créer nounou' }) @ApiResponse({ status: 201, description: 'Nounou créée avec succès' }) @ApiResponse({ status: 403, description: 'Accès refusé : Réservé aux super_admins et gestionnaires' }) @ApiBody({ type: CreateAssistanteDto }) @Post() create(@Body() dto: CreateAssistanteDto): Promise { return this.assistantesMaternellesService.create(dto); } @Roles(RoleType.SUPER_ADMIN, RoleType.GESTIONNAIRE) @Get() @ApiOperation({ summary: 'Récupérer la liste des nounous' }) @ApiResponse({ status: 200, description: 'Liste des nounous' }) @ApiResponse({ status: 403, description: 'Accès refusé : Réservé aux super_admins et gestionnaires' }) getAll(): Promise { return this.assistantesMaternellesService.findAll(); } @Roles(RoleType.SUPER_ADMIN, RoleType.GESTIONNAIRE) @Get(':id') @ApiParam({ name: 'id', description: "UUID de la nounou" }) @ApiOperation({ summary: 'Récupérer une nounou par id' }) @ApiResponse({ status: 200, description: 'Détails de la nounou' }) @ApiResponse({ status: 404, description: 'Nounou non trouvée' }) @ApiResponse({ status: 403, description: 'Accès refusé : Réservé aux super_admins et gestionnaires' }) getOne(@Param('id') user_id: string): Promise { return this.assistantesMaternellesService.findOne(user_id); } @Roles(RoleType.SUPER_ADMIN, RoleType.GESTIONNAIRE) @ApiBody({ type: UpdateAssistanteDto }) @ApiOperation({ summary: 'Mettre à jour une nounou' }) @ApiResponse({ status: 200, description: 'Nounou mise à jour avec succès' }) @ApiResponse({ status: 403, description: 'Accès refusé : Réservé aux super_admins et gestionnaires' }) @ApiResponse({ status: 404, description: 'Nounou non trouvée' }) @ApiParam({ name: 'id', description: "UUID de la nounou" }) @Patch(':id') update(@Param('id') id: string, @Body() dto: UpdateAssistanteDto): Promise { return this.assistantesMaternellesService.update(id, dto); } @Roles(RoleType.SUPER_ADMIN, RoleType.GESTIONNAIRE, RoleType.ADMINISTRATEUR) @ApiOperation({ summary: 'Supprimer une nounou' }) @ApiResponse({ status: 200, description: 'Nounou supprimée avec succès' }) @ApiResponse({ status: 403, description: 'Accès refusé : Réservé aux super_admins, gestionnaires et administrateurs' }) @ApiResponse({ status: 404, description: 'Nounou non trouvée' }) @ApiParam({ name: 'id', description: "UUID de la nounou" }) @Delete(':id') remove(@Param('id') id: string): Promise<{ message: string }> { return this.assistantesMaternellesService.remove(id); } }