@wxn0brp/db 0.0.5 → 0.0.7

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.
Files changed (178) hide show
  1. package/README.md +4 -1
  2. package/dist/cjs/CollectionManager.d.ts +44 -0
  3. package/dist/cjs/CollectionManager.js +59 -0
  4. package/dist/cjs/action.d.ts +66 -0
  5. package/dist/cjs/action.js +193 -0
  6. package/dist/cjs/client/database.d.ts +72 -0
  7. package/dist/cjs/client/database.js +145 -0
  8. package/dist/cjs/client/function.d.ts +5 -0
  9. package/dist/cjs/client/function.js +32 -0
  10. package/dist/cjs/client/graph.d.ts +54 -0
  11. package/dist/cjs/client/graph.js +93 -0
  12. package/dist/cjs/client/remote.d.ts +16 -0
  13. package/dist/cjs/client/remote.js +2 -0
  14. package/dist/cjs/database.d.ts +69 -0
  15. package/dist/cjs/database.js +110 -0
  16. package/dist/cjs/executor.d.ts +28 -0
  17. package/{executor.js → dist/cjs/executor.js} +47 -54
  18. package/dist/cjs/file/find.d.ts +11 -0
  19. package/dist/cjs/file/find.js +80 -0
  20. package/dist/cjs/file/index.d.ts +3 -0
  21. package/dist/cjs/file/index.js +25 -0
  22. package/dist/cjs/file/remove.d.ts +7 -0
  23. package/dist/cjs/file/remove.js +61 -0
  24. package/dist/cjs/file/update.d.ts +7 -0
  25. package/dist/cjs/file/update.js +70 -0
  26. package/dist/cjs/file/utils.d.ts +8 -0
  27. package/dist/cjs/file/utils.js +23 -0
  28. package/dist/cjs/format.d.ts +18 -0
  29. package/dist/cjs/format.js +36 -0
  30. package/dist/cjs/gen.d.ts +5 -0
  31. package/dist/cjs/gen.js +78 -0
  32. package/dist/cjs/graph.d.ts +47 -0
  33. package/dist/cjs/graph.js +90 -0
  34. package/dist/cjs/index.d.ts +13 -0
  35. package/dist/cjs/index.js +18 -0
  36. package/dist/cjs/relation.d.ts +64 -0
  37. package/{relation.js → dist/cjs/relation.js} +26 -45
  38. package/dist/cjs/types/Id.d.ts +3 -0
  39. package/dist/cjs/types/Id.js +2 -0
  40. package/dist/cjs/types/arg.d.ts +12 -0
  41. package/dist/cjs/types/arg.js +2 -0
  42. package/dist/cjs/types/data.d.ts +4 -0
  43. package/dist/cjs/types/data.js +2 -0
  44. package/dist/cjs/types/options.d.ts +12 -0
  45. package/dist/cjs/types/options.js +2 -0
  46. package/dist/cjs/types/searchOpts.d.ts +61 -0
  47. package/dist/cjs/types/searchOpts.js +8 -0
  48. package/dist/cjs/types/types.d.ts +6 -0
  49. package/dist/cjs/types/types.js +2 -0
  50. package/dist/cjs/types/updater.d.ts +26 -0
  51. package/dist/cjs/types/updater.js +5 -0
  52. package/dist/cjs/utils/hasFields.d.ts +8 -0
  53. package/dist/cjs/utils/hasFields.js +22 -0
  54. package/dist/cjs/utils/hasFieldsAdvanced.d.ts +5 -0
  55. package/dist/cjs/utils/hasFieldsAdvanced.js +182 -0
  56. package/dist/cjs/utils/updateFindObject.d.ts +11 -0
  57. package/dist/cjs/utils/updateFindObject.js +32 -0
  58. package/dist/cjs/utils/updateObject.d.ts +7 -0
  59. package/dist/cjs/utils/updateObject.js +148 -0
  60. package/dist/esm/CollectionManager.d.ts +44 -0
  61. package/dist/esm/CollectionManager.js +57 -0
  62. package/dist/esm/action.d.ts +66 -0
  63. package/dist/esm/action.js +188 -0
  64. package/dist/esm/client/database.d.ts +72 -0
  65. package/dist/esm/client/database.js +140 -0
  66. package/dist/esm/client/function.d.ts +5 -0
  67. package/dist/esm/client/function.js +30 -0
  68. package/dist/esm/client/graph.d.ts +54 -0
  69. package/dist/esm/client/graph.js +88 -0
  70. package/dist/esm/client/remote.d.ts +16 -0
  71. package/dist/esm/client/remote.js +1 -0
  72. package/dist/esm/database.d.ts +69 -0
  73. package/dist/esm/database.js +105 -0
  74. package/dist/esm/executor.d.ts +28 -0
  75. package/dist/esm/executor.js +45 -0
  76. package/dist/esm/file/find.d.ts +11 -0
  77. package/dist/esm/file/find.js +73 -0
  78. package/dist/esm/file/index.d.ts +3 -0
  79. package/{file → dist/esm/file}/index.js +1 -1
  80. package/dist/esm/file/remove.d.ts +7 -0
  81. package/dist/esm/file/remove.js +56 -0
  82. package/dist/esm/file/update.d.ts +7 -0
  83. package/dist/esm/file/update.js +65 -0
  84. package/dist/esm/file/utils.d.ts +8 -0
  85. package/{file → dist/esm/file}/utils.js +3 -11
  86. package/dist/esm/format.d.ts +18 -0
  87. package/{format.js → dist/esm/format.js} +29 -29
  88. package/dist/esm/gen.d.ts +5 -0
  89. package/dist/esm/gen.js +75 -0
  90. package/dist/esm/graph.d.ts +47 -0
  91. package/dist/esm/graph.js +85 -0
  92. package/dist/esm/index.d.ts +13 -0
  93. package/dist/esm/index.js +7 -0
  94. package/dist/esm/relation.d.ts +64 -0
  95. package/dist/esm/relation.js +65 -0
  96. package/dist/esm/types/Id.d.ts +3 -0
  97. package/dist/esm/types/Id.js +1 -0
  98. package/dist/esm/types/arg.d.ts +12 -0
  99. package/dist/esm/types/arg.js +1 -0
  100. package/dist/esm/types/data.d.ts +4 -0
  101. package/dist/esm/types/data.js +1 -0
  102. package/dist/esm/types/options.d.ts +12 -0
  103. package/dist/esm/types/options.js +1 -0
  104. package/dist/esm/types/searchOpts.d.ts +61 -0
  105. package/dist/esm/types/searchOpts.js +7 -0
  106. package/dist/esm/types/types.d.ts +6 -0
  107. package/dist/esm/types/types.js +1 -0
  108. package/dist/esm/types/updater.d.ts +26 -0
  109. package/dist/esm/types/updater.js +4 -0
  110. package/dist/esm/utils/hasFields.d.ts +8 -0
  111. package/{utils → dist/esm/utils}/hasFields.js +4 -4
  112. package/dist/esm/utils/hasFieldsAdvanced.d.ts +5 -0
  113. package/dist/esm/utils/hasFieldsAdvanced.js +176 -0
  114. package/dist/esm/utils/updateFindObject.d.ts +11 -0
  115. package/{utils → dist/esm/utils}/updateFindObject.js +11 -16
  116. package/dist/esm/utils/updateObject.d.ts +7 -0
  117. package/dist/esm/utils/updateObject.js +145 -0
  118. package/package.json +52 -36
  119. package/CollectionManager.js +0 -119
  120. package/action.js +0 -258
  121. package/database.d.ts +0 -44
  122. package/database.js +0 -203
  123. package/docs/database.md +0 -140
  124. package/docs/graph.md +0 -86
  125. package/docs/relation.md +0 -51
  126. package/docs/remote.md +0 -30
  127. package/docs/remote_server.md +0 -35
  128. package/docs/search_opts.md +0 -227
  129. package/file/find.js +0 -89
  130. package/file/remove.js +0 -74
  131. package/file/update.js +0 -83
  132. package/gen.d.ts +0 -1
  133. package/gen.js +0 -97
  134. package/graph.d.ts +0 -27
  135. package/graph.js +0 -140
  136. package/index.d.ts +0 -7
  137. package/index.js +0 -15
  138. package/relation.d.ts +0 -23
  139. package/remote/client/database.d.ts +0 -41
  140. package/remote/client/database.js +0 -228
  141. package/remote/client/graph.d.ts +0 -31
  142. package/remote/client/graph.js +0 -148
  143. package/remote/server/auth.js +0 -100
  144. package/remote/server/db.js +0 -197
  145. package/remote/server/function.js +0 -43
  146. package/remote/server/graph.js +0 -136
  147. package/remote/server/gui/css/main.css +0 -130
  148. package/remote/server/gui/css/scrool.css +0 -81
  149. package/remote/server/gui/css/style.css +0 -61
  150. package/remote/server/gui/favicon.svg +0 -12
  151. package/remote/server/gui/html/data.html +0 -15
  152. package/remote/server/gui/html/main.html +0 -46
  153. package/remote/server/gui/html/nav.html +0 -25
  154. package/remote/server/gui/html/popup.html +0 -51
  155. package/remote/server/gui/index.html +0 -49
  156. package/remote/server/gui/js/api.js +0 -166
  157. package/remote/server/gui/js/index.js +0 -17
  158. package/remote/server/gui/js/loadHTML.js +0 -16
  159. package/remote/server/gui/js/popUp.js +0 -72
  160. package/remote/server/gui/js/queryApi.js +0 -51
  161. package/remote/server/gui/js/queryDb.js +0 -79
  162. package/remote/server/gui/js/queryGraph.js +0 -144
  163. package/remote/server/gui/js/render.js +0 -64
  164. package/remote/server/gui/js/templates.js +0 -31
  165. package/remote/server/gui/js/utils.js +0 -36
  166. package/remote/server/gui/js/vars.js +0 -9
  167. package/remote/server/gui/libs/core.js +0 -176
  168. package/remote/server/gui/libs/d3.v7.min.js +0 -2
  169. package/remote/server/gui/libs/handlebars.min.js +0 -29
  170. package/remote/server/gui/libs/json5.min.js +0 -1
  171. package/remote/server/index.js +0 -63
  172. package/remote/server/initDataBases.js +0 -20
  173. package/remote/server/pathUtils.js +0 -7
  174. package/remote/server/secret.js +0 -23
  175. package/remote/serverMgmt/index.js +0 -86
  176. package/test/hasFieldsAdvanced.test.js +0 -70
  177. package/utils/hasFieldsAdvanced.js +0 -184
  178. package/utils/updateObject.js +0 -15
