2022-04-22 02:52:40 +00:00
|
|
|
import {
|
2022-08-31 16:29:48 +00:00
|
|
|
BadRequestException,
|
2022-04-22 02:52:40 +00:00
|
|
|
Injectable,
|
|
|
|
UnauthorizedException,
|
|
|
|
} from '@nestjs/common';
|
2022-04-21 21:31:26 +00:00
|
|
|
import { JwtService } from '@nestjs/jwt';
|
2022-10-16 04:51:56 +00:00
|
|
|
import { Operador } from '../operador/entity/operador.entity';
|
2022-10-17 16:49:59 +00:00
|
|
|
import { Usuario } from '../usuario/entity/usuario.entity';
|
2022-04-22 01:33:05 +00:00
|
|
|
import { BcryptService } from '../bcrypt/bcrypt.service';
|
2022-04-22 02:52:40 +00:00
|
|
|
import { ModuloService } from '../modulo/modulo.service';
|
2022-04-22 01:33:05 +00:00
|
|
|
import { OperadorService } from '../operador/operador.service';
|
|
|
|
import { UsuarioService } from '../usuario/usuario.service';
|
2022-10-16 04:51:56 +00:00
|
|
|
import { JwtPayloadAdmin } from './dto/jwt-payload-admin';
|
|
|
|
import { JwtPayloadOperador } from './dto/jwt-payload-operador';
|
|
|
|
import { JwtPayloadUsuario } from './dto/jwt-payload-usuario';
|
2022-04-21 21:31:26 +00:00
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class AuthService {
|
2022-04-22 01:33:05 +00:00
|
|
|
constructor(
|
|
|
|
private bcryptService: BcryptService,
|
2022-04-22 02:52:40 +00:00
|
|
|
private jwtService: JwtService,
|
|
|
|
private moduloService: ModuloService,
|
2022-04-22 01:33:05 +00:00
|
|
|
private operadorService: OperadorService,
|
|
|
|
private usuarioService: UsuarioService,
|
|
|
|
) {}
|
2022-04-21 21:31:26 +00:00
|
|
|
|
2022-05-02 17:45:12 +00:00
|
|
|
loginAdmin(admin: string, password: string) {
|
2022-10-16 04:51:56 +00:00
|
|
|
return this.operadorService.findInfoOperadorAdmin(admin).then((admin) => {
|
|
|
|
this.validacionBasica(admin, password);
|
2022-10-17 16:49:59 +00:00
|
|
|
this.validacionOperador(admin);
|
2022-10-16 04:51:56 +00:00
|
|
|
|
2022-10-22 17:29:40 +00:00
|
|
|
// Creo payload apartir de la interface que le corresponde a este tipo de usaurio
|
2022-10-16 04:51:56 +00:00
|
|
|
const JwtPayload: JwtPayloadAdmin = {
|
|
|
|
Operador: {
|
|
|
|
id_operador: admin.id_operador,
|
|
|
|
operador: admin.operador,
|
|
|
|
nombre: admin.nombre,
|
2022-10-17 16:49:59 +00:00
|
|
|
institucion: { id_institucion: admin.institucion.id_institucion },
|
|
|
|
tipoUsuario: { id_tipo_usuario: admin.tipoUsuario.id_tipo_usuario },
|
2022-10-16 04:51:56 +00:00
|
|
|
},
|
|
|
|
};
|
2022-10-17 16:49:59 +00:00
|
|
|
|
2022-10-22 17:29:40 +00:00
|
|
|
// "Firmo"/creo el token
|
2022-10-16 04:51:56 +00:00
|
|
|
return { token: this.jwtService.sign(JwtPayload) };
|
2022-04-22 01:33:05 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-06-13 10:33:53 +00:00
|
|
|
async loginOperador(id_modulo: number, operador: string, password: string) {
|
2022-10-05 01:46:31 +00:00
|
|
|
const modulo = await this.moduloService.findInfoModuloById(id_modulo);
|
2022-04-22 02:52:40 +00:00
|
|
|
|
|
|
|
return this.operadorService
|
2022-10-16 04:51:56 +00:00
|
|
|
.findInfoOperador(modulo.institucion, operador)
|
|
|
|
.then((operador) => {
|
|
|
|
this.validacionBasica(operador, password);
|
2022-10-17 16:49:59 +00:00
|
|
|
this.validacionOperador(operador);
|
2022-10-16 04:51:56 +00:00
|
|
|
|
2022-10-22 17:29:40 +00:00
|
|
|
// Creo payload apartir de la interface que le corresponde a este tipo de usaurio
|
2022-10-16 04:51:56 +00:00
|
|
|
const JwtPayload: JwtPayloadOperador = {
|
|
|
|
Operador: {
|
|
|
|
id_operador: operador.id_operador,
|
|
|
|
operador: operador.operador,
|
|
|
|
nombre: operador.nombre,
|
|
|
|
institucion: {
|
|
|
|
id_institucion: operador.institucion.id_institucion,
|
|
|
|
},
|
|
|
|
tipoUsuario: {
|
|
|
|
id_tipo_usuario: operador.tipoUsuario.id_tipo_usuario,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2022-10-22 17:29:40 +00:00
|
|
|
// "Firmo"/creo el token
|
2022-10-16 04:51:56 +00:00
|
|
|
if (operador.tipoUsuario.id_tipo_usuario === 4)
|
|
|
|
JwtPayload.Modulo.id_modulo = modulo.id_modulo;
|
|
|
|
return { token: this.jwtService.sign(JwtPayload) };
|
2022-04-22 02:52:40 +00:00
|
|
|
});
|
2022-04-22 01:33:05 +00:00
|
|
|
}
|
2022-05-02 17:45:12 +00:00
|
|
|
|
|
|
|
loginUsuario(usuario: string, password: string) {
|
2022-09-01 04:43:55 +00:00
|
|
|
return this.usuarioService
|
2022-10-17 03:45:31 +00:00
|
|
|
.findInfoUsuarioByUsuario(usuario)
|
|
|
|
.then((usuario) => {
|
2022-10-22 17:29:40 +00:00
|
|
|
// Sin password = no registrado, valida que este registrado
|
2022-10-17 03:45:31 +00:00
|
|
|
if (usuario && !usuario.password)
|
2022-09-01 04:43:55 +00:00
|
|
|
throw new BadRequestException('Este usuario no ha sido registrado.');
|
2022-10-17 16:49:59 +00:00
|
|
|
this.validacionBasica(usuario, password);
|
2022-10-17 03:45:31 +00:00
|
|
|
|
2022-10-22 17:29:40 +00:00
|
|
|
// Creo payload apartir de la interface que le corresponde a este tipo de usaurio
|
2022-10-17 03:45:31 +00:00
|
|
|
const JwtPayload: JwtPayloadUsuario = {
|
|
|
|
Usuario: {
|
|
|
|
id_usuario: usuario.id_usuario,
|
|
|
|
usuario: usuario.usuario,
|
|
|
|
nombre: usuario.nombre,
|
|
|
|
tipoUsuario: {
|
|
|
|
id_tipo_usuario: usuario.tipoUsuario.id_tipo_usuario,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2022-10-22 17:29:40 +00:00
|
|
|
// "Firmo"/creo el token
|
2022-10-17 03:45:31 +00:00
|
|
|
return { token: this.jwtService.sign(JwtPayload) };
|
2022-09-01 04:43:55 +00:00
|
|
|
});
|
2022-05-02 17:45:12 +00:00
|
|
|
}
|
2022-10-16 04:51:56 +00:00
|
|
|
|
2022-10-17 16:49:59 +00:00
|
|
|
private validacionBasica(
|
|
|
|
operadorUsuario: Operador | Usuario,
|
|
|
|
password: string,
|
|
|
|
) {
|
|
|
|
// Valido que el operador o usuario existan y que el password sea el correcto
|
|
|
|
if (
|
|
|
|
!operadorUsuario ||
|
|
|
|
!this.bcryptService.comparar(password, operadorUsuario.password)
|
|
|
|
)
|
2022-10-16 04:51:56 +00:00
|
|
|
throw new BadRequestException(
|
|
|
|
'Usuario y/o password incorrectos, ingresa unas credenciales válidas.',
|
|
|
|
);
|
2022-10-17 16:49:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private validacionOperador(operador: Operador) {
|
|
|
|
// Valido que el operador este activo
|
2022-10-16 04:51:56 +00:00
|
|
|
if (!operador.activo)
|
|
|
|
throw new UnauthorizedException('Esta cuenta se encuentra desactivada.');
|
|
|
|
}
|
2022-04-21 21:31:26 +00:00
|
|
|
}
|