log.js 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. 'use strict';
  2. const Service = require('egg').Service;
  3. const assert = require('assert');
  4. const moment = require('moment');
  5. const routerMethod = require('../../config/routerMethod');
  6. const routerMondel = require('../../config/routerMondel');
  7. class LogService extends Service {
  8. async create({ mondel, method, data, result, userName, acct, date }) {
  9. assert(mondel, '模块不存在');
  10. assert(method, '类型不存在');
  11. assert(data, '数据不存在');
  12. assert(result, '结果不存在');
  13. assert(userName, '操作人不存在');
  14. assert(acct, '操作帐号不存在');
  15. assert(date, '时间不存在');
  16. const { Log: model } = this.ctx.model;
  17. const createAt = moment().format('x');
  18. try {
  19. await model.create({ data, method, createAt, mondel, result, userName, acct, date });
  20. return { errmsg: '', errcode: 0 };
  21. } catch (error) {
  22. throw new Error('添加失败');
  23. }
  24. }
  25. async del({ id }) {
  26. assert(id, 'id不存在');
  27. const { Log: model } = this.ctx.model;
  28. try {
  29. await model.findById(id).remove();
  30. return { errmsg: '', errcode: 0 };
  31. } catch (error) {
  32. throw new Error('删除失败');
  33. }
  34. }
  35. async query({ skip, limit, mondel, method, result }) {
  36. const { Log: model } = this.ctx.model;
  37. const filter = {};
  38. if (mondel) filter.mondel = mondel;
  39. if (method) filter.method = method;
  40. if (result) filter.result = result;
  41. try {
  42. const total = await model.find({ ...filter });
  43. let res;
  44. if (skip && limit) {
  45. res = await model.find({ ...filter }).skip(Number(skip) * Number(limit)).limit(Number(limit));
  46. } else {
  47. res = await model.find({ ...filter });
  48. }
  49. return { errmsg: '', errcode: 0, data: res, total: total.length };
  50. } catch (error) {
  51. console.log(error);
  52. throw new Error('查询失败');
  53. }
  54. }
  55. async init() {
  56. const { ctx } = this;
  57. const { url, method, body } = ctx.request;
  58. let mondel = '';
  59. let methods = '';
  60. let decode = {};
  61. const { AdminUser: model } = ctx.model;
  62. const date = moment().format('YYYY-MM-DD HH:mm:ss');
  63. if (method !== 'GET') {
  64. // token
  65. const tokenstr = ctx.request.header.authorization;
  66. if (tokenstr) {
  67. const token = tokenstr.substring(7);
  68. decode = ctx.app.jwt.verify(token, ctx.app.config.secret);
  69. } else {
  70. const { acct } = ctx.request.body;
  71. const res = await model.find({ acct });
  72. decode = res[0];
  73. }
  74. const str = url.split('/');
  75. for (let i = 0; i < str.length; i++) {
  76. const e = str[i];
  77. if (e !== '' && e !== 'api') {
  78. if (e === 'create' || e === 'update' || e === 'delete' || e === 'upload' || e === 'login') {
  79. methods = routerMethod[e];
  80. if (e === 'delete') {
  81. break;
  82. }
  83. } else {
  84. mondel = routerMondel[e];
  85. }
  86. }
  87. }
  88. return { mondel, method: methods, data: body, acct: decode.acct, userName: decode.userName, date };
  89. }
  90. }
  91. }
  92. module.exports = LogService;