crud-service.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. "use strict";
  2. const { isString, isArray, get } = require("lodash");
  3. const { isNullOrUndefined, trimData } = require("naf-core").Util;
  4. const assert = require("assert");
  5. const { ObjectId } = require("mongoose").Types;
  6. const { BusinessError, ErrorCode } = require("naf-core").Error;
  7. const { NafService } = require("./naf-service");
  8. class CrudService extends NafService {
  9. async create(data) {
  10. assert(data);
  11. // TODO:保存数据
  12. const res = await this.model.create(data);
  13. return res;
  14. }
  15. async update(filter, update, { projection } = {}) {
  16. assert(filter);
  17. assert(update);
  18. const { _id, id } = filter;
  19. if (_id || id) filter = { _id: ObjectId(_id || id) };
  20. // TODO:检查数据是否存在
  21. const entity = await this.model.findOne(filter).exec();
  22. if (isNullOrUndefined(entity))
  23. throw new BusinessError(ErrorCode.DATA_NOT_EXIST);
  24. // TODO: 修改数据
  25. entity.set(trimData(update));
  26. await entity.save();
  27. return await this.model.findOne(filter, projection).exec();
  28. }
  29. async delete(filter) {
  30. assert(filter);
  31. const { _id, id } = filter;
  32. if (_id || id) {
  33. await this.model.findByIdAndDelete(_id || id).exec();
  34. } else {
  35. await this.model.deleteMany(filter).exec();
  36. }
  37. return "deleted";
  38. }
  39. async fetch(filter, { sort, desc, projection } = {}) {
  40. assert(filter);
  41. const { _id, id } = filter;
  42. if (_id || id) filter = { _id: ObjectId(_id || id) };
  43. // 处理排序
  44. if (sort && isString(sort)) {
  45. sort = { [sort]: desc ? -1 : 1 };
  46. } else if (sort && isArray(sort)) {
  47. sort = sort
  48. .map((f) => ({ [f]: desc ? -1 : 1 }))
  49. .reduce((p, c) => ({ ...p, ...c }), {});
  50. }
  51. return await this.model.findOne(filter, projection).exec();
  52. }
  53. async query(filter, { skip, limit, sort, desc, projection } = {}) {
  54. // 处理排序
  55. if (sort && isString(sort)) {
  56. sort = { [sort]: desc ? -1 : 1 };
  57. } else if (sort && isArray(sort)) {
  58. sort = sort
  59. .map((f) => ({ [f]: desc ? -1 : 1 }))
  60. .reduce((p, c) => ({ ...p, ...c }), {});
  61. }
  62. filter = this.dealFilter(filter);
  63. const rs = await this.model
  64. .find(trimData(filter), projection, { skip, limit, sort })
  65. .exec();
  66. return rs;
  67. }
  68. async count(filter) {
  69. filter = this.dealFilter(filter);
  70. const res = await this.model.countDocuments(trimData(filter)).exec();
  71. return res;
  72. }
  73. async queryAndCount(filter, options) {
  74. filter = this.dealFilter(filter);
  75. const total = await this.count(filter);
  76. if (total === 0) return { total, data: [] };
  77. const rs = await this.query(filter, options);
  78. return { total, data: rs };
  79. }
  80. dealFilter(filter) {
  81. return this.turnFilter(this.turnDateRangeQuery(filter));
  82. }
  83. turnFilter(filter) {
  84. let str = /^%\S*%$/;
  85. let keys = Object.keys(filter);
  86. for (const key of keys) {
  87. let res = key.match(str);
  88. if (res) {
  89. let newKey = key.slice(1, key.length - 1);
  90. if(!ObjectId.isValid(filter[key])) filter[newKey] = new RegExp(filter[key]);
  91. delete filter[key];
  92. }
  93. }
  94. return filter;
  95. }
  96. turnDateRangeQuery(filter) {
  97. const keys = Object.keys(filter);
  98. for (const k of keys) {
  99. if (k.includes("@")) {
  100. const karr = k.split("@");
  101. // 因为是针对处理范围日期,所以必须只有,开始时间和结束时间
  102. if (karr.length === 2) {
  103. const type = karr[1];
  104. if (type === "start")
  105. if (filter[k] && filter[k] !== "") {
  106. filter[karr[0]] = {
  107. ...get(filter, karr[0], {}),
  108. $gte: filter[k],
  109. };
  110. } else {
  111. if (filter[k] && filter[k] !== '') {
  112. filter[karr[0]] = {
  113. ...get(filter, karr[0], {}),
  114. $lte: filter[k],
  115. };
  116. }
  117. delete filter[k];
  118. }
  119. }
  120. }
  121. return filter;
  122. }
  123. }
  124. module.exports.CrudService = CrudService;