equipo tipo entrada service final

This commit is contained in:
lemuel 2022-12-20 14:22:39 -06:00
parent 9cb1a2c8ad
commit a0965b5d49
6 changed files with 94 additions and 79 deletions

View File

@ -53,7 +53,7 @@ export class CarreraProgramaService {
where: { institucionCarrera, programa }, where: { institucionCarrera, programa },
}) })
.then((existeCarretaPrograma) => { .then((existeCarretaPrograma) => {
// Si encuentro uno saco error // Si encontramos uno sacamos error
if (existeCarretaPrograma) if (existeCarretaPrograma)
throw new ConflictException( throw new ConflictException(
'Ya se asignó este programa a esta carrera.', 'Ya se asignó este programa a esta carrera.',

View File

@ -40,16 +40,15 @@ export class EquipoProgramaService {
id_programa, id_programa,
); );
// Validamos que el programa seleccionado no sea "Sin programa" // Validamos que el programa seleccionado no sea "Sin software"
if (programa.id_programa === 1) if (programa.id_programa === 1)
throw new ConflictException( throw new ConflictException(
'No se puede asignar manualmente sin programa.', 'No se puede asignar manualmente sin software.',
); );
// Validamos que el equipo pertenezca a la institución del operador // Validamos que el equipo pertenezca a la institución del operador
if ( if (
operador.tipoUsuario.id_tipo_usuario > 2 &&
operador.institucion.id_institucion != operador.institucion.id_institucion !=
equipo.carrito.modulo.institucion.id_institucion equipo.carrito.modulo.institucion.id_institucion
) )
throw new ForbiddenException( throw new ForbiddenException(
'No puedes modificar la información este equipo porque no pertenece a tu institución.', 'No puedes modificar la información este equipo porque no pertenece a tu institución.',
@ -57,7 +56,7 @@ export class EquipoProgramaService {
// Buscamos un registro con los datos mandados del client // Buscamos un registro con los datos mandados del client
return this.findByEquipoPrograma(equipo, programa) return this.findByEquipoPrograma(equipo, programa)
.then((existeEquipoPrograma) => { .then((existeEquipoPrograma) => {
// Si encuentro uno saco error // Si encontramos uno sacamos error
if (existeEquipoPrograma) if (existeEquipoPrograma)
throw new ConflictException( throw new ConflictException(
'Este software ya fue asignado a este equipo.', 'Este software ya fue asignado a este equipo.',
@ -70,7 +69,7 @@ export class EquipoProgramaService {
} }
create(equipo: Equipo, programa: Programa): Promise<EquipoPrograma> { create(equipo: Equipo, programa: Programa): Promise<EquipoPrograma> {
// Verificamos si tiene programa "Sin programa" // Verificamos si tiene programa "Sin software"
return this.findByEquipoPrograma(equipo, { id_programa: 1 }).then( return this.findByEquipoPrograma(equipo, { id_programa: 1 }).then(
async (existeEquipoSinPrograma) => { async (existeEquipoSinPrograma) => {
// Si lo tiene lo eliminamos // Si lo tiene lo eliminamos
@ -105,13 +104,13 @@ export class EquipoProgramaService {
// No se puede eliminar "Sin programa" manualmente // No se puede eliminar "Sin programa" manualmente
if (equipoPrograma.programa.id_programa === 1) if (equipoPrograma.programa.id_programa === 1)
throw new ConflictException( throw new ConflictException(
'No se puede eliminar manualmente sin programa.', 'No se puede eliminar manualmente sin software.',
); );
// Buscamos cuantos programas tiene el equipo // Buscamos cuantos programas tiene el equipo
return this.repository return this.repository
.count({ where: { equipo: equipoPrograma.equipo } }) .count({ where: { equipo: equipoPrograma.equipo } })
.then(async (n) => { .then(async (n) => {
// Asignar "Sin programa" si es que solo tiene 1, el que se va a eliminar // Asignar "Sin software" si es que solo tiene 1, el que se va a eliminar
if (n === 1) await this.createSinPrograma(equipoPrograma.equipo); if (n === 1) await this.createSinPrograma(equipoPrograma.equipo);
// Eliminamos registro // Eliminamos registro
return this.repository.remove(equipoPrograma); return this.repository.remove(equipoPrograma);
@ -121,24 +120,11 @@ export class EquipoProgramaService {
})); }));
} }
findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoPrograma[]> { findByEquipoPrograma(
return this.fullInformacionEquipoProgramaView equipo: Equipo,
.find({ where: { id_equipo } }) programa: Programa | Partial<Programa>,
.then((infoEquipoProgramas) => { ): Promise<EquipoPrograma> {
const equipoProgramas: EquipoPrograma[] = []; return this.repository.findOne({ where: { equipo, programa } });
for (let i = 0; i < infoEquipoProgramas.length; i++)
equipoProgramas.push(
this.repository.create({
id_equipo_programa: infoEquipoProgramas[i].id_equipo_programa,
programa: {
id_programa: infoEquipoProgramas[i].id_programa,
programa: infoEquipoProgramas[i].programa,
},
}),
);
return equipoProgramas;
});
} }
findById(id_equipo_programa: number): Promise<EquipoPrograma> { findById(id_equipo_programa: number): Promise<EquipoPrograma> {
@ -169,10 +155,23 @@ export class EquipoProgramaService {
}); });
} }
findByEquipoPrograma( findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoPrograma[]> {
equipo: Equipo, return this.fullInformacionEquipoProgramaView
programa: Programa | Partial<Programa>, .find({ where: { id_equipo } })
): Promise<EquipoPrograma> { .then((infoEquipoProgramas) => {
return this.repository.findOne({ where: { equipo, programa } }); const equipoProgramas: EquipoPrograma[] = [];
for (let i = 0; i < infoEquipoProgramas.length; i++)
equipoProgramas.push(
this.repository.create({
id_equipo_programa: infoEquipoProgramas[i].id_equipo_programa,
programa: {
id_programa: infoEquipoProgramas[i].id_programa,
programa: infoEquipoProgramas[i].programa,
},
}),
);
return equipoProgramas;
});
} }
} }

View File

@ -38,6 +38,7 @@ export class EquipoTipoEntradaController {
this.validarUsuarioService.validarAdminOperador(operador); this.validarUsuarioService.validarAdminOperador(operador);
return this.equipoTipoEntradaService.asignar( return this.equipoTipoEntradaService.asignar(
operador,
body.id_equipo, body.id_equipo,
body.id_tipo_entrada, body.id_tipo_entrada,
); );

View File

@ -30,37 +30,50 @@ export class EquipoTipoEntradaService {
private institucionTipoEntradaService: InstitucionTipoEntradaService, private institucionTipoEntradaService: InstitucionTipoEntradaService,
) {} ) {}
async asignar(id_equipo: number, id_tipo_entrada: number) { async asignar(
operador: Operador,
id_equipo: number,
id_tipo_entrada: number,
): Promise<{ message: string }> {
const equipo = await this.equipoService.findById(id_equipo); const equipo = await this.equipoService.findById(id_equipo);
const tipoEntrada = const tipoEntrada =
await this.institucionTipoEntradaService.findTipoEntradaById( await this.institucionTipoEntradaService.findTipoEntradaById(
id_tipo_entrada, id_tipo_entrada,
); );
// Validamos que no eixsta un registro con estos ids // Validamos que el equipo pertenezca a la institución del operador
return this.findByEquipoTipoEntrada(equipo, tipoEntrada).then( if (
(existeEquipoTipoEntrada) => { operador.institucion.id_institucion !=
// Error si existe saco error equipo.carrito.modulo.institucion.id_institucion
)
throw new ForbiddenException(
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
);
// Buscamos un registro con los datos mandados del client
return this.findByEquipoTipoEntrada(equipo, tipoEntrada)
.then((existeEquipoTipoEntrada) => {
// Si encontramos uno sacamos error
if (existeEquipoTipoEntrada) if (existeEquipoTipoEntrada)
throw new ConflictException( throw new ConflictException(
'Este tipo de entrada ya fue asignado a este equipo.', 'Este conector ya fue asignado a este equipo.',
); );
return this.create(equipo, tipoEntrada); return this.create(equipo, tipoEntrada);
}, })
); .then((_) => ({
} message: 'Se asignó correctamente el conector a este equipo.',
create(equipo: Equipo, tipoEntrada: TipoEntrada) {
// Crear y guradar registro
return this.repository
.save(this.repository.create({ equipo, tipoEntrada }))
.then((equipoTipoEntrada) => ({
message: `Se asignó el tipo de entrada: ${tipoEntrada.tipo_entrada}, al equipo con número de inventario: ${equipo.numero_inventario}.`,
equipoTipoEntrada,
})); }));
} }
delete(operador: Operador, id_equipo_tipo_entrada: number) { create(equipo: Equipo, tipoEntrada: TipoEntrada): Promise<EquipoTipoEntrada> {
return this.repository.save(
this.repository.create({ equipo, tipoEntrada }),
);
}
delete(
operador: Operador,
id_equipo_tipo_entrada: number,
): Promise<{ message: string }> {
return this.findById(id_equipo_tipo_entrada) return this.findById(id_equipo_tipo_entrada)
.then((equipoTipoEntrada) => { .then((equipoTipoEntrada) => {
// Validamos que el equipo pertenezca a la institución del operador // Validamos que el equipo pertenezca a la institución del operador
@ -71,36 +84,22 @@ export class EquipoTipoEntradaService {
throw new ForbiddenException( throw new ForbiddenException(
'No puedes modificar la información este equipo porque no pertenece a tu institución.', 'No puedes modificar la información este equipo porque no pertenece a tu institución.',
); );
// Eliminar registro // Eliminamos registro
return this.repository.remove(equipoTipoEntrada); return this.repository.remove(equipoTipoEntrada);
}) })
.then((_) => ({ .then((_) => ({
message: 'Se eliminó correctamente el tipo de entrada de este equipo.', message: 'Se eliminó correctamente el conector de este equipo.',
})); }));
} }
findFullInfoAllByIdEquipo(id_equipo: number) { findByEquipoTipoEntrada(
return this.fullInformacionEquipoTipoEntradaView equipo: Equipo,
.find({ where: { id_equipo } }) tipoEntrada: TipoEntrada,
.then((infoEquipoTipoEntradas) => { ): Promise<EquipoTipoEntrada> {
const equipoTipoEntradas: EquipoTipoEntrada[] = []; return this.repository.findOne({ where: { equipo, tipoEntrada } });
for (let i = 0; i < infoEquipoTipoEntradas.length; i++)
equipoTipoEntradas.push(
this.repository.create({
id_equipo_tipo_entrada:
infoEquipoTipoEntradas[i].id_equipo_tipo_entrada,
tipoEntrada: {
id_tipo_entrada: infoEquipoTipoEntradas[i].id_tipo_entrada,
tipo_entrada: infoEquipoTipoEntradas[i].tipo_entrada,
},
}),
);
return equipoTipoEntradas;
});
} }
findById(id_equipo_tipo_entrada: number) { findById(id_equipo_tipo_entrada: number): Promise<EquipoTipoEntrada> {
return this.informacionEquipoTipoEntradaView return this.informacionEquipoTipoEntradaView
.findOne({ where: { id_equipo_tipo_entrada } }) .findOne({ where: { id_equipo_tipo_entrada } })
.then((infoEquipoTipoEntrada) => { .then((infoEquipoTipoEntrada) => {
@ -130,7 +129,24 @@ export class EquipoTipoEntradaService {
}); });
} }
findByEquipoTipoEntrada(equipo: Equipo, tipoEntrada: TipoEntrada) { findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoTipoEntrada[]> {
return this.repository.findOne({ where: { equipo, tipoEntrada } }); return this.fullInformacionEquipoTipoEntradaView
.find({ where: { id_equipo } })
.then((infoEquipoTipoEntradas) => {
const equipoTipoEntradas: EquipoTipoEntrada[] = [];
for (let i = 0; i < infoEquipoTipoEntradas.length; i++)
equipoTipoEntradas.push(
this.repository.create({
id_equipo_tipo_entrada:
infoEquipoTipoEntradas[i].id_equipo_tipo_entrada,
tipoEntrada: {
id_tipo_entrada: infoEquipoTipoEntradas[i].id_tipo_entrada,
tipo_entrada: infoEquipoTipoEntradas[i].tipo_entrada,
},
}),
);
return equipoTipoEntradas;
});
} }
} }

View File

@ -67,7 +67,7 @@ export class MultaService {
// correctamente esa vez // correctamente esa vez
if (existeMulta) return; if (existeMulta) return;
this.validacionMultaCancelacion(prestamo); this.validacionMultaCancelacion(prestamo);
// Si no se mando un id_institucion_infraccion ni retraso saco error // Si no se mando un id_institucion_infraccion ni retraso sacamos error
if (!id_institucion_infraccion && !retraso) if (!id_institucion_infraccion && !retraso)
throw new ConflictException( throw new ConflictException(
'No se mandó ningún motivo para multar a este alumno.', 'No se mandó ningún motivo para multar a este alumno.',

View File

@ -301,10 +301,9 @@ export class UploadFileService {
} }
await this.equipoTipoEntradaService await this.equipoTipoEntradaService
.create(equipo, tipoEntrada) .create(equipo, tipoEntrada)
.then((res) => { .then((equipoTipoEntrada) =>
equipo.tiposEntradas.push(res.equipoTipoEntrada); equipo.tiposEntradas.push(equipoTipoEntrada),
mensajes.push(res.message); );
});
} }
for (let j = 0; j < programas.length; j++) { for (let j = 0; j < programas.length; j++) {
const programa = const programa =