equipo programa actualizado

This commit is contained in:
xXpuma99Xx 2022-10-15 16:27:27 -05:00
parent d83454af1f
commit 449e2acb5d
8 changed files with 161 additions and 97 deletions

View File

@ -11,7 +11,7 @@ export class EquipoPrograma {
@JoinColumn({ name: 'id_equipo' }) @JoinColumn({ name: 'id_equipo' })
equipo: Equipo; equipo: Equipo;
@ManyToOne(() => Programa, (programa) => programa.equipos, { eager: true }) @ManyToOne(() => Programa, (programa) => programa.equipos)
@JoinColumn({ name: 'id_programa' }) @JoinColumn({ name: 'id_programa' })
programa: Programa; programa: Programa;
} }

View File

@ -1,5 +1,8 @@
import { DataSource, ViewEntity, ViewColumn } from 'typeorm'; import { DataSource, ViewEntity, ViewColumn } from 'typeorm';
import { EquipoPrograma } from '../equipo-programa.entity'; import { EquipoPrograma } from '../equipo-programa.entity';
import { Equipo } from '../../../equipo/entity/equipo.entity';
import { Carrito } from '../../../carrito/entity/carrito.entity';
import { Modulo } from '../../../modulo/entity/modulo.entity';
@ViewEntity({ @ViewEntity({
expression: (dataSource: DataSource) => expression: (dataSource: DataSource) =>
@ -8,15 +11,34 @@ import { EquipoPrograma } from '../equipo-programa.entity';
.select('ep.id_equipo_programa', 'id_equipo_programa') .select('ep.id_equipo_programa', 'id_equipo_programa')
.addSelect('ep.id_equipo', 'id_equipo') .addSelect('ep.id_equipo', 'id_equipo')
.addSelect('ep.id_programa', 'id_programa') .addSelect('ep.id_programa', 'id_programa')
.from(EquipoPrograma, 'ep'), .addSelect('e.id_carrito', 'id_carrito')
.addSelect('c.id_modulo', 'id_modulo')
.addSelect('c.id_tipo_carrito', 'id_tipo_carrito')
.addSelect('m.id_institucion', 'id_institucion')
.from(EquipoPrograma, 'ep')
.innerJoin(Equipo, 'e', 'e.id_equipo = ep.id_equipo')
.innerJoin(Carrito, 'c', 'c.id_carrito = e.id_carrito')
.innerJoin(Modulo, 'm', 'm.id_modulo = c.id_modulo'),
}) })
export class InformacionEquipoProgramaView { export class InformacionEquipoProgramaView {
@ViewColumn() @ViewColumn()
id_equipo_programa: number; id_equipo_programa: number;
@ViewColumn()
id_carrito: number;
@ViewColumn() @ViewColumn()
id_equipo: number; id_equipo: number;
@ViewColumn()
id_institucion: number;
@ViewColumn()
id_modulo: number;
@ViewColumn() @ViewColumn()
id_programa: number; id_programa: number;
@ViewColumn()
id_tipo_carrito: number;
} }

View File

@ -37,7 +37,11 @@ export class EquipoProgramaController {
const operador: Operador = req.user.operador; const operador: Operador = req.user.operador;
this.validarUsuarioService.validarAdminOperador(operador); this.validarUsuarioService.validarAdminOperador(operador);
return this.equipoProgramaService.create(body.id_equipo, body.id_programa); return this.equipoProgramaService.asignar(
operador,
body.id_equipo,
body.id_programa,
);
} }
@Delete() @Delete()

View File

