user.js 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. 'use strict';
  2. const assert = require('assert');
  3. const _ = require('lodash');
  4. const { ObjectId } = require('mongoose').Types;
  5. const { CrudService } = require('naf-framework-mongoose/lib/service');
  6. const { BusinessError, ErrorCode } = require('naf-core').Error;
  7. const jwt = require('jsonwebtoken');
  8. class UserService extends CrudService {
  9. constructor(ctx) {
  10. super(ctx, 'user');
  11. this.model = this.ctx.model.User;
  12. }
  13. // 重写创建方法
  14. async create(data) {
  15. const { name, phone, passwd } = data;
  16. console.log(data);
  17. assert(name && phone && passwd, '缺少部分信息项');
  18. assert(/^\d{11}$/i.test(phone), 'phone无效');
  19. const user = await this.model.findOne({ phone });
  20. if (user) {
  21. throw new BusinessError(ErrorCode.DATA_EXISTED);
  22. }
  23. const newdata = data;
  24. const pas = await this.createJwtPwd(passwd);
  25. newdata.passwd = { secret: pas };
  26. const res = await this.model.create(newdata);
  27. return res;
  28. }
  29. // 创建登录Token
  30. async createJwtPwd(password) {
  31. const { secret, expiresIn, issuer } = this.config.jwt;
  32. const token = await jwt.sign(password, secret);
  33. return token;
  34. }
  35. // 重写修改方法
  36. async update({ id }, data) {
  37. const { name, phone, passwd, openid, role, menus, remark, uid, deptname } = data;
  38. const user = await this.model.findById(id, '+passwd');
  39. if (name) {
  40. user.name = name;
  41. }
  42. if (phone) {
  43. user.phone = phone;
  44. }
  45. if (passwd) {
  46. const newpasswd = await this.createJwtPwd(passwd);
  47. user.passwd = { secret: newpasswd };
  48. }
  49. if (openid) {
  50. user.openid = openid;
  51. }
  52. if (role) {
  53. user.role = role;
  54. }
  55. if (menus) {
  56. user.menus = menus;
  57. }
  58. if (uid) {
  59. user.uid = uid;
  60. }
  61. if (deptname) {
  62. user.deptname = deptname;
  63. }
  64. if (remark) {
  65. user.remark = remark;
  66. }
  67. await user.save();
  68. }
  69. // 用户修改密码
  70. async uppasswd(data) {
  71. const { id, oldpasswd, newpasswd } = data;
  72. assert(id && oldpasswd && newpasswd, '缺少部分信息项');
  73. // 根据用户id查询其他用户表中是否存在相应数据
  74. const user = await this.model.findById(id, '+passwd');
  75. // 如果用户不存在抛出异常
  76. if (!user) {
  77. throw new BusinessError(ErrorCode.USER_NOT_EXIST);
  78. }
  79. // 将用户输入的密码进行加密并与查询到的用户数据密码相比对
  80. const _oldpasswd = await this.createJwtPwd(oldpasswd);
  81. // 如果两个密码不一致抛出异常
  82. if (_oldpasswd !== user.passwd.secret) {
  83. throw new BusinessError(ErrorCode.BAD_PASSWORD);
  84. }
  85. const _newpasswd = await this.createJwtPwd(newpasswd);
  86. user.passwd = { secret: _newpasswd };
  87. await user.save();
  88. }
  89. async querymenus({ id }) {
  90. const user = await this.model.findById(id);
  91. if (!user) {
  92. throw new BusinessError(ErrorCode.USER_NOT_EXIST);
  93. }
  94. const _menus = [];
  95. for (const elm of user.menus) {
  96. const _menu = await this.rmodel.findById({ _id: ObjectId(elm) });
  97. if (_menu) {
  98. _menus.push({ id: elm, role_name: _menu.role_name, url: _menu.url });
  99. }
  100. }
  101. return { id, menus: _menus };
  102. }
  103. // 按条件更新方法
  104. async updatebyuid({ id }, data) {
  105. const user = await this.model.findOne({ uid: id });
  106. if (user) {
  107. user.name = data.name;
  108. user.deptname = data.deptname;
  109. }
  110. await user.save();
  111. }
  112. // 按条件更新方法
  113. async bind(data) {
  114. const user = await this.model.findById(data.uid);
  115. if (!user) {
  116. throw new BusinessError(ErrorCode.USER_NOT_EXIST);
  117. }
  118. if (user.openid) {
  119. throw new BusinessError(ErrorCode.USER_EXIST);
  120. }
  121. user.openid = data.openid;
  122. return await user.save();
  123. }
  124. async findByOpenid(openid) {
  125. const user = await this.model.findOne({ openid });
  126. return user;
  127. }
  128. }
  129. module.exports = UserService;