1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- 'use strict';
- const Service = require('egg').Service;
- const assert = require('assert');
- const moment = require('moment');
- class ContentService extends Service {
- async create({ title, shortTitle, slug, thumbnail, annex, content, istop, columnList }) {
- assert(title, '标题不存在');
- assert(shortTitle, '短标题不存在');
- assert(slug, '摘要不存在');
- // assert(thumbnail, '缩略图不存在');
- assert(content, '内容不存在');
- const { Content: model } = this.ctx.model;
- const createAt = moment().format('x');
- try {
- await model.create({ title, shortTitle, slug, thumbnail, annex, content, istop, columnList, createAt });
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '添加失败' });
- }
- }
- async update({ title, shortTitle, slug, thumbnail, annex, content, istop, columnList, id }) {
- assert(id, 'id不存在');
- const { Content: model } = this.ctx.model;
- try {
- await model.findByIdAndUpdate(id, { title, shortTitle, slug, thumbnail, annex, content, istop, columnList });
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '修改失败' });
- }
- }
- async del({ id }) {
- assert(id, 'id不存在');
- const { Content: model } = this.ctx.model;
- try {
- await model.findByIdAndDelete(id);
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '删除失败' });
- }
- }
- async details({ id }) {
- assert(id, 'id不存在');
- const { Content: model } = this.ctx.model;
- try {
- const res = await model.findById(id);
- return { errmsg: '', errcode: 0, data: res };
- } catch (error) {
- throw new Error({ errcode: -2001, errmsg: '删除失败' });
- }
- }
- async query({ skip, limit, code }) {
- assert(code, '栏目code不存在');
- const { Content: model } = this.ctx.model;
- try {
- let res;
- const total = await model.where('columnList').in(code).select({ content: false });
- if (skip && limit) {
- res = await model.where('columnList').in(code).select({ content: false })
- .skip(Number(skip) * Number(limit))
- .limit(Number(limit));
- // res = await model.find({ code, content: false }).skip(skip * limit).limit(limit);
- } else {
- res = await model.where('columnList').in(code).select({ content: false });
- }
- return { errmsg: '', errcode: 0, data: res, total: total.length };
- } catch (error) {
- console.log(error);
- throw new Error({ errcode: -2001, errmsg: '查询失败' });
- }
- }
- }
- module.exports = ContentService;
|