@ -30,36 +30,45 @@ export class EquipoProgramaService {
private institucionProgramaService: InstitucionProgramaService, private institucionProgramaService: InstitucionProgramaService,
) {} ) {}
async create( async asignar(operador: Operador, id_equipo: number, id_programa: number) {
// operador: Operador, const equipo = await this.equipoService.findInfoEquipoById(id_equipo);
id_equipo: number | Equipo, const programa = await this.institucionProgramaService.findProgramaById(
id_programa: number | Programa, id_programa,
) { );
const equipo =
typeof id_equipo === 'number'
? await this.equipoService.findInfoEquipoById(id_equipo)
: id_equipo;
const programa =
typeof id_programa === 'number'
? await this.institucionProgramaService.findProgramaById(id_programa)
: id_programa;
return this.informacionEquipoPrograma( // Valida que el equipo pertenezca a la institución del operador
if (
operador.tipoUsuario.id_tipo_usuario > 2 &&
operador.institucion.id_institucion !=
equipo.carrito.modulo.institucion.id_institucion
)
throw new ForbiddenException(
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
);
// Verifica que no eixsta un registro con estos ids
return this.findInfoEquipoProgramaByIdEquipoIdPrograma(
equipo.id_equipo, equipo.id_equipo,
programa.id_programa, programa.id_programa,
) ).then((existeEquipoPrograma) => {
.then((existeEquipoPrograma) => { // Error si existe
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.',
); );
return this.informacionEquipoPrograma(equipo.id_equipo, 1);
}) // Creo registro
.then(async (existeEquipoSinPrograma) => { return this.create(equipo, programa);
if (existeEquipoSinPrograma)
await this.repository.delete({
id_equipo_programa: existeEquipoSinPrograma.id_equipo_programa,
}); });
}
async create(equipo: Equipo, programa: Programa) {
// Ver si tiene programa "Sin programa"
return this.findInfoEquipoProgramaByIdEquipoIdPrograma(equipo.id_equipo, 1)
.then(async (existeEquipoSinPrograma) => {
// Si tiene lo elimino
if (existeEquipoSinPrograma)
await this.repository.remove(existeEquipoSinPrograma);
// Creo el registro
return this.repository.save( return this.repository.save(
this.repository.create({ equipo, programa }), this.repository.create({ equipo, programa }),
); );
@ -70,41 +79,33 @@ export class EquipoProgramaService {
})); }));
} }
async createCargaMasiva(equipo: Equipo, programa: Programa) { async createSinPrograma(equipo: Equipo) {
return this.informacionEquipoPrograma(equipo.id_equipo, 1)
.then(async (existeEquipoSinPrograma) => {
if (existeEquipoSinPrograma)
await this.repository.delete({
id_equipo_programa: existeEquipoSinPrograma.id_equipo_programa,
});
return this.repository.save( return this.repository.save(
this.repository.create({ equipo, programa }), this.repository.create({ equipo, programa: { id_programa: 1 } }),
); );
})
.then((equipoPrograma) => ({
message: `Se asignó el software: ${equipoPrograma.programa.programa}, al equipo con número de inventario: ${equipo.numero_inventario}.`,
equipoPrograma,
}));
} }
async delete(operador: Operador, id_equipo_programa: number) { async delete(operador: Operador, id_equipo_programa: number) {
const equipoPrograma = await this.findById(id_equipo_programa); const equipoPrograma = await this.findInfoEquipoProgramaById(
id_equipo_programa,
);
// No se puede eliminar "Sin programa" manualmente
if (equipoPrograma.programa.id_programa === 1)
throw new ConflictException('No se puede eliminar esta opción.');
// Valida que el equipo pertenezca a la institución del operador
if ( if (
operador.institucion.id_institucion != operador.institucion.id_institucion !=
equipoPrograma.equipo.carrito.modulo.institucion.id_institucion equipoPrograma.equipo.carrito.modulo.institucion.id_institucion
) )
throw new ForbiddenException( throw new ForbiddenException(
'No puedes eliminar el software de este equipo porque no pertenece a tu institución.', 'No puedes modificar la información este equipo porque no pertenece a tu institución.',
); );
// Ver 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) => {
if (n === 1) { if (n === 1) await this.createSinPrograma(equipoPrograma.equipo);
if (equipoPrograma.programa.id_programa === 1)
throw new ConflictException('No se puede eliminar esta opción.');
await this.create(equipoPrograma.equipo, 1);
}
return this.repository.remove(equipoPrograma); return this.repository.remove(equipoPrograma);
}) })
.then((_) => ({ .then((_) => ({
@ -112,49 +113,9 @@ export class EquipoProgramaService {
})); }));
} }
findById(id_equipo_programa: number) {
return this.repository
.findOne({
join: {
alias: 'ep',
innerJoinAndSelect: {
e: 'ep.equipo',
p: 'ep.programa',
c: 'e.carrito',
m: 'c.modulo',
i: 'm.institucion',
},
},
where: { id_equipo_programa },
})
.then((equipoPrograma) => {
if (!equipoPrograma)
throw new ConflictException('No existe este id equipo software.');
return equipoPrograma;
});
}
findEquipoProgramaByEquipoPrograma(
equipo: Equipo,
programa: Programa,
validarExistencia = true,
) {
return this.repository
.findOne({ where: { equipo, programa } })
.then((equipoPrograma) => {
if (validarExistencia && equipoPrograma)
throw new ConflictException(
'Este software ya fue asignado a este equipo.',
);
return equipoPrograma;
});
}
findFullInfoEquipoProgramaAllByIdEquipo(id_equipo: number) { findFullInfoEquipoProgramaAllByIdEquipo(id_equipo: number) {
return this.fullInformacionEquipoProgramaView return this.fullInformacionEquipoProgramaView
.find({ .find({ where: { id_equipo } })
where: { id_equipo },
})
.then((infoEquipoProgramas) => { .then((infoEquipoProgramas) => {
const equipoProgramas: EquipoPrograma[] = []; const equipoProgramas: EquipoPrograma[] = [];
@ -172,9 +133,36 @@ export class EquipoProgramaService {
}); });
} }
informacionEquipoPrograma(id_equipo: number, id_programa: number) { findInfoEquipoProgramaById(id_equipo_programa: number) {
return this.informacionEquipoProgramaView.findOne({ return this.informacionEquipoProgramaView
where: { id_equipo, id_programa }, .findOne({ where: { id_equipo_programa } })
.then((infoEquipoPrograma) =>
this.repository.create({
id_equipo_programa: infoEquipoPrograma.id_equipo_programa,
equipo: {
id_equipo: infoEquipoPrograma.id_equipo,
carrito: {
id_carrito: infoEquipoPrograma.id_carrito,
modulo: {
institucion: {
id_institucion: infoEquipoPrograma.id_institucion,
},
},
tipoCarrito: {
id_tipo_carrito: infoEquipoPrograma.id_tipo_carrito,
},
},
},
}),
);
}
findInfoEquipoProgramaByIdEquipoIdPrograma(
id_equipo: number,
id_programa: number,
) {
return this.repository.findOne({
where: { equipo: { id_equipo }, programa: { id_programa } },
}); });
} }
} }