@@ -0,0 +1,176 @@
1
+ import hasFields from "./hasFields.js";
2
+ /**
3
+ * Checks if an object meets the criteria specified in the fields with operators.
4
+ */
5
+ export default function hasFieldsAdvanced(obj, fields) {
6
+ if (typeof fields !== "object" || fields === null) {
7
+ throw new Error("Fields must be an object");
8
+ }
9
+ if ("$and" in fields) {
10
+ return fields["$and"].every(subFields => hasFieldsAdvanced(obj, subFields));
11
+ }
12
+ if ("$or" in fields) {
13
+ return fields["$or"].some(subFields => hasFieldsAdvanced(obj, subFields));
14
+ }
15
+ // Check various conditions
16
+ if (!checkConditions(obj, fields))
17
+ return false;
18
+ const fieldsSubset = removeAdvancedOperators({ ...fields });
19
+ return hasFields(obj, fieldsSubset);
20
+ }
21
+ function removeAdvancedOperators(fields) {
22
+ const advancedOperators = [
23
+ "and", "or",
24
+ "gt", "lt", "gte", "lte", "in", "nin",
25
+ "exists",
26
+ "type",
27
+ "regex",
28
+ "arrinc", "arrincall", "size",
29
+ "startsWith", "endsWith",
30
+ "between",
31
+ "not",
32
+ "subset"
33
+ ].map(operator => "$" + operator);
34
+ advancedOperators.forEach(operator => delete fields[operator]);
35
+ return fields;
36
+ }
37
+ function checkConditions(obj, fields) {
38
+ return (checkComparison(obj, fields) &&
39
+ checkExistence(obj, fields) &&
40
+ checkType(obj, fields) &&
41
+ checkRegex(obj, fields) &&
42
+ checkArrayConditions(obj, fields) &&
43
+ checkStringConditions(obj, fields) &&
44
+ checkBetween(obj, fields) &&
45
+ checkNot(obj, fields) &&
46
+ checkSubset(obj, fields));
47
+ }
48
+ function checkComparison(obj, fields) {
49
+ const comparisonOperators = ["$gt", "$lt", "$gte", "$lte", "$in", "$nin"];
50
+ for (const operator of comparisonOperators) {
51
+ if (operator in fields) {
52
+ for (const entries of Object.entries(fields[operator])) {
53
+ const [key, value] = entries;
54
+ switch (operator) {
55
+ case "$gt":
56
+ if (!(obj[key] > value))
57
+ return false;
58
+ break;
59
+ case "$lt":
60
+ if (!(obj[key] < value))
61
+ return false;
62
+ break;
63
+ case "$gte":
64
+ if (!(obj[key] >= value))
65
+ return false;
66
+ break;
67
+ case "$lte":
68
+ if (!(obj[key] <= value))
69
+ return false;
70
+ break;
71
+ case "$in":
72
+ if (!value.includes(obj[key]))
73
+ return false;
74
+ break;
75
+ case "$nin":
76
+ if (value.includes(obj[key]))
77
+ return false;
78
+ break;
79
+ }
80
+ }
81
+ }
82
+ }
83
+ return true;
84
+ }
85
+ function checkExistence(obj, fields) {
86
+ if ("$exists" in fields) {
87
+ for (const [key, shouldExist] of Object.entries(fields["$exists"])) {
88
+ if (shouldExist && !(key in obj))
89
+ return false;
90
+ if (!shouldExist && (key in obj))
91
+ return false;
92
+ }
93
+ }
94
+ return true;
95
+ }
96
+ function checkType(obj, fields) {
97
+ if ("$type" in fields) {
98
+ for (const [key, type] of Object.entries(fields["$type"])) {
99
+ if (typeof obj[key] !== type)
100
+ return false;
101
+ }
102
+ }
103
+ return true;
104
+ }
105
+ function checkRegex(obj, fields) {
106
+ if ("$regex" in fields) {
107
+ for (const [key, regex] of Object.entries(fields["$regex"])) {
108
+ if (!regex.test(obj[key]))
109
+ return false;
110
+ }
111
+ }
112
+ return true;
113
+ }
114
+ function checkArrayConditions(obj, fields) {
115
+ if ("$arrinc" in fields) {
116
+ for (const [key, values] of Object.entries(fields["$arrinc"])) {
117
+ if (!Array.isArray(obj[key]) || !values.some(val => obj[key].includes(val)))
118
+ return false;
119
+ }
120
+ }
121
+ if ("$arrincall" in fields) {
122
+ for (const [key, values] of Object.entries(fields["$arrincall"])) {
123
+ if (!Array.isArray(obj[key]) || !values.every(val => obj[key].includes(val)))
124
+ return false;
125
+ }
126
+ }
127
+ if ("$size" in fields) {
128
+ for (const [key, size] of Object.entries(fields["$size"])) {
129
+ if (Array.isArray(obj[key]) || typeof obj[key] === "string") {
130
+ if (obj[key].length !== size)
131
+ return false;
132
+ }
133
+ else {
134
+ return false;
135
+ }
136
+ }
137
+ }
138
+ return true;
139
+ }
140
+ function checkStringConditions(obj, fields) {
141
+ if ("$startsWith" in fields) {
142
+ for (const [key, value] of Object.entries(fields["$startsWith"])) {
143
+ if (typeof obj[key] !== "string" || !obj[key].startsWith(value))
144
+ return false;
145
+ }
146
+ }
147
+ if ("$endsWith" in fields) {
148
+ for (const [key, value] of Object.entries(fields["$endsWith"])) {
149
+ if (typeof obj[key] !== "string" || !obj[key].endsWith(value))
150
+ return false;
151
+ }
152
+ }
153
+ return true;
154
+ }
155
+ function checkBetween(obj, fields) {
156
+ if ("$between" in fields) {
157
+ for (const [key, [min, max]] of Object.entries(fields["$between"])) {
158
+ if (typeof obj[key] !== "number" || obj[key] < min || obj[key] > max)
159
+ return false;
160
+ }
161
+ }
162
+ return true;
163
+ }
164
+ function checkNot(obj, fields) {
165
+ if ("$not" in fields) {
166
+ return !hasFieldsAdvanced(obj, fields["$not"]);
167
+ }
168
+ return true;
169
+ }
170
+ function checkSubset(obj, fields) {
171
+ if ("$subset" in fields) {
172
+ const setFields = fields["$subset"];
173
+ return hasFields(obj, setFields);
174
+ }
175
+ return true;
176
+ }
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Updates an object with new values from a findOpts object.
3
+ * @function
4
+ * @param {Object} obj - The object to update.
5
+ * @param {Object} findOpts - An object containing options to update the target object.
6
+ * @param {function} [findOpts.transform] - A function to transform the object before applying the other options.
7
+ * @param {string[]} [findOpts.select] - An array of fields to select from the target object.
8
+ * @param {string[]} [findOpts.exclude] - An array of fields to exclude from the target object.
9
+ * @returns {Object} The updated object.
10
+ */
11
+ export default function updateFindObject(obj: any, findOpts: any): any;
@@ -8,27 +8,22 @@
8
8
  * @param {string[]} [findOpts.exclude] - An array of fields to exclude from the target object.
