123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- 'use strict';
- const Service = require('egg').Service;
- const assert = require('assert');
- const moment = require('moment');
- // const _ = require('lodash');
- class ColumnService extends Service {
- async create({ name, code, menuList }) {
- assert(name, '名称不存在');
- assert(code, '编码不存在');
- const { Column: model } = this.ctx.model;
- const createAt = moment().format('x');
- try {
- const isdata = await model.find({ code });
- if (isdata.length > 0) return { errmsg: '编码已存在', errcode: -2001 };
- await model.create({ name, code, menuList, createAt });
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '添加失败' });
- }
- }
- async update({ name, code, _id, menuList }) {
- assert(_id, 'id不存在');
- const { Column: model } = this.ctx.model;
- try {
- await model.findById(_id).update({ name, code, menuList });
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '修改失败' });
- }
- }
- async del({ id }) {
- assert(id, 'id不存在');
- const { Column: model } = this.ctx.model;
- const { Content: Contentmodel } = this.ctx.model;
- try {
- // 当前数据
- const res = await model.findById(id);
- // 复杂查询文章数据
- const contentList = await Contentmodel.find({ columns: res.code });
- contentList.filter(async p => {
- await Contentmodel.findById(p._id).update({ columns: '' });
- });
- await model.findById(id).remove();
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '删除失败' });
- }
- }
- async menuquery({ code }) {
- const { Column: model } = this.ctx.model;
- try {
- const res = await model.where('menuList').in(code);
- return { errmsg: '', errcode: 0, data: res };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '查询失败' });
- }
- }
- async usercolumnquery() {
- const { Column: model } = this.ctx.model;
- const { AdminUser: Usermodel } = this.ctx.model;
- try {
- const str = this.ctx.request.header.authorization;
- const token = str.substring(7);
- const decode = this.ctx.app.jwt.verify(token, this.app.config.jwt.secret);
- const columnList = [];
- const res = await Usermodel.find({ acct: decode.acct });
- if (res.length > 0) {
- const usercolumnList = res[0].columnList;
- if (usercolumnList.length > 0) {
- for (let i = 0; i < usercolumnList.length; i++) {
- const item = await model.find({ code: usercolumnList[i] });
- columnList.push(item[0]);
- }
- }
- }
- return { errmsg: '', errcode: 0, data: columnList };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '查询失败' });
- }
- }
- async query({ skip, limit, name, code }) {
- const { Column: model } = this.ctx.model;
- const filter = {};
- if (name) filter.name = name;
- if (code) filter.code = code;
- try {
- let res;
- const total = await model.find({ ...filter });
- if (skip && limit) {
- res = await model.find({ ...filter }).skip(Number(skip) * Number(limit)).limit(Number(limit));
- } else {
- res = await model.find({ ...filter });
- }
- return { errmsg: '', errcode: 0, data: res, total: total.length };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '查询失败' });
- }
- }
- }
- module.exports = ColumnService;
|