achieve_expert.js 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. 'use strict';
  2. const { CrudService } = require('naf-framework-mongoose/lib/service');
  3. const { BusinessError, ErrorCode } = require('naf-core').Error;
  4. const _ = require('lodash');
  5. const assert = require('assert');
  6. const jwt = require('jsonwebtoken');
  7. // 临时专家
  8. class Achieve_expertService extends CrudService {
  9. constructor(ctx) {
  10. super(ctx, 'achieve_expert');
  11. this.model = this.ctx.model.AchieveExpert;
  12. }
  13. async create(data) {
  14. const { password } = data;
  15. data.password = { secret: password };
  16. const res = await this.model.create(data);
  17. return res;
  18. }
  19. async update({ id }, data) {
  20. const { password, verify } = data;
  21. const older = await this.model.findById(id);
  22. if (!older) throw new BusinessError(ErrorCode.DATA_NOT_EXIST, '未找到专家信息');
  23. // 此处是检验专家是否可以进行修改
  24. const { status } = older;
  25. if (status === '1') throw new BusinessError(ErrorCode.SERVICE_FAULT, '您的工作已完成,若有问题请联系平台管理员!');
  26. if (password) { data.password = { secret: password }; }
  27. // 如果修改时有评审内容,则将该账号毙掉
  28. if (verify && verify.score) data.status = '1';
  29. await this.model.findByIdAndUpdate(id, data);
  30. return await this.model.findById(id);
  31. }
  32. /**
  33. * 临时专家账号登录
  34. * @param {Object} params 手机号,密码
  35. */
  36. async login({ phone, password }) {
  37. const expert = await this.model.findOne({ phone, status: '0' }, '+password');
  38. if (!expert) throw new BusinessError(ErrorCode.DATA_NOT_EXIST, '您不存在未完成的工作,无需登录');
  39. const { password: op } = expert;
  40. const { secret } = op;
  41. if (secret !== password) throw new BusinessError(ErrorCode.BAD_PASSWORD, '密码错误');
  42. const data = _.omit(JSON.parse(JSON.stringify(expert)), [ 'expert_name', 'meta', 'password', '__v', 'verify' ]);
  43. const { secret: secrets } = this.config.jwt;
  44. data.name = _.get(expert, 'expert_name');
  45. data.role = '3';
  46. const token = jwt.sign(data, secrets);
  47. return token;
  48. }
  49. }
  50. module.exports = Achieve_expertService;