not-node 5.1.25 → 5.1.28

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "not-node",
3
- "version": "5.1.25",
3
+ "version": "5.1.28",
4
4
  "description": "node complimentary part for client side notFramework.",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -28,3 +28,15 @@ class DBExceptionDocumentIsNotFound extends notRequestError {
28
28
  }
29
29
  }
30
30
  module.exports.DBExceptionDocumentIsNotFound = DBExceptionDocumentIsNotFound;
31
+
32
+ class DBExceptionUpdateOneWasNotSuccessful extends notRequestError {
33
+ constructor({ params = {}, cause = null } = {}) {
34
+ super(
35
+ "DB Update One Was Not Successful",
36
+ { code: 505, ...params },
37
+ cause
38
+ );
39
+ }
40
+ }
41
+ module.exports.DBExceptionUpdateOneWasNotSuccessful =
42
+ DBExceptionUpdateOneWasNotSuccessful;
@@ -536,6 +536,26 @@ module.exports = ({
536
536
  return result;
537
537
  }
538
538
 
539
+ static async listAll({ activeUser, ip, root }) {
540
+ return await this._listAll({
541
+ activeUser,
542
+ ip,
543
+ root,
544
+ action: "listAll",
545
+ shouldOwn: false,
546
+ });
547
+ }
548
+
549
+ static async listAllOwn({ activeUser, ip, root }) {
550
+ return await this._listAll({
551
+ activeUser,
552
+ ip,
553
+ root,
554
+ action: "listAllOwn",
555
+ shouldOwn: true,
556
+ });
557
+ }
558
+
539
559
  static async _listAndCount({
540
560
  query,
541
561
  activeUser,
@@ -599,5 +619,124 @@ module.exports = ({
599
619
  shouldOwn: true,
600
620
  });
601
621
  }
622
+
623
+ static async _list({
624
+ query,
625
+ activeUser,
626
+ ip,
627
+ action,
628
+ root,
629
+ shouldOwn = false,
630
+ }) {
631
+ Log.debug(
632
+ `${MODULE_NAME}//Logic//${MODEL_NAME}//${action}`,
633
+ ip,
634
+ root
635
+ );
636
+ const { skip, size, sorter, filter } = query;
637
+ let populate = getPopulate(action, {
638
+ activeUser,
639
+ ip,
640
+ });
641
+ if (shouldOwn) {
642
+ notFilter.filter.modifyRules(filter, {
643
+ [ownerFieldName]: activeUser._id,
644
+ });
645
+ }
646
+ const result = await getModel().listAndPopulate(
647
+ skip,
648
+ size,
649
+ sorter,
650
+ filter,
651
+ populate
652
+ );
653
+ LogAction({
654
+ action,
655
+ by: activeUser._id,
656
+ role: activeUser.role,
657
+ ip,
658
+ root,
659
+ shouldOwn,
660
+ });
661
+ return result;
662
+ }
663
+
664
+ static async list({ query, activeUser, ip, root }) {
665
+ return await this._list({
666
+ query,
667
+ activeUser,
668
+ ip,
669
+ root,
670
+ action: "list",
671
+ shouldOwn: false,
672
+ });
673
+ }
674
+
675
+ static async listOwn({ query, activeUser, ip, root }) {
676
+ return await this._list({
677
+ query,
678
+ activeUser,
679
+ ip,
680
+ root,
681
+ action: "listOwn",
682
+ shouldOwn: true,
683
+ });
684
+ }
685
+
686
+ static async _count({
687
+ query,
688
+ activeUser,
689
+ ip,
690
+ action,
691
+ root,
692
+ shouldOwn = false,
693
+ }) {
694
+ Log.debug(
695
+ `${MODULE_NAME}//Logic//${MODEL_NAME}//${action}`,
696
+ ip,
697
+ root
698
+ );
699
+ const { filter, search } = query;
700
+ if (shouldOwn) {
701
+ notFilter.filter.modifyRules(filter, {
702
+ [ownerFieldName]: activeUser._id,
703
+ });
704
+ }
705
+ if (search) {
706
+ notFilter.filter.modifyRules(search, filter);
707
+ }
708
+ const result = await getModel().countWithFilter(search || filter);
709
+ LogAction({
710
+ action,
711
+ by: activeUser._id,
712
+ role: activeUser.role,
713
+ ip,
714
+ root,
715
+ shouldOwn,
716
+ });
717
+ return result;
718
+ }
719
+
720
+ static async count({ query, activeUser, ip, root }) {
721
+ return await this._count({
722
+ query,
723
+ activeUser,
724
+ ip,
725
+ root,
726
+ action: "count",
727
+ shouldOwn: false,
728
+ });
729
+ }
730
+
731
+ static async countOwn({ query, activeUser, ip, root }) {
732
+ return await this._count({
733
+ query,
734
+ activeUser,
735
+ ip,
736
+ root,
737
+ action: "countOwn",
738
+ shouldOwn: true,
739
+ });
740
+ }
602
741
  };
603
742
  };
