módulo controller final

This commit is contained in:
lemuel 2022-12-23 08:21:51 -06:00
parent fd8592872c
commit 5c08668a22
2 changed files with 28 additions and 37 deletions

View File

@ -1,6 +1,6 @@
import { Expose } from 'class-transformer'; import { Expose } from 'class-transformer';
export class OnlyModuloMinOutputDto { export class OnlyModuloOutputDto {
@Expose() @Expose()
id_modulo; id_modulo;

View File

@ -1,7 +1,6 @@
import { import {
Body, Body,
Controller, Controller,
ForbiddenException,
Get, Get,
Post, Post,
Put, Put,
@ -27,7 +26,7 @@ import { ModuloDto } from './dto/input/modulo.dto';
import { UpdateModuloDto } from './dto/input/update.dto'; import { UpdateModuloDto } from './dto/input/update.dto';
import { MessageOutputDto } from '../dto/output/message.dto'; import { MessageOutputDto } from '../dto/output/message.dto';
import { ModuloOutputDto } from './dto/output/modulo.dto'; import { ModuloOutputDto } from './dto/output/modulo.dto';
import { OnlyModuloMinOutputDto } from './dto/output/only-modulo-min.dto'; import { OnlyModuloOutputDto } from './dto/output/only-modulo.dto';
@Controller('modulo') @Controller('modulo')
@ApiTags('modulo') @ApiTags('modulo')
@ -40,11 +39,11 @@ export class ModuloController {
@Serealize(MessageOutputDto) @Serealize(MessageOutputDto)
@Post() @Post()
@UseGuards(AuthGuard('jwt')) @UseGuards(AuthGuard('jwt'))
@ApiOperation({ description: 'Endpoint que crea un módulo.' }) @ApiOperation({ description: 'Crear un nuevo módulo.' })
@ApiBearerAuth('jwt') @ApiBearerAuth('jwt')
@ApiBody({ @ApiBody({
description: 'Ambas variables son obligatorias.', description: 'Variables que necesita el endpoint.',
examples: { ejemplo: { value: { id_institucion: 200, modulo: '' } } }, examples: { ejemplo: { value: { modulo: '' } } },
}) })
create(@Request() req, @Body() body: CreateModuloDto) { create(@Request() req, @Body() body: CreateModuloDto) {
const admin: Operador = req.user.operador; const admin: Operador = req.user.operador;
@ -57,7 +56,7 @@ export class ModuloController {
@Get('modulo') @Get('modulo')
@UseGuards(AuthGuard('jwt')) @UseGuards(AuthGuard('jwt'))
@ApiOperation({ @ApiOperation({
description: 'Endpoint que retorna la información de un módulo.', description: 'Información de un módulo de la institución de un operador.',
}) })
@ApiBearerAuth('jwt') @ApiBearerAuth('jwt')
@ApiQuery({ @ApiQuery({
@ -69,46 +68,28 @@ export class ModuloController {
const admin: Operador = req.user.operador; const admin: Operador = req.user.operador;
this.validarUsuarioService.validarAdmin(admin); this.validarUsuarioService.validarAdmin(admin);
return this.moduloService return this.moduloService.findMinInfoModuloById(parseInt(query.id_modulo));
.findMinInfoModuloById(parseInt(query.id_modulo))
.then((modulo) => {
if (
admin.tipoUsuario.id_tipo_usuario === 3 &&
admin.institucion.id_institucion != modulo.institucion.id_institucion
)
throw new ForbiddenException(
'No puedes acceder a esta información porque no le pertenece a tu institución.',
);
return modulo;
});
} }
@Serealize(OnlyModuloMinOutputDto) @Serealize(OnlyModuloOutputDto)
@Get('modulos') @Get('modulos')
@UseGuards(AuthGuard('jwt')) @UseGuards(AuthGuard('jwt'))
@ApiOperation({ @ApiOperation({
description: 'Endpoint que retorna todos los módulos de una institución.', description: 'Todos los módulos de una institución de un operador.',
}) })
@ApiBearerAuth('jwt') @ApiBearerAuth('jwt')
@ApiQuery({ modulos(@Request() req) {
description: 'Id de la institución.', const admin: Operador = req.user.operador;
name: 'id_institucion',
type: 'string',
})
modulos(@Request() req, @Query() query: IdInstitucionDto) {
const operador: Operador = req.user.operador;
this.validarUsuarioService.validarOperador(operador); this.validarUsuarioService.validarAdmin(admin);
return this.moduloService.findMinInfoModuloAll( return this.moduloService.findMinInfoModuloAll(
parseInt(query.id_institucion), admin.institucion.id_institucion,
); );
} }
@Serealize(OnlyModuloMinOutputDto) @Serealize(OnlyModuloOutputDto)
@Get('modulos-activos') @Get('modulos-activos')
@ApiOperation({ @ApiOperation({ description: 'Todos los módulos de una institución.' })
description: 'Endpoint que retorna todos los módulos de una institución.',
})
@ApiQuery({ @ApiQuery({
description: 'Id de la institución.', description: 'Id de la institución.',
name: 'id_institucion', name: 'id_institucion',
@ -129,9 +110,19 @@ export class ModuloController {
}) })
@ApiBearerAuth('jwt') @ApiBearerAuth('jwt')
@ApiBody({ @ApiBody({
description: 'Todas las variables a excepción de id_modulo son opcionales.', description:
'Variables que necesita el endpoint. Las variables con "_" al inicio son opcionales.',
examples: { examples: {
ejemplo: { value: { id_modulo: 1, _activo: true, _modulo: '' } }, ejemplo: {
value: {
id_modulo: 1,
_activo: true,
_modulo: '',
_motivo: '',
_numero_alumnos: 1,
_fecha_creacion: '',
},
},
}, },
}) })
update(@Request() req, @Body() body: UpdateModuloDto) { update(@Request() req, @Body() body: UpdateModuloDto) {
@ -139,7 +130,7 @@ export class ModuloController {
const data = { ...body }; const data = { ...body };
this.validarUsuarioService.validarAdmin(admin); this.validarUsuarioService.validarAdmin(admin);
delete data.modulo; delete data.motivo;
delete data.numero_alumnos; delete data.numero_alumnos;
delete data.fecha_creacion; delete data.fecha_creacion;
return this.moduloService.update( return this.moduloService.update(