@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.
- package/README.md +4 -1
- package/dist/cjs/CollectionManager.d.ts +44 -0
- package/dist/cjs/CollectionManager.js +59 -0
- package/dist/cjs/action.d.ts +66 -0
- package/dist/cjs/action.js +193 -0
- package/dist/cjs/client/database.d.ts +72 -0
- package/dist/cjs/client/database.js +145 -0
- package/dist/cjs/client/function.d.ts +5 -0
- package/dist/cjs/client/function.js +32 -0
- package/dist/cjs/client/graph.d.ts +54 -0
- package/dist/cjs/client/graph.js +93 -0
- package/dist/cjs/client/remote.d.ts +16 -0
- package/dist/cjs/client/remote.js +2 -0
- package/dist/cjs/database.d.ts +69 -0
- package/dist/cjs/database.js +110 -0
- package/dist/cjs/executor.d.ts +28 -0
- package/{executor.js → dist/cjs/executor.js} +47 -54
- package/dist/cjs/file/find.d.ts +11 -0
- package/dist/cjs/file/find.js +80 -0
- package/dist/cjs/file/index.d.ts +3 -0
- package/dist/cjs/file/index.js +25 -0
- package/dist/cjs/file/remove.d.ts +7 -0
- package/dist/cjs/file/remove.js +61 -0
- package/dist/cjs/file/update.d.ts +7 -0
- package/dist/cjs/file/update.js +70 -0
- package/dist/cjs/file/utils.d.ts +8 -0
- package/dist/cjs/file/utils.js +23 -0
- package/dist/cjs/format.d.ts +18 -0
- package/dist/cjs/format.js +36 -0
- package/dist/cjs/gen.d.ts +5 -0
- package/dist/cjs/gen.js +78 -0
- package/dist/cjs/graph.d.ts +47 -0
- package/dist/cjs/graph.js +90 -0
- package/dist/cjs/index.d.ts +13 -0
- package/dist/cjs/index.js +18 -0
- package/dist/cjs/relation.d.ts +64 -0
- package/{relation.js → dist/cjs/relation.js} +26 -45
- package/dist/cjs/types/Id.d.ts +3 -0
- package/dist/cjs/types/Id.js +2 -0
- package/dist/cjs/types/arg.d.ts +12 -0
- package/dist/cjs/types/arg.js +2 -0
- package/dist/cjs/types/data.d.ts +4 -0
- package/dist/cjs/types/data.js +2 -0
- package/dist/cjs/types/options.d.ts +12 -0
- package/dist/cjs/types/options.js +2 -0
- package/dist/cjs/types/searchOpts.d.ts +61 -0
- package/dist/cjs/types/searchOpts.js +8 -0
- package/dist/cjs/types/types.d.ts +6 -0
- package/dist/cjs/types/types.js +2 -0
- package/dist/cjs/types/updater.d.ts +26 -0
- package/dist/cjs/types/updater.js +5 -0
- package/dist/cjs/utils/hasFields.d.ts +8 -0
- package/dist/cjs/utils/hasFields.js +22 -0
- package/dist/cjs/utils/hasFieldsAdvanced.d.ts +5 -0
- package/dist/cjs/utils/hasFieldsAdvanced.js +182 -0
- package/dist/cjs/utils/updateFindObject.d.ts +11 -0
- package/dist/cjs/utils/updateFindObject.js +32 -0
- package/dist/cjs/utils/updateObject.d.ts +7 -0
- package/dist/cjs/utils/updateObject.js +148 -0
- package/dist/esm/CollectionManager.d.ts +44 -0
- package/dist/esm/CollectionManager.js +57 -0
- package/dist/esm/action.d.ts +66 -0
- package/dist/esm/action.js +188 -0
- package/dist/esm/client/database.d.ts +72 -0
- package/dist/esm/client/database.js +140 -0
- package/dist/esm/client/function.d.ts +5 -0
- package/dist/esm/client/function.js +30 -0
- package/dist/esm/client/graph.d.ts +54 -0
- package/dist/esm/client/graph.js +88 -0
- package/dist/esm/client/remote.d.ts +16 -0
- package/dist/esm/client/remote.js +1 -0
- package/dist/esm/database.d.ts +69 -0
- package/dist/esm/database.js +105 -0
- package/dist/esm/executor.d.ts +28 -0
- package/dist/esm/executor.js +45 -0
- package/dist/esm/file/find.d.ts +11 -0
- package/dist/esm/file/find.js +73 -0
- package/dist/esm/file/index.d.ts +3 -0
- package/{file → dist/esm/file}/index.js +1 -1
- package/dist/esm/file/remove.d.ts +7 -0
- package/dist/esm/file/remove.js +56 -0
- package/dist/esm/file/update.d.ts +7 -0
- package/dist/esm/file/update.js +65 -0
- package/dist/esm/file/utils.d.ts +8 -0
- package/{file → dist/esm/file}/utils.js +3 -11
- package/dist/esm/format.d.ts +18 -0
- package/{format.js → dist/esm/format.js} +29 -29
- package/dist/esm/gen.d.ts +5 -0
- package/dist/esm/gen.js +75 -0
- package/dist/esm/graph.d.ts +47 -0
- package/dist/esm/graph.js +85 -0
- package/dist/esm/index.d.ts +13 -0
- package/dist/esm/index.js +7 -0
- package/dist/esm/relation.d.ts +64 -0
- package/dist/esm/relation.js +65 -0
- package/dist/esm/types/Id.d.ts +3 -0
- package/dist/esm/types/Id.js +1 -0
- package/dist/esm/types/arg.d.ts +12 -0
- package/dist/esm/types/arg.js +1 -0
- package/dist/esm/types/data.d.ts +4 -0
- package/dist/esm/types/data.js +1 -0
- package/dist/esm/types/options.d.ts +12 -0
- package/dist/esm/types/options.js +1 -0
- package/dist/esm/types/searchOpts.d.ts +61 -0
- package/dist/esm/types/searchOpts.js +7 -0
- package/dist/esm/types/types.d.ts +6 -0
- package/dist/esm/types/types.js +1 -0
- package/dist/esm/types/updater.d.ts +26 -0
- package/dist/esm/types/updater.js +4 -0
- package/dist/esm/utils/hasFields.d.ts +8 -0
- package/{utils → dist/esm/utils}/hasFields.js +4 -4
- package/dist/esm/utils/hasFieldsAdvanced.d.ts +5 -0
- package/dist/esm/utils/hasFieldsAdvanced.js +176 -0
- package/dist/esm/utils/updateFindObject.d.ts +11 -0
- package/{utils → dist/esm/utils}/updateFindObject.js +11 -16
- package/dist/esm/utils/updateObject.d.ts +7 -0
- package/dist/esm/utils/updateObject.js +145 -0
- package/package.json +52 -36
- package/CollectionManager.js +0 -119
- package/action.js +0 -258
- package/database.d.ts +0 -44
- package/database.js +0 -203
- package/docs/database.md +0 -140
- package/docs/graph.md +0 -86
- package/docs/relation.md +0 -51
- package/docs/remote.md +0 -30
- package/docs/remote_server.md +0 -35
- package/docs/search_opts.md +0 -227
- package/file/find.js +0 -89
- package/file/remove.js +0 -74
- package/file/update.js +0 -83
- package/gen.d.ts +0 -1
- package/gen.js +0 -97
- package/graph.d.ts +0 -27
- package/graph.js +0 -140
- package/index.d.ts +0 -7
- package/index.js +0 -15
- package/relation.d.ts +0 -23
- package/remote/client/database.d.ts +0 -41
- package/remote/client/database.js +0 -228
- package/remote/client/graph.d.ts +0 -31
- package/remote/client/graph.js +0 -148
- package/remote/server/auth.js +0 -100
- package/remote/server/db.js +0 -197
- package/remote/server/function.js +0 -43
- package/remote/server/graph.js +0 -136
- package/remote/server/gui/css/main.css +0 -130
- package/remote/server/gui/css/scrool.css +0 -81
- package/remote/server/gui/css/style.css +0 -61
- package/remote/server/gui/favicon.svg +0 -12
- package/remote/server/gui/html/data.html +0 -15
- package/remote/server/gui/html/main.html +0 -46
- package/remote/server/gui/html/nav.html +0 -25
- package/remote/server/gui/html/popup.html +0 -51
- package/remote/server/gui/index.html +0 -49
- package/remote/server/gui/js/api.js +0 -166
- package/remote/server/gui/js/index.js +0 -17
- package/remote/server/gui/js/loadHTML.js +0 -16
- package/remote/server/gui/js/popUp.js +0 -72
- package/remote/server/gui/js/queryApi.js +0 -51
- package/remote/server/gui/js/queryDb.js +0 -79
- package/remote/server/gui/js/queryGraph.js +0 -144
- package/remote/server/gui/js/render.js +0 -64
- package/remote/server/gui/js/templates.js +0 -31
- package/remote/server/gui/js/utils.js +0 -36
- package/remote/server/gui/js/vars.js +0 -9
- package/remote/server/gui/libs/core.js +0 -176
- package/remote/server/gui/libs/d3.v7.min.js +0 -2
- package/remote/server/gui/libs/handlebars.min.js +0 -29
- package/remote/server/gui/libs/json5.min.js +0 -1
- package/remote/server/index.js +0 -63
- package/remote/server/initDataBases.js +0 -20
- package/remote/server/pathUtils.js +0 -7
- package/remote/server/secret.js +0 -23
- package/remote/serverMgmt/index.js +0 -86
- package/test/hasFieldsAdvanced.test.js +0 -70
- package/utils/hasFieldsAdvanced.js +0 -184
- 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
|
-
|
|
14
|
-
|
|
15
|
-
|
|
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))
|
|
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))
|
|
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
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
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
|
}
|
package/CollectionManager.js
DELETED
|
@@ -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;
|