adminUser.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. 'use strict';
  2. const Service = require('egg').Service;
  3. const assert = require('assert');
  4. const moment = require('moment');
  5. const crypto = require('crypto');
  6. class adminUserService extends Service {
  7. async create({ acct, password, userName, phone, state, roleList }) {
  8. assert(acct, '帐号不存在');
  9. assert(password, '密码不存在');
  10. assert(userName, '用户名不存在');
  11. assert(state, '状态不存在');
  12. const { AdminUser: model } = this.ctx.model;
  13. const user = await model.find({ acct });
  14. if (user.length > 0) return { errmsg: '帐号已存在', errcode: -2001 };
  15. const createAt = moment().format('x');
  16. const hash = crypto.createHmac('sha256', this.app.config.userSecret);
  17. const pwa = hash.update(password).digest('hex');
  18. try {
  19. const res = await model.create({ acct, password: pwa, userName, phone, createAt, state, roleList });
  20. return { errmsg: '', errcode: 0, res };
  21. } catch (error) {
  22. console.log(error);
  23. throw new Error('添加失败');
  24. }
  25. }
  26. async update({ userName, phone, _id, roleList, state, password }) {
  27. assert(_id, 'id不存在');
  28. const { AdminUser: model } = this.ctx.model;
  29. try {
  30. const hash = crypto.createHmac('sha256', this.app.config.userSecret);
  31. const pwd = hash.update(password).digest('hex');
  32. await model.findById(_id).update({ userName, phone, roleList, state, password: pwd });
  33. return { errmsg: '', errcode: 0 };
  34. } catch (error) {
  35. console.log(error);
  36. throw new Error('修改失败');
  37. }
  38. }
  39. async pwdUpdate({ password, userName, confirmPwd }) {
  40. console.log(password, userName, confirmPwd);
  41. assert(userName, '用户名不存在');
  42. const { AdminUser: model } = this.ctx.model;
  43. const hash = crypto.createHmac('sha256', this.app.config.userSecret);
  44. const cpwd = hash.update(confirmPwd).digest('hex');
  45. try {
  46. const res = await model.findOne({ userName });
  47. if (res.password !== cpwd) {
  48. return { errmsg: '原密码错误', errcode: -2003 };
  49. }
  50. const hash = crypto.createHmac('sha256', this.app.config.userSecret);
  51. const pwd = hash.update(password).digest('hex');
  52. await model.findByIdAndUpdate(res._id, { password: pwd });
  53. return { errmsg: '', errcode: 0 };
  54. } catch (error) {
  55. throw new Error('修改失败');
  56. }
  57. }
  58. async del({ id }) {
  59. assert(id, 'id不存在');
  60. const { AdminUser: model } = this.ctx.model;
  61. try {
  62. await model.findById(id).remove();
  63. return { errmsg: '', errcode: 0 };
  64. } catch (error) {
  65. throw new Error('删除失败');
  66. }
  67. }
  68. async query({ skip, limit, userName, state, acct }) {
  69. const { AdminUser: model } = this.ctx.model;
  70. const filter = {};
  71. if (userName) filter.userName = userName;
  72. if (state) filter.state = state;
  73. if (acct) filter.acct = acct;
  74. try {
  75. let res;
  76. const total = await model.find({ ...filter });
  77. if (skip && limit) {
  78. res = await model.find({ ...filter }, { password: false }).skip(Number(skip) * Number(limit)).limit(Number(limit));
  79. } else {
  80. res = await model.find({ ...filter }, { password: false });
  81. }
  82. return { errmsg: '', errcode: 0, data: res, total: total.length };
  83. } catch (error) {
  84. throw new Error('查询失败');
  85. }
  86. }
  87. }
  88. module.exports = adminUserService;