123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- 'use strict';
- const Service = require('egg').Service;
- const assert = require('assert');
- const moment = require('moment');
- class ContentService extends Service {
- async create({ title, thumbnail, annex, content, istop, menus, date, annexname, term, sort, columns, contentType, href }) {
- assert(title, '标题不存在');
- // assert(thumbnail, '缩略图不存在');
- // assert(content, '内容不存在');
- const { Content: model } = this.ctx.model;
- const createAt = moment().format('x');
- let text = content.replace(new RegExp('</?[^>]+>', 'gm'), '');
- text = text.replace(/\s*|\t|\r|\n/g, '');
- text = text.replace(/ /ig, '');
- const slug = text.substring(0, 200);
- try {
- const year = date.slice(0, 4) + '年';
- await model.create({ title, slug, thumbnail, annex, content, istop, menus, createAt, year, date, annexname, term, hits: 0, sort, columns, contentType, href });
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error('添加失败');
- }
- }
- async update({ title, thumbnail, annex, content, istop, menus, date, annexname, term, _id, sort, columns, contentType, href }) {
- assert(_id, 'id不存在');
- const { Content: model } = this.ctx.model;
- let text = content.replace(new RegExp('</?[^>]+>', 'gm'), '');
- text = text.replace('\\s*|\t|\r|\n', '');
- const slug = text.substring(0, 200);
- const year = date.slice(0, 4) + '年';
- try {
- await model.findById(_id).update({ title, slug, thumbnail, annex, content, istop, menus, year, date, annexname, term, sort, columns, contentType, href });
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error('修改失败');
- }
- }
- async del({ id }) {
- assert(id, 'id不存在');
- const { Content: model } = this.ctx.model;
- try {
- await model.findById(id).remove();
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error('删除失败');
- }
- }
- async details({ id }) {
- assert(id, 'id不存在');
- const { Content: model } = this.ctx.model;
- try {
- const res = await model.findById(id);
- const token = Boolean(this.ctx.request.header.authorization);
- if (!token) {
- res.hits++;
- await model.findById(id).update(res);
- }
- return { errmsg: '', errcode: 0, data: res };
- } catch (error) {
- throw new Error('删除失败');
- }
- }
- async query({ skip, limit, title, code, columns }) {
- const { Content: model } = this.ctx.model;
- const filter = {};
- const arr = { title, code, columns };
- for (const e in arr) {
- let datas;
- if (e === 'columns') {
- console.log(arr[e]);
- datas = `{ "${e}": { "$elemMatch": { "$eq": "${arr[e]}" } } }`;
- } else {
- datas = `{ "${e}": { "$regex": "${arr[e]}" } }`;
- }
- if (arr[e]) {
- filter.$or = [];
- filter.$or.push(JSON.parse(datas));
- }
- }
- let total = 0;
- try {
- let res;
- total = await model.find({ ...filter });
- if (skip && limit) {
- res = await model.find({ ...filter }, { content: false }).skip(Number(skip) * Number(limit)).limit(Number(limit))
- .sort({ sort: -1, createAt: -1 });
- } else {
- res = await model.find({ ...filter }, { content: false }).sort({ sort: -1, createAt: -1 });
- }
- return { errmsg: '', errcode: 0, data: res, total: total.length };
- } catch (error) {
- throw new Error('查询失败');
- }
- }
- // 数据库添加过滤数据方法
- async filepath() {
- const { Content: model } = this.ctx.model;
- try {
- const res = await model.find();
- for (let i = 0; i < res.length; i++) {
- const columns = [ res[i].menus ];
- await model.findById(res[i]._id).update({ ...res, columns });
- }
- return { errmsg: '', errcode: 0 };
- } catch (error) {
- throw new Error('删除失败');
- }
- }
- }
- module.exports = ContentService;
|