equipo programa service final
This commit is contained in:
parent
2122ad3770
commit
584531b317
@ -58,7 +58,7 @@ export class AuthController {
|
||||
|
||||
@Get('validar-token')
|
||||
@UseGuards(AuthGuard('jwt'))
|
||||
@ApiOperation({ description: 'Valida que el un token sea válido.' })
|
||||
@ApiOperation({ description: 'Validamos que el un token sea válido.' })
|
||||
validarToken() {
|
||||
return { valido: true };
|
||||
}
|
||||
|
@ -46,7 +46,7 @@ export class CarreraProgramaService {
|
||||
throw new ForbiddenException(
|
||||
'Esta carrera no pertenece a tu institución.',
|
||||
);
|
||||
// Busco un registro con los datos mandados del client
|
||||
// Buscamos un registro con los datos mandados del client
|
||||
return this.repository
|
||||
.findOne({
|
||||
select: ['id_carrera_programa'],
|
||||
@ -58,7 +58,7 @@ export class CarreraProgramaService {
|
||||
throw new ConflictException(
|
||||
'Ya se asignó este programa a esta carrera.',
|
||||
);
|
||||
// Creo y guardo registro
|
||||
// Creamos y guardamos registro
|
||||
return this.repository.save(
|
||||
this.repository.create({ institucionCarrera, programa }),
|
||||
);
|
||||
|
@ -16,7 +16,7 @@ export class EquipoPrograma {
|
||||
@Column({ type: Number, nullable: true })
|
||||
id_equipo: number;
|
||||
|
||||
@Column({ type: Number, nullable: true })
|
||||
@Column({ type: Number, nullable: true, default: 1 })
|
||||
id_programa: number;
|
||||
|
||||
@ManyToOne(() => Equipo, (equipo) => equipo.programas)
|
||||
|
@ -30,18 +30,22 @@ export class EquipoProgramaService {
|
||||
private institucionProgramaService: InstitucionProgramaService,
|
||||
) {}
|
||||
|
||||
async asignar(operador: Operador, id_equipo: number, id_programa: number) {
|
||||
async asignar(
|
||||
operador: Operador,
|
||||
id_equipo: number,
|
||||
id_programa: number,
|
||||
): Promise<{ message: string }> {
|
||||
const equipo = await this.equipoService.findById(id_equipo);
|
||||
const programa = await this.institucionProgramaService.findProgramaById(
|
||||
id_programa,
|
||||
);
|
||||
|
||||
// valido que el programa seleccionado no sea "Sin programa"
|
||||
// Validamos que el programa seleccionado no sea "Sin programa"
|
||||
if (programa.id_programa === 1)
|
||||
throw new ConflictException(
|
||||
'No se puede asignar manualmente este programa.',
|
||||
'No se puede asignar manualmente sin programa.',
|
||||
);
|
||||
// Valida que el equipo pertenezca a la institución del operador
|
||||
// Validamos que el equipo pertenezca a la institución del operador
|
||||
if (
|
||||
operador.tipoUsuario.id_tipo_usuario > 2 &&
|
||||
operador.institucion.id_institucion !=
|
||||
@ -50,47 +54,47 @@ export class EquipoProgramaService {
|
||||
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.findByEquipoPrograma(equipo, programa).then(
|
||||
(existeEquipoPrograma) => {
|
||||
// Error si existe
|
||||
// Buscamos un registro con los datos mandados del client
|
||||
return this.findByEquipoPrograma(equipo, programa)
|
||||
.then((existeEquipoPrograma) => {
|
||||
// Si encuentro uno saco error
|
||||
if (existeEquipoPrograma)
|
||||
throw new ConflictException(
|
||||
'Este software ya fue asignado a este equipo.',
|
||||
);
|
||||
return this.create(equipo, programa);
|
||||
})
|
||||
.then((_) => ({
|
||||
message: 'Se asignó correctamente el software a este equipo.',
|
||||
}));
|
||||
}
|
||||
|
||||
create(equipo: Equipo, programa: Programa): Promise<EquipoPrograma> {
|
||||
// Verificamos si tiene programa "Sin programa"
|
||||
return this.findByEquipoPrograma(equipo, { id_programa: 1 }).then(
|
||||
async (existeEquipoSinPrograma) => {
|
||||
// Si lo tiene lo eliminamos
|
||||
if (existeEquipoSinPrograma)
|
||||
await this.repository.remove(existeEquipoSinPrograma);
|
||||
// Creamos y guardamos el registro
|
||||
return this.repository.save(
|
||||
this.repository.create({ equipo, programa }),
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
create(equipo: Equipo, programa: Programa) {
|
||||
// Ver si tiene programa "Sin programa"
|
||||
return this.findByEquipoPrograma(equipo, { id_programa: 1 })
|
||||
.then(async (existeEquipoSinPrograma) => {
|
||||
// Si tiene lo elimino
|
||||
if (existeEquipoSinPrograma)
|
||||
await this.repository.remove(existeEquipoSinPrograma);
|
||||
// Creo el registro
|
||||
return this.repository.save(
|
||||
this.repository.create({ equipo, programa }),
|
||||
);
|
||||
})
|
||||
.then((equipoPrograma) => ({
|
||||
message: `Se asignó el software: ${equipoPrograma.programa.programa}, al equipo con número de inventario: ${equipo.numero_inventario}.`,
|
||||
equipoPrograma,
|
||||
}));
|
||||
createSinPrograma(equipo: Equipo): Promise<EquipoPrograma> {
|
||||
return this.repository.save(this.repository.create({ equipo }));
|
||||
}
|
||||
|
||||
createSinPrograma(equipo: Equipo) {
|
||||
return this.repository.save(
|
||||
this.repository.create({ equipo, programa: { id_programa: 1 } }),
|
||||
);
|
||||
}
|
||||
|
||||
async delete(operador: Operador, id_equipo_programa: number) {
|
||||
async delete(
|
||||
operador: Operador,
|
||||
id_equipo_programa: number,
|
||||
): Promise<{ message: string }> {
|
||||
const equipoPrograma = await this.findById(id_equipo_programa);
|
||||
|
||||
// Valida que el equipo pertenezca a la institución del operador
|
||||
// Validamos que el equipo pertenezca a la institución del operador
|
||||
if (
|
||||
operador.institucion.id_institucion !=
|
||||
equipoPrograma.equipo.carrito.modulo.institucion.id_institucion
|
||||
@ -100,14 +104,16 @@ export class EquipoProgramaService {
|
||||
);
|
||||
// No se puede eliminar "Sin programa" manualmente
|
||||
if (equipoPrograma.programa.id_programa === 1)
|
||||
throw new ConflictException('No se puede eliminar esta opción.');
|
||||
// Ver cuantos programas tiene el equipo
|
||||
throw new ConflictException(
|
||||
'No se puede eliminar manualmente sin programa.',
|
||||
);
|
||||
// Buscamos cuantos programas tiene el equipo
|
||||
return this.repository
|
||||
.count({ where: { equipo: equipoPrograma.equipo } })
|
||||
.then(async (n) => {
|
||||
// Asignar "Sin programa" si es que solo tiene 1, el que se va a eliminar
|
||||
if (n === 1) await this.createSinPrograma(equipoPrograma.equipo);
|
||||
// Eliminar registro
|
||||
// Eliminamos registro
|
||||
return this.repository.remove(equipoPrograma);
|
||||
})
|
||||
.then((_) => ({
|
||||
@ -115,7 +121,7 @@ export class EquipoProgramaService {
|
||||
}));
|
||||
}
|
||||
|
||||
findFullInfoAllByIdEquipo(id_equipo: number) {
|
||||
findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoPrograma[]> {
|
||||
return this.fullInformacionEquipoProgramaView
|
||||
.find({ where: { id_equipo } })
|
||||
.then((infoEquipoProgramas) => {
|
||||
@ -135,7 +141,7 @@ export class EquipoProgramaService {
|
||||
});
|
||||
}
|
||||
|
||||
findById(id_equipo_programa: number) {
|
||||
findById(id_equipo_programa: number): Promise<EquipoPrograma> {
|
||||
return this.informacionEquipoProgramaView
|
||||
.findOne({ where: { id_equipo_programa } })
|
||||
.then((infoEquipoPrograma) => {
|
||||
@ -163,7 +169,10 @@ export class EquipoProgramaService {
|
||||
});
|
||||
}
|
||||
|
||||
findByEquipoPrograma(equipo: Equipo, programa: Programa | Partial<Programa>) {
|
||||
findByEquipoPrograma(
|
||||
equipo: Equipo,
|
||||
programa: Programa | Partial<Programa>,
|
||||
): Promise<EquipoPrograma> {
|
||||
return this.repository.findOne({ where: { equipo, programa } });
|
||||
}
|
||||
}
|
||||
|
@ -37,7 +37,7 @@ export class EquipoTipoEntradaService {
|
||||
id_tipo_entrada,
|
||||
);
|
||||
|
||||
// Verifica que no eixsta un registro con estos ids
|
||||
// Validamos que no eixsta un registro con estos ids
|
||||
return this.findByEquipoTipoEntrada(equipo, tipoEntrada).then(
|
||||
(existeEquipoTipoEntrada) => {
|
||||
// Error si existe saco error
|
||||
@ -63,7 +63,7 @@ export class EquipoTipoEntradaService {
|
||||
delete(operador: Operador, id_equipo_tipo_entrada: number) {
|
||||
return this.findById(id_equipo_tipo_entrada)
|
||||
.then((equipoTipoEntrada) => {
|
||||
// Valida que el equipo pertenezca a la institución del operador
|
||||
// Validamos que el equipo pertenezca a la institución del operador
|
||||
if (
|
||||
operador.institucion.id_institucion !=
|
||||
equipoTipoEntrada.equipo.carrito.modulo.institucion.id_institucion
|
||||
|
@ -51,7 +51,7 @@ export class InformacionEquipoView {
|
||||
numero_inventario: string;
|
||||
|
||||
@ViewColumn()
|
||||
prestado: boolean;
|
||||
prestado: number;
|
||||
|
||||
@ViewColumn()
|
||||
u: number;
|
||||
|
@ -212,10 +212,15 @@ export class EquipoService {
|
||||
}
|
||||
|
||||
findAllResetear(): Promise<Equipo[]> {
|
||||
return this.repository.find({
|
||||
select: ['id_equipo'],
|
||||
where: { prestado: true, status: { id_status: Not(3) } },
|
||||
});
|
||||
return this.informacionEquipoView
|
||||
.find({ where: { prestado: 1, id_status: Not(3) } })
|
||||
.then((infoEquipos) => {
|
||||
const equipos: Equipo[] = [];
|
||||
|
||||
for (let i = 0; i < infoEquipos.length; i++)
|
||||
equipos.push(this.viewToEquipo(infoEquipos[i]));
|
||||
return equipos;
|
||||
});
|
||||
}
|
||||
|
||||
findByEquipo(
|
||||
@ -537,7 +542,7 @@ export class EquipoService {
|
||||
id_equipo: infoEquipo.id_equipo,
|
||||
equipo: infoEquipo.equipo,
|
||||
numero_inventario: infoEquipo.numero_inventario,
|
||||
prestado: infoEquipo.prestado,
|
||||
prestado: infoEquipo.prestado === 1,
|
||||
u: infoEquipo.u,
|
||||
carrito: {
|
||||
id_carrito: infoEquipo.id_carrito,
|
||||
|
@ -43,7 +43,7 @@ export class HoraExcepcionService {
|
||||
throw new BadRequestException(
|
||||
'La hora inicio no puede ser mayor que la hora fin.',
|
||||
);
|
||||
// Busco un horario servicio que pertenezca al mismo día y que sus horas inicio
|
||||
// Buscamos un horario servicio que pertenezca al mismo día y que sus horas inicio
|
||||
// y fin encierren, en tiempo, a alguna de las horas mandadas del front
|
||||
return this.repository
|
||||
.findOne({
|
||||
|
@ -60,7 +60,7 @@ export class InstitucionDiaService {
|
||||
// Validamos que no sea domingo
|
||||
if (ahora.weekday() === 0)
|
||||
throw new ConflictException('No hay servicio los días domingo.');
|
||||
// Busco un institucionDia apartir de la institución enviada y del día de hoy
|
||||
// Buscamos un institucionDia apartir de la institución enviada y del día de hoy
|
||||
return this.institucionService
|
||||
.findById(id_institucion)
|
||||
.then((institucion) =>
|
||||
|
@ -22,14 +22,14 @@ export class InstitucionInfraccionService {
|
||||
) {}
|
||||
|
||||
create(infraccion: string) {
|
||||
// Busco una infracción con ese nombre
|
||||
// Buscamos una infracción con ese nombre
|
||||
return this.infraccionRepository
|
||||
.findOne({ where: { infraccion } })
|
||||
.then((existeInfraccion) => {
|
||||
// Saco error si existe
|
||||
if (existeInfraccion)
|
||||
throw new ConflictException('Ya existe esta infracción.');
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
return this.infraccionRepository.save(
|
||||
this.infraccionRepository.create({ infraccion }),
|
||||
);
|
||||
|
@ -21,14 +21,14 @@ export class InstitucionProgramaService {
|
||||
) {}
|
||||
|
||||
create(programa: string) {
|
||||
// Busco un programa con ese nombre
|
||||
// Buscamos un programa con ese nombre
|
||||
return this.programaRepository
|
||||
.findOne({ where: { programa } })
|
||||
.then((existePrograma) => {
|
||||
// Saco error si existe
|
||||
if (existePrograma)
|
||||
throw new ConflictException('Ya existe este programa.');
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
return this.programaRepository.save(
|
||||
this.programaRepository.create({ programa }),
|
||||
);
|
||||
|
@ -21,7 +21,7 @@ export class InstitucionTipoCarritoService {
|
||||
) {}
|
||||
|
||||
create(letra: string, tipo_carrito: string) {
|
||||
// Busco un tipo de carrito con ese nombre o letra
|
||||
// Buscamos un tipo de carrito con ese nombre o letra
|
||||
return this.tipoCarritoRepository
|
||||
.findOne({ where: [{ letra }, { tipo_carrito }] })
|
||||
.then((existeTipoCarrito) => {
|
||||
@ -36,7 +36,7 @@ export class InstitucionTipoCarritoService {
|
||||
'Ya existe un tipo carrito con este nombre, intente con otro nombre.',
|
||||
);
|
||||
}
|
||||
// Creo y guardo el registros
|
||||
// Creamos y guardamos el registros
|
||||
return this.tipoCarritoRepository.save(
|
||||
this.tipoCarritoRepository.create({ letra, tipo_carrito }),
|
||||
);
|
||||
|
@ -21,14 +21,14 @@ export class InstitucionTipoEntradaService {
|
||||
) {}
|
||||
|
||||
async create(tipo_entrada: string) {
|
||||
// Busco un tipo de entrada con ese nombre
|
||||
// Buscamos un tipo de entrada con ese nombre
|
||||
return this.tipoEntradaRepository
|
||||
.findOne({ where: { tipo_entrada } })
|
||||
.then((existeTipoEntrada) => {
|
||||
// Saco error si existe
|
||||
if (existeTipoEntrada)
|
||||
throw new ConflictException('Ya existe este tipo de entrada.');
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
return this.tipoEntradaRepository.save(
|
||||
this.tipoEntradaRepository.create({ tipo_entrada }),
|
||||
);
|
||||
|
@ -21,7 +21,7 @@ export class InstitucionUsuarioService {
|
||||
) {}
|
||||
|
||||
create(institucionCarrera: InstitucionCarrera, usuario: Usuario) {
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
return this.repository
|
||||
.save(this.repository.create({ institucionCarrera, usuario }))
|
||||
.then((institucionUsuario) => ({
|
||||
@ -31,7 +31,7 @@ export class InstitucionUsuarioService {
|
||||
}
|
||||
|
||||
desactivarCuentas(admin: Operador) {
|
||||
// Busco todas los registros que le pertenecen a la institutción del operador
|
||||
// Buscamos todas los registros que le pertenecen a la institutción del operador
|
||||
// que esta realizando esta acción
|
||||
return this.informacionInstitucionUsuarioView
|
||||
.find({
|
||||
|
@ -8,12 +8,12 @@ export class MarcaService {
|
||||
constructor(@InjectRepository(Marca) private repository: Repository<Marca>) {}
|
||||
|
||||
create(marca: string, tipo: string) {
|
||||
// Busco una marca con ese nombre
|
||||
// Buscamos una marca con ese nombre
|
||||
return this.findByMarca(marca, tipo, false)
|
||||
.then((existeMarca) => {
|
||||
// Saco error si existe
|
||||
if (existeMarca) throw new ConflictException('Ya existe esta marca.');
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
return this.repository.save(this.repository.create({ marca, tipo }));
|
||||
})
|
||||
.then((_) => ({ message: 'Se creó correctamente una nueva marca.' }));
|
||||
|
@ -10,12 +10,12 @@ export class ModeloService {
|
||||
) {}
|
||||
|
||||
create(modelo: string, tipo: string) {
|
||||
// Busco un modelo con ese nombre
|
||||
// Buscamos un modelo con ese nombre
|
||||
return this.findByModelo(modelo, tipo, false)
|
||||
.then((existeModelo) => {
|
||||
// Saco error si existe
|
||||
if (existeModelo) throw new ConflictException('Ya existe este modelo.');
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
return this.repository.save(this.repository.create({ modelo, tipo }));
|
||||
})
|
||||
.then((_) => ({ message: 'Se creó correctamente un nuevo modelo.' }));
|
||||
|
@ -29,11 +29,11 @@ export class ModuloService {
|
||||
) {}
|
||||
|
||||
create(admin: Operador, modulo: string) {
|
||||
// Busco una modulo con ese nombre en la institución del admin
|
||||
// Buscamos una modulo con ese nombre en la institución del admin
|
||||
// que realiza esta acción
|
||||
return this.findModulo(admin.institucion, modulo, true)
|
||||
.then((_) =>
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
this.repository.save(
|
||||
this.repository.create({
|
||||
institucion: admin.institucion,
|
||||
@ -151,7 +151,7 @@ export class ModuloService {
|
||||
throw new ConflictException(
|
||||
'No puedes actualizar la información de este módulo porque no le pertenece a tu institución.',
|
||||
);
|
||||
// Busco un modulo en esa institución con ese nombre
|
||||
// Buscamos un modulo en esa institución con ese nombre
|
||||
if (attrs.modulo)
|
||||
await this.findModulo(modulo.institucion, attrs.modulo, true);
|
||||
// Asigno valores enviados al objeto
|
||||
|
@ -116,10 +116,10 @@ export class MultaService {
|
||||
);
|
||||
this.validacionMultaCancelacion(prestamo);
|
||||
fecha_fin.add(institucionInfraccion.dias_multa, 'd');
|
||||
// Busco una multa con este préstamo
|
||||
// Buscamos una multa con este préstamo
|
||||
return this.findByPrestamo(prestamo)
|
||||
.then((_) =>
|
||||
// Creo y guardo registro
|
||||
// Creamos y guardamos registro
|
||||
this.repository.save(
|
||||
this.repository.create({
|
||||
descripcion,
|
||||
|
@ -204,12 +204,12 @@ export class PrestamoService {
|
||||
`Se suspendió el servicio de préstamo temporalmente de ${institucionDia.horasExcepcion[i].hora_inicio} a ${institucionDia.horasExcepcion[i].hora_fin}.`,
|
||||
);
|
||||
}
|
||||
// Busco instituciones activas y sin multa de este usuario
|
||||
// Buscamos instituciones activas y sin multa de este usuario
|
||||
return this.institucionUsuarioService
|
||||
.findFullInfoAllByUsuario(usuario, false)
|
||||
.then((instituciones) => {
|
||||
this.validarInstitucionUsuario(instituciones, modulo);
|
||||
// Busco un prestamo activo con el id del usuario que realiza la acción
|
||||
// Buscamos un prestamo activo con el id del usuario que realiza la acción
|
||||
return this.informacionPrestamoView.findOne({
|
||||
where: { activo: 1, id_usuario: usuario.id_usuario },
|
||||
});
|
||||
@ -220,7 +220,7 @@ export class PrestamoService {
|
||||
throw new ConflictException(
|
||||
'Este usuario ya tiene un préstamo activo.',
|
||||
);
|
||||
// Busco un equipo con las caracteríasticas solicitadas
|
||||
// Buscamos un equipo con las caracteríasticas solicitadas
|
||||
return this.equipoService.findEquipo(
|
||||
usuario,
|
||||
modulo,
|
||||
@ -879,7 +879,7 @@ export class PrestamoService {
|
||||
descripcion?: string,
|
||||
id_institucion_infraccion?: number,
|
||||
) {
|
||||
// Busco el prestamo por id prestamo y luego regreso el equipo
|
||||
// Buscamos el prestamo por id prestamo y luego regreso el equipo
|
||||
return this.findById(id_prestamo).then((prestamo) =>
|
||||
this.regresar(
|
||||
operador,
|
||||
@ -902,7 +902,7 @@ export class PrestamoService {
|
||||
descripcion?: string,
|
||||
id_institucion_infraccion?: number,
|
||||
) {
|
||||
// Busco el prestamo por número de inventario y la institución del operador
|
||||
// Buscamos el prestamo por número de inventario y la institución del operador
|
||||
// luego regreso el equipo
|
||||
return this.findByNumeroInventario(
|
||||
operador.institucion,
|
||||
|
@ -14,14 +14,14 @@ export class TipoUsuarioService {
|
||||
) {}
|
||||
|
||||
create(tipo_usuario: string) {
|
||||
// Busco un tipo de usuario con ese nombre
|
||||
// Buscamos un tipo de usuario con ese nombre
|
||||
return this.repository
|
||||
.findOne({ where: { tipo_usuario } })
|
||||
.then((existeTipoUsuario) => {
|
||||
// Saco error si existe
|
||||
if (existeTipoUsuario)
|
||||
throw new ConflictException('Ya existe este tipo usuario');
|
||||
// Creo y guardo el registro
|
||||
// Creamos y guardamos el registro
|
||||
return this.repository.save(this.repository.create({ tipo_usuario }));
|
||||
})
|
||||
.then((_) => ({
|
||||
|
@ -338,10 +338,7 @@ export class UploadFileService {
|
||||
}
|
||||
await this.equipoProgramaService
|
||||
.create(equipo, programa)
|
||||
.then((res) => {
|
||||
equipo.programas.push(res.equipoPrograma);
|
||||
mensajes.push(res.message);
|
||||
});
|
||||
.then((equipoPrograma) => equipo.programas.push(equipoPrograma));
|
||||
}
|
||||
equiposNuevos.push(equipo);
|
||||
});
|
||||
|
@ -219,7 +219,7 @@ export class UsuarioService {
|
||||
const password = this.bcryptService.generarPassword();
|
||||
let message: string;
|
||||
|
||||
// Busco usuario
|
||||
// Buscamos usuario
|
||||
return this.findByUsuario(usuario, rfc)
|
||||
.then(async (existeUsuario) => {
|
||||
// Ai no existe o tiene contraseña, es decir que esta registrado, saca error
|
||||
|
Loading…
Reference in New Issue
Block a user