12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- 'use strict';
- const crypto = require('crypto');
- const assert = require('assert');
- const Service = require('egg').Service;
- class AdminUserService extends Service {
- constructor(ctx) {
- super(ctx);
- this.model = this.ctx.model.AdminUser;
- this.UserBindRoleModel = this.ctx.model.UserBindRole;
- }
- async create({ userName, password, openid, name, phone }) {
- assert(userName, '缺少用户名');
- assert(password, '缺少密码');
- password = crypto.createHash('md5').update(password).digest('hex');
- const obj = await this.model.findOne({ userName });
- if (obj) return { errcode: -1001, errmsg: '用户名已存在', data: '' };
- try {
- const res = await this.model.create({ userName, password, openid, name, phone });
- return { errcode: 0, errmsg: 'ok', data: res };
- } catch (error) {
- throw error;
- }
- }
- async update({ id, userName, password, openid, name, phone }) {
- assert(id, '缺少用户ID');
- if (password) password = crypto.createHash('md5').update(password).digest('hex');
- try {
- const user = await this.model.findOne({ _id: id });
- if (!user) return { errcode: -1001, errmsg: '用户不存在', data: '' };
- await this.model.updateOne({ _id: id }, { userName, password, openid, name, phone });
- return { errcode: 0, errmsg: 'ok', data: 'update' };
- } catch (error) {
- throw error;
- }
- }
- async delete({ id }) {
- assert(id, '缺少用户ID');
- try {
- const user = await this.model.findOne({ _id: id });
- if (!user) return { errcode: -1001, errmsg: '用户不存在', data: '' };
- await this.model.remove({ _id: id });
- await this.UserBindRoleModel.find({ userId: id }).remove();
- return { errcode: 0, errmsg: 'ok', data: 'delete' };
- } catch (error) {
- throw error;
- }
- }
- async query({ skip, limit, phone, name, userName }) {
- const filter = {};
- if (userName || name || phone) filter.$or = [];
- if (userName) filter.$or.push({ code: { $regex: userName } });
- if (name) filter.$or.push({ name: { $regex: name } });
- if (phone) filter.$or.push({ phone: { $regex: phone } });
- try {
- const total = await this.model.find({ ...filter }, { password: false });
- let res;
- if (skip && limit) {
- res = await this.model.find({ ...filter }, { password: false }).skip(Number(skip) * Number(limit)).limit(Number(limit));
- } else {
- res = await this.model.find({ ...filter }, { password: false });
- }
- return { errcode: 0, errmsg: 'ok', data: res, total: total.length };
- } catch (error) {
- throw error;
- }
- }
- async updatePwd({ id, password, oldpassword }) {
- assert(id, '缺少用ID');
- assert(password, '缺少新密码');
- assert(oldpassword, '缺少原密码');
- oldpassword = crypto.createHash('md5').update(oldpassword).digest('hex');
- const user = await this.model.findOne({ _id: id });
- if (!user) return { errcode: -1001, errmsg: '用户不存在', data: '' };
- if (user.password !== oldpassword) return { errcode: -1001, errmsg: '原密码不正确', data: '' };
- password = crypto.createHash('md5').update(password).digest('hex');
- try {
- const res = await this.model.updateOne({ _id: id }, { password });
- return { errcode: 0, errmsg: 'ok', data: { ...res, password: '' } };
- } catch (error) {
- throw error;
- }
- }
- }
- module.exports = AdminUserService;
|