equipo programa service final

This commit is contained in:
lemuel 2022-12-20 07:18:37 -06:00
parent 2122ad3770
commit 584531b317
22 changed files with 94 additions and 83 deletions

View File

@ -58,7 +58,7 @@ export class AuthController {
@Get('validar-token') @Get('validar-token')
@UseGuards(AuthGuard('jwt')) @UseGuards(AuthGuard('jwt'))
@ApiOperation({ description: 'Valida que el un token sea válido.' }) @ApiOperation({ description: 'Validamos que el un token sea válido.' })
validarToken() { validarToken() {
return { valido: true }; return { valido: true };
} }

View File

@ -46,7 +46,7 @@ export class CarreraProgramaService {
throw new ForbiddenException( throw new ForbiddenException(
'Esta carrera no pertenece a tu institución.', '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 return this.repository
.findOne({ .findOne({
select: ['id_carrera_programa'], select: ['id_carrera_programa'],
@ -58,7 +58,7 @@ export class CarreraProgramaService {
throw new ConflictException( throw new ConflictException(
'Ya se asignó este programa a esta carrera.', 'Ya se asignó este programa a esta carrera.',
); );
// Creo y guardo registro // Creamos y guardamos registro
return this.repository.save( return this.repository.save(
this.repository.create({ institucionCarrera, programa }), this.repository.create({ institucionCarrera, programa }),
); );

View File

@ -16,7 +16,7 @@ export class EquipoPrograma {
@Column({ type: Number, nullable: true }) @Column({ type: Number, nullable: true })
id_equipo: number; id_equipo: number;
@Column({ type: Number, nullable: true }) @Column({ type: Number, nullable: true, default: 1 })
id_programa: number; id_programa: number;
@ManyToOne(() => Equipo, (equipo) => equipo.programas) @ManyToOne(() => Equipo, (equipo) => equipo.programas)

View File

@ -30,18 +30,22 @@ export class EquipoProgramaService {
private institucionProgramaService: InstitucionProgramaService, 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 equipo = await this.equipoService.findById(id_equipo);
const programa = await this.institucionProgramaService.findProgramaById( const programa = await this.institucionProgramaService.findProgramaById(
id_programa, 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) if (programa.id_programa === 1)
throw new ConflictException( 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 ( if (
operador.tipoUsuario.id_tipo_usuario > 2 && operador.tipoUsuario.id_tipo_usuario > 2 &&
operador.institucion.id_institucion != operador.institucion.id_institucion !=
@ -50,47 +54,47 @@ export class EquipoProgramaService {
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.',
); );
// Verifica que no eixsta un registro con estos ids // Buscamos un registro con los datos mandados del client
return this.findByEquipoPrograma(equipo, programa).then( return this.findByEquipoPrograma(equipo, programa)
(existeEquipoPrograma) => { .then((existeEquipoPrograma) => {
// Error si existe // Si encuentro uno saco 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.',
); );
return this.create(equipo, programa); 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) { createSinPrograma(equipo: Equipo): Promise<EquipoPrograma> {
// Ver si tiene programa "Sin programa" return this.repository.save(this.repository.create({ equipo }));
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) { async delete(
return this.repository.save( operador: Operador,
this.repository.create({ equipo, programa: { id_programa: 1 } }), id_equipo_programa: number,
); ): Promise<{ message: string }> {
}
async delete(operador: Operador, id_equipo_programa: number) {
const equipoPrograma = await this.findById(id_equipo_programa); 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 ( if (
operador.institucion.id_institucion != operador.institucion.id_institucion !=
equipoPrograma.equipo.carrito.modulo.institucion.id_institucion equipoPrograma.equipo.carrito.modulo.institucion.id_institucion
@ -100,14 +104,16 @@ 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('No se puede eliminar esta opción.'); throw new ConflictException(
// Ver cuantos programas tiene el equipo 'No se puede eliminar manualmente sin programa.',
);
// 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 programa" 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);
// Eliminar registro // Eliminamos registro
return this.repository.remove(equipoPrograma); return this.repository.remove(equipoPrograma);
}) })
.then((_) => ({ .then((_) => ({
@ -115,7 +121,7 @@ export class EquipoProgramaService {
})); }));
} }
findFullInfoAllByIdEquipo(id_equipo: number) { findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoPrograma[]> {
return this.fullInformacionEquipoProgramaView return this.fullInformacionEquipoProgramaView
.find({ where: { id_equipo } }) .find({ where: { id_equipo } })
.then((infoEquipoProgramas) => { .then((infoEquipoProgramas) => {
@ -135,7 +141,7 @@ export class EquipoProgramaService {
}); });
} }
findById(id_equipo_programa: number) { findById(id_equipo_programa: number): Promise<EquipoPrograma> {
return this.informacionEquipoProgramaView return this.informacionEquipoProgramaView
.findOne({ where: { id_equipo_programa } }) .findOne({ where: { id_equipo_programa } })
.then((infoEquipoPrograma) => { .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 } }); return this.repository.findOne({ where: { equipo, programa } });
} }
} }

View File

@ -37,7 +37,7 @@ export class EquipoTipoEntradaService {
id_tipo_entrada, 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( return this.findByEquipoTipoEntrada(equipo, tipoEntrada).then(
(existeEquipoTipoEntrada) => { (existeEquipoTipoEntrada) => {
// Error si existe saco error // Error si existe saco error
@ -63,7 +63,7 @@ export class EquipoTipoEntradaService {
delete(operador: Operador, id_equipo_tipo_entrada: number) { delete(operador: Operador, id_equipo_tipo_entrada: number) {
return this.findById(id_equipo_tipo_entrada) return this.findById(id_equipo_tipo_entrada)
.then((equipoTipoEntrada) => { .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 ( if (
operador.institucion.id_institucion != operador.institucion.id_institucion !=
equipoTipoEntrada.equipo.carrito.modulo.institucion.id_institucion equipoTipoEntrada.equipo.carrito.modulo.institucion.id_institucion

View File

@ -51,7 +51,7 @@ export class InformacionEquipoView {
numero_inventario: string; numero_inventario: string;
@ViewColumn() @ViewColumn()
prestado: boolean; prestado: number;
@ViewColumn() @ViewColumn()
u: number; u: number;

View File

@ -212,9 +212,14 @@ export class EquipoService {
} }
findAllResetear(): Promise<Equipo[]> { findAllResetear(): Promise<Equipo[]> {
return this.repository.find({ return this.informacionEquipoView
select: ['id_equipo'], .find({ where: { prestado: 1, id_status: Not(3) } })
where: { prestado: true, status: { 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;
}); });
} }
@ -537,7 +542,7 @@ export class EquipoService {
id_equipo: infoEquipo.id_equipo, id_equipo: infoEquipo.id_equipo,
equipo: infoEquipo.equipo, equipo: infoEquipo.equipo,
numero_inventario: infoEquipo.numero_inventario, numero_inventario: infoEquipo.numero_inventario,
prestado: infoEquipo.prestado, prestado: infoEquipo.prestado === 1,
u: infoEquipo.u, u: infoEquipo.u,
carrito: { carrito: {
id_carrito: infoEquipo.id_carrito, id_carrito: infoEquipo.id_carrito,

View File

@ -43,7 +43,7 @@ export class HoraExcepcionService {
throw new BadRequestException( throw new BadRequestException(
'La hora inicio no puede ser mayor que la hora fin.', '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 // y fin encierren, en tiempo, a alguna de las horas mandadas del front
return this.repository return this.repository
.findOne({ .findOne({

View File

@ -60,7 +60,7 @@ export class InstitucionDiaService {
// Validamos que no sea domingo // Validamos que no sea domingo
if (ahora.weekday() === 0) if (ahora.weekday() === 0)
throw new ConflictException('No hay servicio los días domingo.'); 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 return this.institucionService
.findById(id_institucion) .findById(id_institucion)
.then((institucion) => .then((institucion) =>

View File

@ -22,14 +22,14 @@ export class InstitucionInfraccionService {
) {} ) {}
create(infraccion: string) { create(infraccion: string) {
// Busco una infracción con ese nombre // Buscamos una infracción con ese nombre
return this.infraccionRepository return this.infraccionRepository
.findOne({ where: { infraccion } }) .findOne({ where: { infraccion } })
.then((existeInfraccion) => { .then((existeInfraccion) => {
// Saco error si existe // Saco error si existe
if (existeInfraccion) if (existeInfraccion)
throw new ConflictException('Ya existe esta infracción.'); throw new ConflictException('Ya existe esta infracción.');
// Creo y guardo el registro // Creamos y guardamos el registro
return this.infraccionRepository.save( return this.infraccionRepository.save(
this.infraccionRepository.create({ infraccion }), this.infraccionRepository.create({ infraccion }),
); );

View File

@ -21,14 +21,14 @@ export class InstitucionProgramaService {
) {} ) {}
create(programa: string) { create(programa: string) {
// Busco un programa con ese nombre // Buscamos un programa con ese nombre
return this.programaRepository return this.programaRepository
.findOne({ where: { programa } }) .findOne({ where: { programa } })
.then((existePrograma) => { .then((existePrograma) => {
// Saco error si existe // Saco error si existe
if (existePrograma) if (existePrograma)
throw new ConflictException('Ya existe este programa.'); throw new ConflictException('Ya existe este programa.');
// Creo y guardo el registro // Creamos y guardamos el registro
return this.programaRepository.save( return this.programaRepository.save(
this.programaRepository.create({ programa }), this.programaRepository.create({ programa }),
); );

View File

@ -21,7 +21,7 @@ export class InstitucionTipoCarritoService {
) {} ) {}
create(letra: string, tipo_carrito: string) { 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 return this.tipoCarritoRepository
.findOne({ where: [{ letra }, { tipo_carrito }] }) .findOne({ where: [{ letra }, { tipo_carrito }] })
.then((existeTipoCarrito) => { .then((existeTipoCarrito) => {
@ -36,7 +36,7 @@ export class InstitucionTipoCarritoService {
'Ya existe un tipo carrito con este nombre, intente con otro nombre.', '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( return this.tipoCarritoRepository.save(
this.tipoCarritoRepository.create({ letra, tipo_carrito }), this.tipoCarritoRepository.create({ letra, tipo_carrito }),
); );

View File

@ -21,14 +21,14 @@ export class InstitucionTipoEntradaService {
) {} ) {}
async create(tipo_entrada: string) { async create(tipo_entrada: string) {
// Busco un tipo de entrada con ese nombre // Buscamos un tipo de entrada con ese nombre
return this.tipoEntradaRepository return this.tipoEntradaRepository
.findOne({ where: { tipo_entrada } }) .findOne({ where: { tipo_entrada } })
.then((existeTipoEntrada) => { .then((existeTipoEntrada) => {
// Saco error si existe // Saco error si existe
if (existeTipoEntrada) if (existeTipoEntrada)
throw new ConflictException('Ya existe este tipo de entrada.'); throw new ConflictException('Ya existe este tipo de entrada.');
// Creo y guardo el registro // Creamos y guardamos el registro
return this.tipoEntradaRepository.save( return this.tipoEntradaRepository.save(
this.tipoEntradaRepository.create({ tipo_entrada }), this.tipoEntradaRepository.create({ tipo_entrada }),
); );

View File

@ -21,7 +21,7 @@ export class InstitucionUsuarioService {
) {} ) {}
create(institucionCarrera: InstitucionCarrera, usuario: Usuario) { create(institucionCarrera: InstitucionCarrera, usuario: Usuario) {
// Creo y guardo el registro // Creamos y guardamos el registro
return this.repository return this.repository
.save(this.repository.create({ institucionCarrera, usuario })) .save(this.repository.create({ institucionCarrera, usuario }))
.then((institucionUsuario) => ({ .then((institucionUsuario) => ({
@ -31,7 +31,7 @@ export class InstitucionUsuarioService {
} }
desactivarCuentas(admin: Operador) { 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 // que esta realizando esta acción
return this.informacionInstitucionUsuarioView return this.informacionInstitucionUsuarioView
.find({ .find({

View File

@ -8,12 +8,12 @@ export class MarcaService {
constructor(@InjectRepository(Marca) private repository: Repository<Marca>) {} constructor(@InjectRepository(Marca) private repository: Repository<Marca>) {}
create(marca: string, tipo: string) { create(marca: string, tipo: string) {
// Busco una marca con ese nombre // Buscamos una marca con ese nombre
return this.findByMarca(marca, tipo, false) return this.findByMarca(marca, tipo, false)
.then((existeMarca) => { .then((existeMarca) => {
// Saco error si existe // Saco error si existe
if (existeMarca) throw new ConflictException('Ya existe esta marca.'); 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 })); return this.repository.save(this.repository.create({ marca, tipo }));
}) })
.then((_) => ({ message: 'Se creó correctamente una nueva marca.' })); .then((_) => ({ message: 'Se creó correctamente una nueva marca.' }));

View File

@ -10,12 +10,12 @@ export class ModeloService {
) {} ) {}
create(modelo: string, tipo: string) { create(modelo: string, tipo: string) {
// Busco un modelo con ese nombre // Buscamos un modelo con ese nombre
return this.findByModelo(modelo, tipo, false) return this.findByModelo(modelo, tipo, false)
.then((existeModelo) => { .then((existeModelo) => {
// Saco error si existe // Saco error si existe
if (existeModelo) throw new ConflictException('Ya existe este modelo.'); 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 })); return this.repository.save(this.repository.create({ modelo, tipo }));
}) })
.then((_) => ({ message: 'Se creó correctamente un nuevo modelo.' })); .then((_) => ({ message: 'Se creó correctamente un nuevo modelo.' }));

View File

@ -29,11 +29,11 @@ export class ModuloService {
) {} ) {}
create(admin: Operador, modulo: string) { 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 // que realiza esta acción
return this.findModulo(admin.institucion, modulo, true) return this.findModulo(admin.institucion, modulo, true)
.then((_) => .then((_) =>
// Creo y guardo el registro // Creamos y guardamos el registro
this.repository.save( this.repository.save(
this.repository.create({ this.repository.create({
institucion: admin.institucion, institucion: admin.institucion,
@ -151,7 +151,7 @@ export class ModuloService {
throw new ConflictException( throw new ConflictException(
'No puedes actualizar la información de este módulo porque no le pertenece a tu institución.', '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) if (attrs.modulo)
await this.findModulo(modulo.institucion, attrs.modulo, true); await this.findModulo(modulo.institucion, attrs.modulo, true);
// Asigno valores enviados al objeto // Asigno valores enviados al objeto

View File

@ -116,10 +116,10 @@ export class MultaService {
); );
this.validacionMultaCancelacion(prestamo); this.validacionMultaCancelacion(prestamo);
fecha_fin.add(institucionInfraccion.dias_multa, 'd'); 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) return this.findByPrestamo(prestamo)
.then((_) => .then((_) =>
// Creo y guardo registro // Creamos y guardamos registro
this.repository.save( this.repository.save(
this.repository.create({ this.repository.create({
descripcion, descripcion,

View File

@ -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}.`, `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 return this.institucionUsuarioService
.findFullInfoAllByUsuario(usuario, false) .findFullInfoAllByUsuario(usuario, false)
.then((instituciones) => { .then((instituciones) => {
this.validarInstitucionUsuario(instituciones, modulo); 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({ return this.informacionPrestamoView.findOne({
where: { activo: 1, id_usuario: usuario.id_usuario }, where: { activo: 1, id_usuario: usuario.id_usuario },
}); });
@ -220,7 +220,7 @@ export class PrestamoService {
throw new ConflictException( throw new ConflictException(
'Este usuario ya tiene un préstamo activo.', '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( return this.equipoService.findEquipo(
usuario, usuario,
modulo, modulo,
@ -879,7 +879,7 @@ export class PrestamoService {
descripcion?: string, descripcion?: string,
id_institucion_infraccion?: number, 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) => return this.findById(id_prestamo).then((prestamo) =>
this.regresar( this.regresar(
operador, operador,
@ -902,7 +902,7 @@ export class PrestamoService {
descripcion?: string, descripcion?: string,
id_institucion_infraccion?: number, 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 // luego regreso el equipo
return this.findByNumeroInventario( return this.findByNumeroInventario(
operador.institucion, operador.institucion,

View File

@ -14,14 +14,14 @@ export class TipoUsuarioService {
) {} ) {}
create(tipo_usuario: string) { create(tipo_usuario: string) {
// Busco un tipo de usuario con ese nombre // Buscamos un tipo de usuario con ese nombre
return this.repository return this.repository
.findOne({ where: { tipo_usuario } }) .findOne({ where: { tipo_usuario } })
.then((existeTipoUsuario) => { .then((existeTipoUsuario) => {
// Saco error si existe // Saco error si existe
if (existeTipoUsuario) if (existeTipoUsuario)
throw new ConflictException('Ya existe este tipo usuario'); 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 })); return this.repository.save(this.repository.create({ tipo_usuario }));
}) })
.then((_) => ({ .then((_) => ({

View File

@ -338,10 +338,7 @@ export class UploadFileService {
} }
await this.equipoProgramaService await this.equipoProgramaService
.create(equipo, programa) .create(equipo, programa)
.then((res) => { .then((equipoPrograma) => equipo.programas.push(equipoPrograma));
equipo.programas.push(res.equipoPrograma);
mensajes.push(res.message);
});
} }
equiposNuevos.push(equipo); equiposNuevos.push(equipo);
}); });

View File

@ -219,7 +219,7 @@ export class UsuarioService {
const password = this.bcryptService.generarPassword(); const password = this.bcryptService.generarPassword();
let message: string; let message: string;
// Busco usuario // Buscamos usuario
return this.findByUsuario(usuario, rfc) return this.findByUsuario(usuario, rfc)
.then(async (existeUsuario) => { .then(async (existeUsuario) => {
// Ai no existe o tiene contraseña, es decir que esta registrado, saca error // Ai no existe o tiene contraseña, es decir que esta registrado, saca error