login.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. 'use strict';
  2. const assert = require('assert');
  3. const { ObjectId } = require('mongoose').Types;
  4. const { CrudService } = require('naf-framework-mongoose/lib/service');
  5. const { BusinessError, ErrorCode } = require('naf-core').Error;
  6. const jwt = require('jsonwebtoken');
  7. const uuid = require('uuid');
  8. class LoginService extends CrudService {
  9. constructor(ctx) {
  10. super(ctx, 'login');
  11. this.model = this.ctx.model.Dock;
  12. }
  13. // 用户登录
  14. async login(data) {
  15. const { room_phone, passwd, role } = data;
  16. const phone = room_phone;
  17. const room_id = room_phone;
  18. // 根据用户输入的手机号查询其他用户表中是否存在相应数据
  19. let user = await this.model.findOne({ phone, role });
  20. const flag = true;
  21. if (!user) {
  22. user = await this.model.findOne({ room_id, role });
  23. }
  24. // 如果用户不存在抛出异常
  25. if (!user) {
  26. throw new BusinessError(ErrorCode.USER_NOT_EXIST);
  27. }
  28. let _user = '';
  29. // 将用户输入的密码进行加密并与查询到的用户数据密码相比对
  30. const pasw = await this.createJwtPwd(passwd);
  31. if (flag) {
  32. // 手机
  33. _user = await this.model.findOne({ phone, pasw });
  34. } else {
  35. // 房间号
  36. _user = await this.model.findOne({ room_id, pasw });
  37. }
  38. if (_user === '') {
  39. throw new BusinessError(ErrorCode.USER_NOT_EXIST);
  40. // throw new BusinessError(ErrorCode.BAD_PASSWORD);
  41. } else {
  42. if (role === '3') {
  43. const operationlogdata = { login_id: user.id, login_name: user.name, login_role: user.role, type: '0', operation_edit: '登录' };
  44. const url = 'http://127.0.0.1:9004/api/market/operationlog/';
  45. const operationlog = await this.ctx.curl(url, {
  46. method: 'post',
  47. headers: {
  48. 'content-type': 'application/json',
  49. },
  50. dataType: 'json',
  51. data: JSON.stringify(operationlogdata),
  52. });
  53. }
  54. }
  55. // 取出用户的类型,根据用户类型返回相应信息
  56. const state = uuid();
  57. const key = `free:auth:state:${state}`;
  58. const token = await this.createJwt(user);
  59. await this.app.redis.set(key, token, 'EX', 60 * 60 * 24);
  60. return { key };
  61. }
  62. // 创建登录Token
  63. async createJwtPwd(password) {
  64. const { secret } = this.config.jwt;
  65. const token = await jwt.sign(password, secret);
  66. return token;
  67. }
  68. // 创建登录Token
  69. async createJwt({ id, adminuser, uid, phone, role, remark, deptid, pid, code }) {
  70. const { secret, expiresIn = '1d', issuer = role } = this.config.jwt;
  71. const subject = phone;
  72. const res = { uid: id, userid: uid, adminuser, phone, role, remark, deptid, pid, code };
  73. const token = await jwt.sign(res, secret, { expiresIn, issuer, subject });
  74. return token;
  75. }
  76. // 取得redis内token信息
  77. async token({ key }) {
  78. assert(key, 'key不能为空');
  79. const token = await this.app.redis.get(key);
  80. if (!token) {
  81. throw new BusinessError(ErrorCode.SERVICE_FAULT, 'token已经过期');
  82. }
  83. return { token };
  84. }
  85. // 删除操作
  86. async destroy({ key }) {
  87. const res = await this.app.redis.del(key);
  88. console.log(res);
  89. return res;
  90. }
  91. }
  92. module.exports = LoginService;