forked from Ynov/ptitspas-ynov-back
82 lines
3.7 KiB
TypeScript
82 lines
3.7 KiB
TypeScript
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<AssistanteMaternelle> {
|
|
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<AssistanteMaternelle[]> {
|
|
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<AssistanteMaternelle> {
|
|
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<AssistanteMaternelle> {
|
|
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);
|
|
}
|
|
}
|