@push.rocks/smartmongo 2.1.0 → 3.0.0
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/dist_ts/00_commitinfo_data.js +1 -1
- package/dist_ts/index.d.ts +1 -1
- package/dist_ts/index.js +3 -3
- package/dist_ts/tsmdb/engine/AggregationEngine.js +189 -0
- package/dist_ts/tsmdb/engine/IndexEngine.js +376 -0
- package/dist_ts/tsmdb/engine/QueryEngine.js +271 -0
- package/dist_ts/{congodb → tsmdb}/engine/TransactionEngine.d.ts +1 -1
- package/dist_ts/tsmdb/engine/TransactionEngine.js +287 -0
- package/dist_ts/tsmdb/engine/UpdateEngine.js +461 -0
- package/dist_ts/{congodb/errors/CongoErrors.d.ts → tsmdb/errors/TsmdbErrors.d.ts} +16 -16
- package/dist_ts/tsmdb/errors/TsmdbErrors.js +155 -0
- package/dist_ts/{congodb → tsmdb}/index.d.ts +4 -4
- package/dist_ts/tsmdb/index.js +26 -0
- package/dist_ts/{congodb → tsmdb}/server/CommandRouter.d.ts +4 -4
- package/dist_ts/tsmdb/server/CommandRouter.js +132 -0
- package/dist_ts/{congodb/server/CongoServer.d.ts → tsmdb/server/TsmdbServer.d.ts} +6 -6
- package/dist_ts/tsmdb/server/TsmdbServer.js +227 -0
- package/dist_ts/{congodb → tsmdb}/server/WireProtocol.d.ts +1 -1
- package/dist_ts/tsmdb/server/WireProtocol.js +298 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/AdminHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/AdminHandler.js +568 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/AggregateHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/AggregateHandler.js +277 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/DeleteHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/DeleteHandler.js +83 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/FindHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/FindHandler.js +261 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/HelloHandler.d.ts +1 -1
- package/dist_ts/{congodb → tsmdb}/server/handlers/HelloHandler.js +2 -2
- package/dist_ts/{congodb → tsmdb}/server/handlers/IndexHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/IndexHandler.js +183 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/InsertHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/InsertHandler.js +76 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/UpdateHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/UpdateHandler.js +270 -0
- package/dist_ts/tsmdb/server/handlers/index.js +10 -0
- package/dist_ts/{congodb → tsmdb}/server/index.d.ts +2 -2
- package/dist_ts/tsmdb/server/index.js +7 -0
- package/dist_ts/{congodb → tsmdb}/storage/FileStorageAdapter.d.ts +2 -2
- package/dist_ts/tsmdb/storage/FileStorageAdapter.js +396 -0
- package/dist_ts/{congodb → tsmdb}/storage/IStorageAdapter.d.ts +2 -2
- package/dist_ts/{congodb → tsmdb}/storage/IStorageAdapter.js +1 -1
- package/dist_ts/{congodb → tsmdb}/storage/MemoryStorageAdapter.d.ts +2 -2
- package/dist_ts/tsmdb/storage/MemoryStorageAdapter.js +367 -0
- package/dist_ts/{congodb → tsmdb}/storage/OpLog.d.ts +1 -1
- package/dist_ts/tsmdb/storage/OpLog.js +221 -0
- package/dist_ts/tsmdb/tsmdb.plugins.js +14 -0
- package/dist_ts/{congodb → tsmdb}/types/interfaces.d.ts +3 -3
- package/dist_ts/{congodb → tsmdb}/types/interfaces.js +1 -1
- package/package.json +1 -1
- package/readme.hints.md +7 -12
- package/readme.md +398 -44
- package/ts/00_commitinfo_data.ts +1 -1
- package/ts/index.ts +2 -2
- package/ts/{congodb → tsmdb}/engine/AggregationEngine.ts +1 -1
- package/ts/{congodb → tsmdb}/engine/IndexEngine.ts +7 -7
- package/ts/{congodb → tsmdb}/engine/QueryEngine.ts +1 -1
- package/ts/{congodb → tsmdb}/engine/TransactionEngine.ts +12 -12
- package/ts/{congodb → tsmdb}/engine/UpdateEngine.ts +1 -1
- package/ts/{congodb/errors/CongoErrors.ts → tsmdb/errors/TsmdbErrors.ts} +34 -34
- package/ts/{congodb → tsmdb}/index.ts +7 -7
- package/ts/{congodb → tsmdb}/server/CommandRouter.ts +5 -5
- package/ts/{congodb/server/CongoServer.ts → tsmdb/server/TsmdbServer.ts} +8 -8
- package/ts/{congodb → tsmdb}/server/WireProtocol.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/AdminHandler.ts +6 -6
- package/ts/{congodb → tsmdb}/server/handlers/AggregateHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/DeleteHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/FindHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/HelloHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/IndexHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/InsertHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/UpdateHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/index.ts +2 -2
- package/ts/{congodb → tsmdb}/storage/FileStorageAdapter.ts +2 -2
- package/ts/{congodb → tsmdb}/storage/IStorageAdapter.ts +2 -2
- package/ts/{congodb → tsmdb}/storage/MemoryStorageAdapter.ts +2 -2
- package/ts/{congodb → tsmdb}/storage/OpLog.ts +1 -1
- package/ts/{congodb → tsmdb}/types/interfaces.ts +3 -3
- package/dist_ts/congodb/congodb.plugins.js +0 -14
- package/dist_ts/congodb/engine/AggregationEngine.js +0 -189
- package/dist_ts/congodb/engine/IndexEngine.js +0 -376
- package/dist_ts/congodb/engine/QueryEngine.js +0 -271
- package/dist_ts/congodb/engine/TransactionEngine.js +0 -287
- package/dist_ts/congodb/engine/UpdateEngine.js +0 -461
- package/dist_ts/congodb/errors/CongoErrors.js +0 -155
- package/dist_ts/congodb/index.js +0 -26
- package/dist_ts/congodb/server/CommandRouter.js +0 -132
- package/dist_ts/congodb/server/CongoServer.js +0 -227
- package/dist_ts/congodb/server/WireProtocol.js +0 -298
- package/dist_ts/congodb/server/handlers/AdminHandler.js +0 -568
- package/dist_ts/congodb/server/handlers/AggregateHandler.js +0 -277
- package/dist_ts/congodb/server/handlers/DeleteHandler.js +0 -83
- package/dist_ts/congodb/server/handlers/FindHandler.js +0 -261
- package/dist_ts/congodb/server/handlers/IndexHandler.js +0 -183
- package/dist_ts/congodb/server/handlers/InsertHandler.js +0 -76
- package/dist_ts/congodb/server/handlers/UpdateHandler.js +0 -270
- package/dist_ts/congodb/server/handlers/index.js +0 -10
- package/dist_ts/congodb/server/index.js +0 -7
- package/dist_ts/congodb/storage/FileStorageAdapter.js +0 -396
- package/dist_ts/congodb/storage/MemoryStorageAdapter.js +0 -367
- package/dist_ts/congodb/storage/OpLog.js +0 -221
- /package/dist_ts/{congodb → tsmdb}/engine/AggregationEngine.d.ts +0 -0
- /package/dist_ts/{congodb → tsmdb}/engine/IndexEngine.d.ts +0 -0
- /package/dist_ts/{congodb → tsmdb}/engine/QueryEngine.d.ts +0 -0
- /package/dist_ts/{congodb → tsmdb}/engine/UpdateEngine.d.ts +0 -0
- /package/dist_ts/{congodb → tsmdb}/server/handlers/index.d.ts +0 -0
- /package/dist_ts/{congodb/congodb.plugins.d.ts → tsmdb/tsmdb.plugins.d.ts} +0 -0
- /package/ts/{congodb → tsmdb}/server/handlers/index.ts +0 -0
- /package/ts/{congodb/congodb.plugins.ts → tsmdb/tsmdb.plugins.ts} +0 -0
|
@@ -0,0 +1,270 @@
|
|
|
1
|
+
import * as plugins from '../../tsmdb.plugins.js';
|
|
2
|
+
import { QueryEngine } from '../../engine/QueryEngine.js';
|
|
3
|
+
import { UpdateEngine } from '../../engine/UpdateEngine.js';
|
|
4
|
+
/**
|
|
5
|
+
* UpdateHandler - Handles update, findAndModify commands
|
|
6
|
+
*/
|
|
7
|
+
export class UpdateHandler {
|
|
8
|
+
async handle(context) {
|
|
9
|
+
const { command } = context;
|
|
10
|
+
// Check findAndModify first since it also has an 'update' field
|
|
11
|
+
if (command.findAndModify) {
|
|
12
|
+
return this.handleFindAndModify(context);
|
|
13
|
+
}
|
|
14
|
+
else if (command.update && typeof command.update === 'string') {
|
|
15
|
+
// 'update' command has collection name as the value
|
|
16
|
+
return this.handleUpdate(context);
|
|
17
|
+
}
|
|
18
|
+
return {
|
|
19
|
+
ok: 0,
|
|
20
|
+
errmsg: 'Unknown update-related command',
|
|
21
|
+
code: 59,
|
|
22
|
+
codeName: 'CommandNotFound',
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Handle update command
|
|
27
|
+
*/
|
|
28
|
+
async handleUpdate(context) {
|
|
29
|
+
const { storage, database, command, documentSequences } = context;
|
|
30
|
+
const collection = command.update;
|
|
31
|
+
if (typeof collection !== 'string') {
|
|
32
|
+
return {
|
|
33
|
+
ok: 0,
|
|
34
|
+
errmsg: 'update command requires a collection name',
|
|
35
|
+
code: 2,
|
|
36
|
+
codeName: 'BadValue',
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
// Get updates from command or document sequences
|
|
40
|
+
let updates = command.updates || [];
|
|
41
|
+
// Check for OP_MSG document sequences
|
|
42
|
+
if (documentSequences && documentSequences.has('updates')) {
|
|
43
|
+
updates = documentSequences.get('updates');
|
|
44
|
+
}
|
|
45
|
+
if (!Array.isArray(updates) || updates.length === 0) {
|
|
46
|
+
return {
|
|
47
|
+
ok: 0,
|
|
48
|
+
errmsg: 'update command requires updates array',
|
|
49
|
+
code: 2,
|
|
50
|
+
codeName: 'BadValue',
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
const ordered = command.ordered !== false;
|
|
54
|
+
const writeErrors = [];
|
|
55
|
+
let totalMatched = 0;
|
|
56
|
+
let totalModified = 0;
|
|
57
|
+
let totalUpserted = 0;
|
|
58
|
+
const upserted = [];
|
|
59
|
+
// Ensure collection exists
|
|
60
|
+
await storage.createCollection(database, collection);
|
|
61
|
+
for (let i = 0; i < updates.length; i++) {
|
|
62
|
+
const updateSpec = updates[i];
|
|
63
|
+
const filter = updateSpec.q || updateSpec.filter || {};
|
|
64
|
+
const update = updateSpec.u || updateSpec.update || {};
|
|
65
|
+
const multi = updateSpec.multi || false;
|
|
66
|
+
const upsert = updateSpec.upsert || false;
|
|
67
|
+
const arrayFilters = updateSpec.arrayFilters;
|
|
68
|
+
try {
|
|
69
|
+
// Get all documents
|
|
70
|
+
let documents = await storage.findAll(database, collection);
|
|
71
|
+
// Apply filter
|
|
72
|
+
let matchingDocs = QueryEngine.filter(documents, filter);
|
|
73
|
+
if (matchingDocs.length === 0 && upsert) {
|
|
74
|
+
// Upsert: create new document
|
|
75
|
+
const newDoc = { _id: new plugins.bson.ObjectId() };
|
|
76
|
+
// Apply filter fields to the new document
|
|
77
|
+
this.applyFilterToDoc(newDoc, filter);
|
|
78
|
+
// Apply update
|
|
79
|
+
const updatedDoc = UpdateEngine.applyUpdate(newDoc, update, arrayFilters);
|
|
80
|
+
// Handle $setOnInsert
|
|
81
|
+
if (update.$setOnInsert) {
|
|
82
|
+
Object.assign(updatedDoc, update.$setOnInsert);
|
|
83
|
+
}
|
|
84
|
+
await storage.insertOne(database, collection, updatedDoc);
|
|
85
|
+
totalUpserted++;
|
|
86
|
+
upserted.push({ index: i, _id: updatedDoc._id });
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
// Update existing documents
|
|
90
|
+
const docsToUpdate = multi ? matchingDocs : matchingDocs.slice(0, 1);
|
|
91
|
+
totalMatched += docsToUpdate.length;
|
|
92
|
+
for (const doc of docsToUpdate) {
|
|
93
|
+
const updatedDoc = UpdateEngine.applyUpdate(doc, update, arrayFilters);
|
|
94
|
+
// Check if document actually changed
|
|
95
|
+
const changed = JSON.stringify(doc) !== JSON.stringify(updatedDoc);
|
|
96
|
+
if (changed) {
|
|
97
|
+
await storage.updateById(database, collection, doc._id, updatedDoc);
|
|
98
|
+
totalModified++;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
catch (error) {
|
|
104
|
+
writeErrors.push({
|
|
105
|
+
index: i,
|
|
106
|
+
code: error.code || 1,
|
|
107
|
+
errmsg: error.message || 'Update failed',
|
|
108
|
+
});
|
|
109
|
+
if (ordered) {
|
|
110
|
+
break;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
const response = {
|
|
115
|
+
ok: 1,
|
|
116
|
+
n: totalMatched + totalUpserted,
|
|
117
|
+
nModified: totalModified,
|
|
118
|
+
};
|
|
119
|
+
if (upserted.length > 0) {
|
|
120
|
+
response.upserted = upserted;
|
|
121
|
+
}
|
|
122
|
+
if (writeErrors.length > 0) {
|
|
123
|
+
response.writeErrors = writeErrors;
|
|
124
|
+
}
|
|
125
|
+
return response;
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Handle findAndModify command
|
|
129
|
+
*/
|
|
130
|
+
async handleFindAndModify(context) {
|
|
131
|
+
const { storage, database, command } = context;
|
|
132
|
+
const collection = command.findAndModify;
|
|
133
|
+
const query = command.query || {};
|
|
134
|
+
const update = command.update;
|
|
135
|
+
const remove = command.remove || false;
|
|
136
|
+
const returnNew = command.new || false;
|
|
137
|
+
const upsert = command.upsert || false;
|
|
138
|
+
const sort = command.sort;
|
|
139
|
+
const fields = command.fields;
|
|
140
|
+
const arrayFilters = command.arrayFilters;
|
|
141
|
+
// Validate - either update or remove, not both
|
|
142
|
+
if (update && remove) {
|
|
143
|
+
return {
|
|
144
|
+
ok: 0,
|
|
145
|
+
errmsg: 'cannot specify both update and remove',
|
|
146
|
+
code: 2,
|
|
147
|
+
codeName: 'BadValue',
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
if (!update && !remove) {
|
|
151
|
+
return {
|
|
152
|
+
ok: 0,
|
|
153
|
+
errmsg: 'either update or remove is required',
|
|
154
|
+
code: 2,
|
|
155
|
+
codeName: 'BadValue',
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
// Ensure collection exists
|
|
159
|
+
await storage.createCollection(database, collection);
|
|
160
|
+
// Get matching documents
|
|
161
|
+
let documents = await storage.findAll(database, collection);
|
|
162
|
+
let matchingDocs = QueryEngine.filter(documents, query);
|
|
163
|
+
// Apply sort if specified
|
|
164
|
+
if (sort) {
|
|
165
|
+
matchingDocs = QueryEngine.sort(matchingDocs, sort);
|
|
166
|
+
}
|
|
167
|
+
const doc = matchingDocs[0];
|
|
168
|
+
if (remove) {
|
|
169
|
+
// Delete operation
|
|
170
|
+
if (!doc) {
|
|
171
|
+
return { ok: 1, value: null };
|
|
172
|
+
}
|
|
173
|
+
await storage.deleteById(database, collection, doc._id);
|
|
174
|
+
let result = doc;
|
|
175
|
+
if (fields) {
|
|
176
|
+
result = QueryEngine.project([doc], fields)[0];
|
|
177
|
+
}
|
|
178
|
+
return {
|
|
179
|
+
ok: 1,
|
|
180
|
+
value: result,
|
|
181
|
+
lastErrorObject: {
|
|
182
|
+
n: 1,
|
|
183
|
+
},
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
else {
|
|
187
|
+
// Update operation
|
|
188
|
+
if (!doc && !upsert) {
|
|
189
|
+
return { ok: 1, value: null };
|
|
190
|
+
}
|
|
191
|
+
let resultDoc;
|
|
192
|
+
let originalDoc = null;
|
|
193
|
+
let isUpsert = false;
|
|
194
|
+
if (doc) {
|
|
195
|
+
// Update existing
|
|
196
|
+
originalDoc = { ...doc };
|
|
197
|
+
resultDoc = UpdateEngine.applyUpdate(doc, update, arrayFilters);
|
|
198
|
+
await storage.updateById(database, collection, doc._id, resultDoc);
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
// Upsert
|
|
202
|
+
isUpsert = true;
|
|
203
|
+
const newDoc = { _id: new plugins.bson.ObjectId() };
|
|
204
|
+
this.applyFilterToDoc(newDoc, query);
|
|
205
|
+
resultDoc = UpdateEngine.applyUpdate(newDoc, update, arrayFilters);
|
|
206
|
+
if (update.$setOnInsert) {
|
|
207
|
+
Object.assign(resultDoc, update.$setOnInsert);
|
|
208
|
+
}
|
|
209
|
+
await storage.insertOne(database, collection, resultDoc);
|
|
210
|
+
}
|
|
211
|
+
// Apply projection
|
|
212
|
+
let returnValue = returnNew ? resultDoc : (originalDoc || null);
|
|
213
|
+
if (returnValue && fields) {
|
|
214
|
+
returnValue = QueryEngine.project([returnValue], fields)[0];
|
|
215
|
+
}
|
|
216
|
+
const response = {
|
|
217
|
+
ok: 1,
|
|
218
|
+
value: returnValue,
|
|
219
|
+
lastErrorObject: {
|
|
220
|
+
n: 1,
|
|
221
|
+
updatedExisting: !isUpsert && doc !== undefined,
|
|
222
|
+
},
|
|
223
|
+
};
|
|
224
|
+
if (isUpsert) {
|
|
225
|
+
response.lastErrorObject.upserted = resultDoc._id;
|
|
226
|
+
}
|
|
227
|
+
return response;
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Apply filter equality conditions to a new document (for upsert)
|
|
232
|
+
*/
|
|
233
|
+
applyFilterToDoc(doc, filter) {
|
|
234
|
+
for (const [key, value] of Object.entries(filter)) {
|
|
235
|
+
// Skip operators
|
|
236
|
+
if (key.startsWith('$'))
|
|
237
|
+
continue;
|
|
238
|
+
// Handle nested paths
|
|
239
|
+
if (typeof value === 'object' && value !== null) {
|
|
240
|
+
// Check if it's an operator
|
|
241
|
+
const valueKeys = Object.keys(value);
|
|
242
|
+
if (valueKeys.some(k => k.startsWith('$'))) {
|
|
243
|
+
// Extract equality value from $eq if present
|
|
244
|
+
if ('$eq' in value) {
|
|
245
|
+
this.setNestedValue(doc, key, value.$eq);
|
|
246
|
+
}
|
|
247
|
+
continue;
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
// Direct value assignment
|
|
251
|
+
this.setNestedValue(doc, key, value);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Set a nested value using dot notation
|
|
256
|
+
*/
|
|
257
|
+
setNestedValue(obj, path, value) {
|
|
258
|
+
const parts = path.split('.');
|
|
259
|
+
let current = obj;
|
|
260
|
+
for (let i = 0; i < parts.length - 1; i++) {
|
|
261
|
+
const part = parts[i];
|
|
262
|
+
if (!(part in current)) {
|
|
263
|
+
current[part] = {};
|
|
264
|
+
}
|
|
265
|
+
current = current[part];
|
|
266
|
+
}
|
|
267
|
+
current[parts[parts.length - 1]] = value;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXBkYXRlSGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3RzL3RzbWRiL3NlcnZlci9oYW5kbGVycy9VcGRhdGVIYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sd0JBQXdCLENBQUM7QUFFbEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzFELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUU1RDs7R0FFRztBQUNILE1BQU0sT0FBTyxhQUFhO0lBQ3hCLEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBd0I7UUFDbkMsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUU1QixnRUFBZ0U7UUFDaEUsSUFBSSxPQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDMUIsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDM0MsQ0FBQzthQUFNLElBQUksT0FBTyxDQUFDLE1BQU0sSUFBSSxPQUFPLE9BQU8sQ0FBQyxNQUFNLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDaEUsb0RBQW9EO1lBQ3BELE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwQyxDQUFDO1FBRUQsT0FBTztZQUNMLEVBQUUsRUFBRSxDQUFDO1lBQ0wsTUFBTSxFQUFFLGdDQUFnQztZQUN4QyxJQUFJLEVBQUUsRUFBRTtZQUNSLFFBQVEsRUFBRSxpQkFBaUI7U0FDNUIsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNLLEtBQUssQ0FBQyxZQUFZLENBQUMsT0FBd0I7UUFDakQsTUFBTSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLEdBQUcsT0FBTyxDQUFDO1FBRWxFLE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUM7UUFDbEMs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
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// Export all command handlers
|
|
2
|
+
export { HelloHandler } from './HelloHandler.js';
|
|
3
|
+
export { InsertHandler } from './InsertHandler.js';
|
|
4
|
+
export { FindHandler } from './FindHandler.js';
|
|
5
|
+
export { UpdateHandler } from './UpdateHandler.js';
|
|
6
|
+
export { DeleteHandler } from './DeleteHandler.js';
|
|
7
|
+
export { AggregateHandler } from './AggregateHandler.js';
|
|
8
|
+
export { IndexHandler } from './IndexHandler.js';
|
|
9
|
+
export { AdminHandler } from './AdminHandler.js';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90cy90c21kYi9zZXJ2ZXIvaGFuZGxlcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsOEJBQThCO0FBRTlCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQyJ9
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export {
|
|
2
|
-
export type {
|
|
1
|
+
export { TsmdbServer } from './TsmdbServer.js';
|
|
2
|
+
export type { ITsmdbServerOptions } from './TsmdbServer.js';
|
|
3
3
|
export { WireProtocol } from './WireProtocol.js';
|
|
4
4
|
export { CommandRouter } from './CommandRouter.js';
|
|
5
5
|
export type { ICommandHandler, IHandlerContext, ICursorState } from './CommandRouter.js';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
// Server module exports
|
|
2
|
+
export { TsmdbServer } from './TsmdbServer.js';
|
|
3
|
+
export { WireProtocol } from './WireProtocol.js';
|
|
4
|
+
export { CommandRouter } from './CommandRouter.js';
|
|
5
|
+
// Export handlers
|
|
6
|
+
export * from './handlers/index.js';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90cy90c21kYi9zZXJ2ZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsd0JBQXdCO0FBRXhCLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUUvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBR25ELGtCQUFrQjtBQUNsQixjQUFjLHFCQUFxQixDQUFDIn0=
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import * as plugins from '../
|
|
1
|
+
import * as plugins from '../tsmdb.plugins.js';
|
|
2
2
|
import type { IStorageAdapter } from './IStorageAdapter.js';
|
|
3
3
|
import type { IStoredDocument, IOpLogEntry, Document } from '../types/interfaces.js';
|
|
4
4
|
/**
|
|
5
|
-
* File-based storage adapter for
|
|
5
|
+
* File-based storage adapter for TsmDB
|
|
6
6
|
* Stores data in JSON files on disk for persistence
|
|
7
7
|
*/
|
|
8
8
|
export declare class FileStorageAdapter implements IStorageAdapter {
|