@@ -62,6 +62,24 @@ module.exports = ({ getLogic, before, after }) => {
62
62
  return await getLogic().listAndCountOwn(prepared);
63
63
  }
64
64
 
65
+ static async _list(req, res, next, prepared) {
66
+ prepared.root = true;
67
+ return await getLogic().list(prepared);
68
+ }
69
+
70
+ static async list(req, res, next, prepared) {
71
+ return await getLogic().listOwn(prepared);
72
+ }
73
+
74
+ static async _count(req, res, next, prepared) {
75
+ prepared.root = true;
76
+ return await getLogic().count(prepared);
77
+ }
78
+
79
+ static async count(req, res, next, prepared) {
80
+ return await getLogic().countOwn(prepared);
81
+ }
82
+
65
83
  static async _delete(req, res, next, prepared) {
66
84
  prepared.root = true;
67
85
  return await getLogic().delete(prepared);
@@ -59,9 +59,9 @@ module.exports.formId = formId;
59
59
  **/
60
60
  function secureUpdate(thisModel, which, cmd, opts) {
61
61
  if (typeof thisModel.updateOne === "function") {
62
- return thisModel.updateOne(which, cmd, opts).exec();
62
+ return thisModel.updateOne(which, cmd, opts);
63
63
  } else {
64
- return thisModel.update(which, cmd, opts).exec();
64
+ return thisModel.update(which, cmd, opts);
65
65
  }
66
66
  }
67
67
 
@@ -1,7 +1,8 @@
1
1
  /** @module Model/Routine */
2
2
 
3
3
  const incrementNext = require("./increment");
4
-
4
+ const { DBExceptionUpdateOneWasNotSuccessful } = require("../exceptions/db");
5
+ const { updateResponseSuccess } = require("./utils");
5
6
  class ModelRoutine {
6
7
  static incremental(model) {
7
8
  return model.schema.statics.__incField;
@@ -44,6 +45,7 @@ class ModelRoutine {
44
45
  }
45
46
 
46
47
  static async update(model, filter, data) {
48
+ if ("_id" in data) delete data._id;
47
49
  if (ModelRoutine.versioning(model)) {
48
50
  return ModelRoutine.updateWithVersion(model, filter, data);
49
51
  } else {
@@ -63,13 +65,18 @@ class ModelRoutine {
63
65
  static async updateWithVersion(model, filter, data) {
64
66
  filter.__latest = true;
65
67
  filter.__closed = false;
66
- const item = await model
67
- .updateOne(filter, data, { returnOriginal: false })
68
- .exec();
69
- return model.saveVersion(item._id);
68
+ const result = await model.updateOne(filter, data, {
69
+ returnOriginal: false,
70
+ });
71
+ if (updateResponseSuccess(result, 1)) {
72
+ return model.saveVersion(filter._id);
73
+ } else {
74
+ throw new DBExceptionUpdateOneWasNotSuccessful();
75
+ }
70
76
  }
71
77
 
72
78
  static async updateMany(model, filter, data) {
79
+ if ("_id" in data) delete data._id;
73
80
  if (ModelRoutine.versioning(model)) {
74
81
  return ModelRoutine.updateManyWithVersion(model, filter, data);
75
82
  } else {
@@ -82,13 +89,11 @@ class ModelRoutine {
82
89
  }
83
90
 
84
91
  static async updateManyWithVersion(model, filter, data) {
85
- const list = await model
86
- .find({
87
- __closed: false,
88
- __latest: true,
89
- ...filter,
90
- })
91
- .exec();
92
+ const list = await model.find({
93
+ __closed: false,
94
+ __latest: true,
95
+ ...filter,
96
+ });
92
97
  return await Promise.allSettled(
93
98
  list.map((item) => {
94
99
  return ModelRoutine.updateWithVersion(
@@ -7,7 +7,7 @@ function updateResponseSuccess(res, count = 1) {
7
7
  if (responseList.includes("ok")) {
8
8
  return res.ok === 1 && res.n === count;
9
9
  } else {
10
- return res.matchedCount === count && res.modifiedCount === count;
10
+ return res.matchedCount === count && res.acknowledged;
11
11
  }
12
12
  } else {
13
13
  return false;