9
9
  * @returns {Object} The updated object.
10
10
  */
11
- export default function updateFindObject(obj, findOpts){
12
- const {
13
- transform,
14
- select,
15
- exclude,
16
- } = findOpts;
17
-
18
- if(typeof transform === "function") obj = transform(obj);
19
-
20
- if(Array.isArray(exclude)){
11
+ export default function updateFindObject(obj, findOpts) {
12
+ const { transform, select, exclude, } = findOpts;
13
+ if (typeof transform === "function")
14
+ obj = transform(obj);
15
+ if (Array.isArray(exclude)) {
21
16
  exclude.forEach(field => {
22
- if(obj.hasOwnProperty(field)) delete obj[field];
17
+ if (obj.hasOwnProperty(field))
18
+ delete obj[field];
23
19
  });
24
20
  }
25
-
26
- if(Array.isArray(select)){
21
+ if (Array.isArray(select)) {
27
22
  obj = select.reduce((acc, field) => {
28
- if(obj.hasOwnProperty(field)) acc[field] = obj[field];
23
+ if (obj.hasOwnProperty(field))
24
+ acc[field] = obj[field];
29
25
  return acc;
30
26
  }, {});
31
27
  }
32
-
33
28
  return obj;
34
- }
29
+ }
@@ -0,0 +1,7 @@
1
+ import { UpdaterArg } from "../types/updater.js";
2
+ /**
3
+ * Updates an object with new values.
4
+ * @param obj - The object to update.
5
+ * @param fields - An object containing new values to update in the target object.
6
+ */
7
+ export default function updateObjectAdvanced(obj: any, fields: UpdaterArg | UpdaterArg[]): any;
@@ -0,0 +1,145 @@
1
+ /**
2
+ * Updates an object with new values.
3
+ * @param obj - The object to update.
4
+ * @param fields - An object containing new values to update in the target object.
5
+ */
6
+ export default function updateObjectAdvanced(obj, fields) {
7
+ if (typeof fields !== "object" || fields === null) {
8
+ throw new Error("Fields must be an object or object array");
9
+ }
10
+ const fieldsArray = Array.isArray(fields) ? fields : [fields];
11
+ for (const field of fieldsArray) {
12
+ if (typeof field !== "object" || field === null) {
13
+ throw new Error("Fields must be an object or object array");
14
+ }
15
+ updateAdvanced(obj, field);
16
+ const fieldsSubset = removeAdvancedOperators({ ...field });
17
+ updateObject(obj, fieldsSubset);
18
+ }
19
+ return obj;
20
+ }
21
+ function updateAdvanced(obj, fields) {
22
+ updateArray(obj, fields);
23
+ updateNested(obj, fields);
24
+ updateIncrement(obj, fields);
25
+ updateUnset(obj, fields);
26
+ updateRename(obj, fields);
27
+ }
28
+ function removeAdvancedOperators(fields) {
29
+ const advancedOperators = [
30
+ "push", "pushset", "pull", "pullall",
31
+ "inc", "dec",
32
+ "unset",
33
+ "merge",
34
+ "rename"
35
+ ].map(operator => "$" + operator);
36
+ advancedOperators.forEach(operator => delete fields[operator]);
37
+ return fields;
38
+ }
39
+ function updateArray(obj, fields) {
40
+ if ("$push" in fields) {
41
+ for (const [key, value] of Object.entries(fields["$push"])) {
42
+ if (Array.isArray(obj[key])) {
43
+ obj[key].push(value);
44
+ }
45
+ else {
46
+ obj[key] = [value];
47
+ }
48
+ }
49
+ }
50
+ if ("$pushset" in fields) {
51
+ for (const [key, value] of Object.entries(fields["$pushset"])) {
52
+ if (Array.isArray(obj[key])) {
53
+ obj[key].push(value);
54
+ }
55
+ else {
56
+ obj[key] = [value];
57
+ }
58
+ obj[key] = [...new Set(obj[key])];
59
+ }
60
+ }
61
+ if ("$pull" in fields) {
62
+ for (const [key, value] of Object.entries(fields["$pull"])) {
63
+ if (Array.isArray(obj[key])) {
64
+ obj[key] = obj[key].filter(item => item !== value);
65
+ }
66
+ }
67
+ }
68
+ if ("$pullall" in fields) {
69
+ for (const [key, values] of Object.entries(fields["$pullall"])) {
70
+ if (Array.isArray(obj[key])) {
71
+ obj[key] = obj[key].filter(item => !values.includes(item));
72
+ }
73
+ }
74
+ }
75
+ }
76
+ function updateNested(obj, fields) {
77
+ if ("$merge" in fields) {
78
+ for (const [key, value] of Object.entries(fields["$merge"])) {
79
+ if (typeof obj[key] === "object" && typeof value === "object") {
80
+ obj[key] = { ...obj[key], ...value };
81
+ }
82
+ else {
83
+ obj[key] = value;
84
+ }
85
+ }
86
+ }
87
+ }
88
+ function updateIncrement(obj, fields) {
89
+ if ("$inc" in fields) {
90
+ for (const [key, value] of Object.entries(fields["$inc"])) {
91
+ if (typeof obj[key] === "number" && typeof value === "number") {
92
+ obj[key] += value;
93
+ }
94
+ else if (!(key in obj)) {
95
+ obj[key] = value;
96
+ }
97
+ else {
98
+ throw new Error(`Cannot increment non-numeric value at key: ${key}`);
99
+ }
100
+ }
101
+ }
102
+ if ("$dec" in fields) {
103
+ for (const [key, value] of Object.entries(fields["$dec"])) {
104
+ if (typeof obj[key] === "number" && typeof value === "number") {
105
+ obj[key] -= value;
106
+ }
107
+ else if (!(key in obj)) {
108
+ obj[key] = value;
109
+ }
110
+ else {
111
+ throw new Error(`Cannot decrement non-numeric value at key: ${key}`);
112
+ }
113
+ }
114
+ }
115
+ }
116
+ function updateUnset(obj, fields) {
117
+ if ("$unset" in fields) {
118
+ for (const key of Object.keys(fields["$unset"])) {
119
+ delete obj[key];
120
+ }
121
+ }
122
+ }
123
+ function updateRename(obj, fields) {
124
+ if ("$rename" in fields) {
125
+ for (const [oldKey, newKey] of Object.entries(fields["$rename"])) {
126
+ if (oldKey in obj) {
127
+ obj[newKey] = obj[oldKey];
128
+ delete obj[oldKey];
129
+ }
130
+ }
131
+ }
132
+ }
133
+ /**
134
+ * Updates an object with new values.
135
+ * @param obj - The object to update.
136
+ * @param newVal - An object containing new values to update in the target object.
137
+ */
138
+ function updateObject(obj, newVal) {
139
+ for (let key in newVal) {
140
+ if (newVal.hasOwnProperty(key)) {
141
+ obj[key] = newVal[key];
142
+ }
143
+ }
144
+ return obj;
145
+ }
package/package.json CHANGED
@@ -1,38 +1,54 @@
1
1
  {
2
- "name": "@wxn0brp/db",
3
- "version": "0.0.5",
4
- "main": "index.js",
5
- "description": "A simple file-based database management system with support for CRUD operations, custom queries, and graph structures.",
6
- "homepage": "https://github.com/wxn0brP/database",
7
- "repository": {
8
- "type": "git",
9
- "url": "https://github.com/wxn0brP/database.git"
10
- },
11
- "keywords": [
12
- "database",
13
- "file-based",
14
- "CRUD",
15
- "graph",
16
- "query"
17
- ],
18
- "author": "wxn0brP",
19
- "license": "MIT",
20
- "type": "module",
21
- "dependencies": {
22
- "got": "^14.4.2",
23
- "json5": "^2.2.3",
24
- "readline": "^1.3.0"
25
- },
26
- "devDependencies": {
27
- "ava": "^6.2.0",
28
- "body-parser": "^1.20.3",
29
- "cors": "^2.8.5",
30
- "dotenv": "^16.4.5",
31
- "express": "^4.21.1",
32
- "jwt-simple": "^0.5.6",
33
- "node-cache": "^5.1.2"
34
- },
35
- "scripts": {
36
- "postversion": "git push && git push --tags"
37
- }
2
+ "name": "@wxn0brp/db",
3
+ "version": "0.0.7",
4
+ "main": "dist/esm/index.js",
5
+ "types": "dist/esm/index.d.ts",
6
+ "description": "A simple file-based database management system with support for CRUD operations, custom queries, and graph structures.",
7
+ "homepage": "https://github.com/wxn0brP/database",
8
+ "repository": {
9
+ "type": "git",
10
+ "url": "https://github.com/wxn0brP/database.git"
11
+ },
12
+ "keywords": [
13
+ "database",
14
+ "file-based",
15
+ "CRUD",
16
+ "graph",
17
+ "query"
18
+ ],
19
+ "author": "wxn0brP",
20
+ "license": "MIT",
21
+ "type": "module",
22
+ "dependencies": {
23
+ "got": "^14.4.2",
24
+ "json5": "^2.2.3",
25
+ "readline": "^1.3.0"
26
+ },
27
+ "devDependencies": {
28
+ "@types/got": "^9.6.12",
29
+ "@types/node": "^22.10.2",
30
+ "typescript": "^5.7.2"
31
+ },
32
+ "scripts": {
33
+ "build:esm": "tsc",
34
+ "build:cjs": "tsc --module CommonJS --outDir ./dist/cjs --declarationDir ./dist/cjs",
35
+ "build": "npm run build:esm && npm run build:cjs",
36
+ "prepare": "npm run build",
37
+ "postversion": "git push && git push --tags"
38
+ },
39
+ "files": [
40
+ "dist"
41
+ ],
42
+ "exports": {
43
+ ".": {
44
+ "import": "./dist/esm/index.js",
45
+ "require": "./dist/cjs/index.js",
46
+ "types": "./dist/esm/index.d.ts"
47
+ },
48
+ "./*": {
49
+ "import": "./dist/esm/*",
50
+ "require": "./dist/cjs/*",
51
+ "types": "./dist/esm/*"
52
+ }
53
+ }
38
54
  }
@@ -1,119 +0,0 @@
1
- class CollectionManager{
2
- constructor(db, collection){
3
- this.db = db;
4
- this.collection = collection;
5
- }
6
-
7
- /**
8
- * Add data to a database.
9
- *
10
- * @async
11
- * @function
12
- * @param {Object} data - The data to add.
13
- * @param {boolean} id_gen - Whether to generate an ID for the entry. Default is true.
14
- * @returns {Promise<Object>} A Promise that resolves with the added data.
15
- */
16
- async add(data, id_gen=true){
17
- return await this.db.add(this.collection, data, id_gen);
18
- }
19
-
20
- /**
21
- * Find data in a database.
22
- *
23
- * @async
24
- * @function
25
- * @param {function|Object} search - The query. It can be an object or a function.
26
- * @param {Object} context - The context object (for functions).
27
- * @param {Object} options - The options for the search.
28
- * @param {number} options.max - The maximum number of entries to return. Default is -1, meaning no limit.
29
- * @param {boolean} options.reverse - Whether to reverse the order of returned entries. Default is false.
30
- * @returns {Promise<Array<Object>>} A Promise that resolves with the matching data.
31
- */
32
- async find(search, context={}, options={}){
33
- return await this.db.find(this.collection, search, context, options);
34
- }
35
-
36
- /**
37
- * Find one data entry in a database.
38
- *
39
- * @async
40
- * @function
41
- * @param {function|Object} search - The query. It can be an object or a function.
42
- * @param {Object} context - The context object (for functions).
43
- * @returns {Promise<Object|null>} A Promise that resolves with the first matching data entry.
44
- */
45
- async findOne(search, context={}){
46
- return await this.db.findOne(this.collection, search, context);
47
- }
48
-
49
- /**
50
- * Update data in a database.
51
- *
52
- * @async
53
- * @function
54
- * @param {function|Object} search - The query. It can be an object or a function.
55
- * @param {function|Object} arg - Update arguments.
56
- * @param {Object} context - The context object (for functions).
57
- * @returns {Promise<boolean>} A Promise that resolves when the data is updated.
58
- */
59
- async update(search, arg, context={}){
60
- return await this.db.update(this.collection, search, arg, context);
61
- }
62
-
63
- /**
64
- * Update one data entry in a database.
65
- *
66
- * @async
67
- * @function
68
- * @param {function|Object} search - The query. It can be an object or a function.
69
- * @param {function|Object} arg - The query.
70
- * @param {Object} context - The context object (for functions).
71
- * @returns {Promise<boolean>} A Promise that resolves when the data entry is updated.
72
- */
73
- async updateOne(search, arg, context={}){
74
- return await this.db.updateOne(this.collection, search, arg, context);
75
- }
76
-
77
- /**
78
- * Remove data from a database.
79
- *
80
- * @async
81
- * @function
82
- * @param {function|Object} search - The query. It can be an object or a function.
83
- * @param {Object} context - The context object (for functions).
84
- * @returns {Promise<boolean>} A Promise that resolves when the data is removed.
85
- */
86
-
87
- async remove(search, context={}){
88
- return await this.db.remove(this.collection, search, context);
89
- }
90
-
91
- /**
92
- * Remove one data entry from a database.
93
- *
94
- * @async
95
- * @function
96
- * @param {function|Object} search - The query. It can be an object or a function.
97
- * @param {Object} context - The context object (for functions).
98
- * @returns {Promise<boolean>} A Promise that resolves when the data entry is removed.
99
- */
100
- async removeOne(search, context={}){
101
- return await this.db.removeOne(this.collection, search, context);
102
- }
103
-
104
- /**
105
- * Asynchronously updates one entry in a database or adds a new one if it doesn't exist.
106
- *
107
- * @param {function|Object} search - The query. It can be an object or a function.
108
- * @param {function|Object} arg - The search criteria for the update.
109
- * @param {function|Object} add_arg - The arguments to be added to the new entry.
110
- * @param {Object} context - The context object (for functions).
111
- * @param {boolean} id_gen - Whether to generate an ID for the entry. Default is true.
112
- * @return {Promise<boolean>} A Promise that resolves to `true` if the entry was updated, or `false` if it was added.
113
- */
114
- async updateOneOrAdd(search, arg, add_arg={}, context={}, id_gen=true){
115
- return await this.db.updateOneOrAdd(this.collection, search, arg, add_arg, context, id_gen);
116
- }
117
- }
118
-
119
- export default CollectionManager;