View File

@ -82,7 +82,7 @@ export class EquipoService {
); );
return this.equipoProgramaService return this.equipoProgramaService
.create(equipoNuevo, 1) .createSinPrograma(equipoNuevo)
.then((_) => equipoNuevo); .then((_) => equipoNuevo);
} }

View File

@ -0,0 +1,28 @@
// import { DataSource, ViewEntity, ViewColumn } from 'typeorm';
// import { EquipoPrograma } from '../equipo-programa.entity';
// import { Programa } from '../../../institucion-programa/entity/programa.entity';
// @ViewEntity({
// expression: (dataSource: DataSource) =>
// dataSource
// .createQueryBuilder()
// .select('ep.id_equipo_programa', 'id_equipo_programa')
// .addSelect('ep.id_equipo', 'id_equipo')
// .addSelect('ep.id_programa', 'id_programa')
// .addSelect('p.programa', 'programa')
// .from(EquipoPrograma, 'ep')
// .innerJoin(Programa, 'p', 'p.id_programa = ep.id_programa'),
// })
// export class FullInformacionEquipoProgramaView {
// @ViewColumn()
// id_equipo_programa: number;
// @ViewColumn()
// id_equipo: number;
// @ViewColumn()
// id_programa: number;
// @ViewColumn()
// programa: string;
// }

View File

@ -0,0 +1,22 @@
import { DataSource, ViewEntity, ViewColumn } from 'typeorm';
import { InstitucionUsuario } from '../institucion-usuario.entity';
@ViewEntity({
expression: (dataSource: DataSource) =>
dataSource
.createQueryBuilder()
.select('ep.id_equipo_programa', 'id_equipo_programa')
.addSelect('ep.id_equipo', 'id_equipo')
.addSelect('ep.id_programa', 'id_programa')
.from(InstitucionUsuario, 'ep'),
})
export class InformacionEquipoProgramaView {
@ViewColumn()
id_equipo_programa: number;
@ViewColumn()
id_equipo: number;
@ViewColumn()
id_programa: number;
}

View File

@ -321,7 +321,7 @@ export class UploadFileService {
false, false,
); );
const existeEquipoPrograma = programa const existeEquipoPrograma = programa
? await this.equipoProgramaService.informacionEquipoPrograma( ? await this.equipoProgramaService.findInfoEquipoProgramaByIdEquipoIdPrograma(
equipo.id_equipo, equipo.id_equipo,
programa.id_programa, programa.id_programa,
) )
@ -345,7 +345,7 @@ export class UploadFileService {
continue; continue;
} }
await this.equipoProgramaService await this.equipoProgramaService
.createCargaMasiva(equipo, programa) .create(equipo, programa)
.then((res) => { .then((res) => {
equipo.programas.push(res.equipoPrograma); equipo.programas.push(res.equipoPrograma);
mensajes.push(res.message); mensajes.push(res.message);