log.js 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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.findOne({ acct });
  72. if (!res) {
  73. decode = { acct, userName: '用户不存在' };
  74. } else {
  75. decode = res;
  76. }
  77. }
  78. const str = url.split('/');
  79. for (let i = 0; i < str.length; i++) {
  80. const e = str[i];
  81. if (e !== '' && e !== 'api') {
  82. if (e === 'create' || e === 'update' || e === 'delete' || e === 'upload' || e === 'login' || e === 'pwdUpdate') {
  83. methods = routerMethod[e];
  84. if (e === 'delete') {
  85. break;
  86. }
  87. } else {
  88. mondel = routerMondel[e];
  89. }
  90. }
  91. }
  92. return { mondel, method: methods, data: body, acct: decode.acct, userName: decode && decode.userName, date };
  93. }
  94. }
  95. }
  96. module.exports = LogService;