login.js 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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. console.log('--------------------------->>>>>>>>>>>>>>>>>>>>>>>>>>>>>>');
  19. console.log(passwd);
  20. console.log(role);
  21. console.log(room_phone);
  22. // 根据用户输入的手机号查询其他用户表中是否存在相应数据
  23. let user = await this.model.findOne({ phone, role });
  24. const flag = true;
  25. if (!user) {
  26. user = await this.model.findOne({ room_id, role });
  27. }
  28. // 如果用户不存在抛出异常
  29. if (!user) {
  30. throw new BusinessError(ErrorCode.USER_NOT_EXIST);
  31. }
  32. let _user = '';
  33. // 将用户输入的密码进行加密并与查询到的用户数据密码相比对
  34. const pasw = await this.createJwtPwd(passwd);
  35. if (flag) {
  36. // 手机
  37. _user = await this.model.findOne({ phone, pasw });
  38. } else {
  39. // 房间号
  40. _user = await this.model.findOne({ room_id, pasw });
  41. }
  42. if (_user === '') {
  43. throw new BusinessError(ErrorCode.USER_NOT_EXIST);
  44. // throw new BusinessError(ErrorCode.BAD_PASSWORD);
  45. }
  46. // 将用户输入的密码进行加密并与查询到的用户数据密码相比对
  47. // const pas = await this.createJwtPwd(passwd);
  48. // // 如果两个密码不一致抛出异常
  49. // if (pas !== _user.passwd.secret) {
  50. // throw new BusinessError(ErrorCode.BAD_PASSWORD);
  51. // }
  52. // if (role === '3') {
  53. // console.log('vip用户');
  54. // } else if (role === '8') {
  55. // console.log('展会vip用户');
  56. // } else {
  57. // console.log('无此展会');
  58. // }
  59. // if (_user.role === '3' || _user.role === '8') {
  60. // const url = 'http://127.0.0.1:9004/api/market/user/' + _user.uid;
  61. // const marketuser = await this.ctx.curl(url, {
  62. // method: 'get',
  63. // headers: {
  64. // 'content-type': 'application/json',
  65. // },
  66. // dataType: 'json',
  67. // });
  68. // if (marketuser.data.data.status !== '1') {
  69. // throw new BusinessError(ErrorCode.ACCESS_DENIED);
  70. // }
  71. // } else if (_user.role === '6') {
  72. // const url = 'http://127.0.0.1:9004/api/market/expertsuser/' + _user.uid;
  73. // const expertsuser = await this.ctx.curl(url, {
  74. // method: 'get',
  75. // headers: {
  76. // 'content-type': 'application/json',
  77. // },
  78. // dataType: 'json',
  79. // });
  80. // if (expertsuser.data.data.status !== '1') {
  81. // throw new BusinessError(ErrorCode.ACCESS_DENIED);
  82. // }
  83. // }
  84. // 取出用户的类型,根据用户类型返回相应信息
  85. const state = uuid();
  86. const key = `free:auth:state:${state}`;
  87. // const _menus = [];
  88. // for (const elm of user.menus) {
  89. // const _menu = await this.rmodel.findById({ _id: ObjectId(elm) });
  90. // if (_menu) {
  91. // _menus.push({ id: elm, role_name: _menu.role_name, url: _menu.url });
  92. // }
  93. // }
  94. // user.menus = JSON.stringify(_menus);
  95. const token = await this.createJwt(user);
  96. await this.app.redis.set(key, token, 'EX', 60 * 60 * 24);
  97. return { key };
  98. }
  99. // 创建登录Token
  100. async createJwtPwd(password) {
  101. const { secret } = this.config.jwt;
  102. const token = await jwt.sign(password, secret);
  103. return token;
  104. }
  105. // 创建登录Token
  106. async createJwt({ id, name, uid, phone, role, menus, remark, openid, deptid, deptname, pid, code }) {
  107. const { secret, expiresIn = '1d', issuer = role } = this.config.jwt;
  108. const subject = phone;
  109. const res = { uid: id, userid: uid, name, phone, role, menus, openid, remark, deptid, deptname, pid, code };
  110. const token = await jwt.sign(res, secret, { expiresIn, issuer, subject });
  111. return token;
  112. }
  113. // 取得redis内token信息
  114. async token({ key }) {
  115. assert(key, 'key不能为空');
  116. const token = await this.app.redis.get(key);
  117. if (!token) {
  118. throw new BusinessError(ErrorCode.SERVICE_FAULT, 'token已经过期');
  119. }
  120. return { token };
  121. }
  122. // 删除操作
  123. async destroy({ key }) {
  124. const res = await this.app.redis.del(key);
  125. console.log(res);
  126. return res;
  127. }
  128. }
  129. module.exports = LoginService;