2022-04-22 02:52:40 +00:00
|
|
|
import {
|
|
|
|
ConflictException,
|
|
|
|
Injectable,
|
|
|
|
UnauthorizedException,
|
|
|
|
} from '@nestjs/common';
|
2022-04-21 21:31:26 +00:00
|
|
|
import { JwtService } from '@nestjs/jwt';
|
2022-07-08 04:58:21 +00:00
|
|
|
import { Operador } from '../operador/entity/operador.entity';
|
|
|
|
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-04-22 02:52:40 +00:00
|
|
|
import { JwtPayload } from './dto/jwt-payload';
|
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-05-02 19:40:17 +00:00
|
|
|
return this.operadorService.findAdmin(admin, false).then((operador) => {
|
2022-06-13 10:33:53 +00:00
|
|
|
this.validarLogin(operador, password);
|
2022-04-22 03:34:10 +00:00
|
|
|
|
|
|
|
const payload: JwtPayload = {
|
2022-05-02 17:45:12 +00:00
|
|
|
id_operador: operador.id_operador,
|
|
|
|
id_tipo_usuario: operador.tipoUsuario.id_tipo_usuario,
|
2022-04-22 03:34:10 +00:00
|
|
|
};
|
|
|
|
|
2022-05-02 17:45:12 +00:00
|
|
|
return { operador, token: this.jwtService.sign(payload) };
|
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-04-22 02:52:40 +00:00
|
|
|
const modulo = await this.moduloService.findById(id_modulo);
|
|
|
|
|
|
|
|
return this.operadorService
|
2022-06-13 10:33:53 +00:00
|
|
|
.findByOperador(modulo.institucion, operador, false)
|
2022-04-22 02:52:40 +00:00
|
|
|
.then((operador) => {
|
2022-06-13 10:33:53 +00:00
|
|
|
this.validarLogin(operador, password);
|
2022-04-22 02:52:40 +00:00
|
|
|
|
|
|
|
const payload: JwtPayload = {
|
2022-07-06 02:53:47 +00:00
|
|
|
id_modulo: modulo.id_modulo,
|
2022-04-22 02:52:40 +00:00
|
|
|
id_operador: operador.id_operador,
|
|
|
|
id_tipo_usuario: operador.tipoUsuario.id_tipo_usuario,
|
|
|
|
};
|
|
|
|
|
|
|
|
return { operador, token: this.jwtService.sign(payload) };
|
|
|
|
});
|
2022-04-22 01:33:05 +00:00
|
|
|
}
|
2022-05-02 17:45:12 +00:00
|
|
|
|
|
|
|
loginUsuario(usuario: string, password: string) {
|
|
|
|
return this.usuarioService.findByUsuario(usuario, false).then((usuario) => {
|
2022-06-13 10:33:53 +00:00
|
|
|
this.validarLogin(usuario, password);
|
2022-05-02 17:45:12 +00:00
|
|
|
|
|
|
|
const payload: JwtPayload = {
|
|
|
|
id_usuario: usuario.id_usuario,
|
|
|
|
id_tipo_usuario: usuario.tipoUsuario.id_tipo_usuario,
|
|
|
|
};
|
|
|
|
|
2022-07-06 02:53:47 +00:00
|
|
|
return { token: this.jwtService.sign(payload), usuario };
|
2022-05-02 17:45:12 +00:00
|
|
|
});
|
|
|
|
}
|
2022-06-13 10:33:53 +00:00
|
|
|
|
|
|
|
validarLogin(usuarioOperador: Usuario | Operador, password: string) {
|
|
|
|
if (
|
|
|
|
!usuarioOperador ||
|
|
|
|
!this.bcryptService.comparar(password, usuarioOperador.password)
|
|
|
|
)
|
|
|
|
throw new UnauthorizedException(
|
|
|
|
'Usuario y/o password incorrectos, trata de nuevo.',
|
|
|
|
);
|
|
|
|
if (!usuarioOperador.activo)
|
|
|
|
throw new ConflictException('Esta cuenta se encuentra desactivada.');
|
|
|
|
}
|
2022-04-21 21:31:26 +00:00
|
|
|
}
|