counter.js 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /**
  2. * Created by Tony on 2017/3/21.
  3. */
  4. var mongoose = require('mongoose');
  5. var dbm = require("../../config/db/db_manager");
  6. var projectdb = dbm.getCfgConnection("scConstruct");
  7. var Schema = mongoose.Schema;
  8. var counterSchema = new Schema({
  9. _id: String,
  10. sequence_value: Number
  11. });
  12. counterSchema.statics.findAndModify = function (query, sort, doc, options, callback) {
  13. return this.collection.findAndModify(query, sort, doc, options, callback);
  14. };
  15. var counterModel = projectdb.model("counters", counterSchema);
  16. // All counter Must predefine in DB
  17. const COUNTER_MODULE_NAME = {
  18. project: 'projects',
  19. user: 'users',
  20. bills: 'bills',
  21. rations: 'rations',
  22. GLJ: 'glj',
  23. rationMap: 'rationMaps',
  24. rationTree: 'rationChapterTrees',
  25. report: 'rptTemplates',
  26. fee: 'fees',
  27. unitPriceFile: 'unitPriceFile',
  28. unitPriceGLJ: 'unitPriceGLJ',
  29. template_bills: 'temp_bills',
  30. stdGljLib: 'stdGljLib',
  31. billsLib: 'billsLib',
  32. billsLib_jobs: 'billsLib_jobs',
  33. billsLib_items: 'billsLib_items',
  34. coeList: 'coeList'
  35. }
  36. /*const PROJECT_COUNTER = 'projects', USER_COUNTER = 'users', BILL_COUNTER = 'bills', RATION_COUNTER = 'rations',
  37. REPORT_COUNTER = 'rptTemplates', FEE_COUNTER = 'fees'*/
  38. var counterDAO = function(){};
  39. /*
  40. * callback = function (err, result) {
  41. * result.value.sequence_value Ϊ�޸ĺ��id
  42. * }
  43. */
  44. counterDAO.prototype.getIDAfterCount = async function(moduleName, stepCount, callback = null) {
  45. var sc = stepCount;
  46. if (isNaN(stepCount) || (stepCount < 0)) {
  47. sc = 1;
  48. } else if (!(/^-?\d+$/.test(stepCount))) {
  49. sc = Math.round(stepCount + 0.5);
  50. }
  51. if (callback === null) {
  52. return await counterModel.findAndModify({_id: moduleName}, [], { $inc: { sequence_value: sc } }, {'new':true});
  53. } else {
  54. counterModel.findAndModify({_id: moduleName}, [], { $inc: { sequence_value: sc } }, {'new':true}, callback);
  55. }
  56. }
  57. counterDAO.prototype.getCurrentID = function(moduleName, callback) {
  58. if (callback) {
  59. counterModel.findOne({_id: moduleName}).exec()
  60. .then(function(result, err) {
  61. if (callback) {
  62. callback(result, err);
  63. }
  64. }
  65. );
  66. return null;
  67. } else {
  68. var rst = counterModel.findOne({_id: moduleName}).exec() ;
  69. return rst;
  70. }
  71. }
  72. module.exports = {
  73. counterDAO: new counterDAO(),
  74. moduleName: COUNTER_MODULE_NAME
  75. };