@push.rocks/smartmongo 2.2.0 → 4.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.
Files changed (126) hide show
  1. package/dist_ts/00_commitinfo_data.js +1 -1
  2. package/dist_ts/index.d.ts +1 -1
  3. package/dist_ts/index.js +3 -3
  4. package/dist_ts/tsmdb/engine/AggregationEngine.js +189 -0
  5. package/dist_ts/{congodb → tsmdb}/engine/IndexEngine.d.ts +23 -3
  6. package/dist_ts/tsmdb/engine/IndexEngine.js +678 -0
  7. package/dist_ts/tsmdb/engine/QueryEngine.js +271 -0
  8. package/dist_ts/tsmdb/engine/QueryPlanner.d.ts +64 -0
  9. package/dist_ts/tsmdb/engine/QueryPlanner.js +308 -0
  10. package/dist_ts/tsmdb/engine/SessionEngine.d.ts +117 -0
  11. package/dist_ts/tsmdb/engine/SessionEngine.js +232 -0
  12. package/dist_ts/{congodb → tsmdb}/engine/TransactionEngine.d.ts +1 -1
  13. package/dist_ts/tsmdb/engine/TransactionEngine.js +287 -0
  14. package/dist_ts/tsmdb/engine/UpdateEngine.js +461 -0
  15. package/dist_ts/{congodb/errors/CongoErrors.d.ts → tsmdb/errors/TsmdbErrors.d.ts} +16 -16
  16. package/dist_ts/tsmdb/errors/TsmdbErrors.js +155 -0
  17. package/dist_ts/{congodb → tsmdb}/index.d.ts +11 -4
  18. package/dist_ts/tsmdb/index.js +31 -0
  19. package/dist_ts/tsmdb/server/CommandRouter.d.ts +87 -0
  20. package/dist_ts/tsmdb/server/CommandRouter.js +222 -0
  21. package/dist_ts/{congodb/server/CongoServer.d.ts → tsmdb/server/TsmdbServer.d.ts} +6 -6
  22. package/dist_ts/tsmdb/server/TsmdbServer.js +229 -0
  23. package/dist_ts/{congodb → tsmdb}/server/WireProtocol.d.ts +1 -1
  24. package/dist_ts/tsmdb/server/WireProtocol.js +298 -0
  25. package/dist_ts/{congodb → tsmdb}/server/handlers/AdminHandler.d.ts +1 -1
  26. package/dist_ts/tsmdb/server/handlers/AdminHandler.js +668 -0
  27. package/dist_ts/{congodb → tsmdb}/server/handlers/AggregateHandler.d.ts +1 -1
  28. package/dist_ts/tsmdb/server/handlers/AggregateHandler.js +277 -0
  29. package/dist_ts/{congodb → tsmdb}/server/handlers/DeleteHandler.d.ts +1 -1
  30. package/dist_ts/tsmdb/server/handlers/DeleteHandler.js +95 -0
  31. package/dist_ts/{congodb → tsmdb}/server/handlers/FindHandler.d.ts +1 -1
  32. package/dist_ts/tsmdb/server/handlers/FindHandler.js +291 -0
  33. package/dist_ts/{congodb → tsmdb}/server/handlers/HelloHandler.d.ts +1 -1
  34. package/dist_ts/{congodb → tsmdb}/server/handlers/HelloHandler.js +2 -2
  35. package/dist_ts/{congodb → tsmdb}/server/handlers/IndexHandler.d.ts +1 -1
  36. package/dist_ts/tsmdb/server/handlers/IndexHandler.js +183 -0
  37. package/dist_ts/{congodb → tsmdb}/server/handlers/InsertHandler.d.ts +1 -1
  38. package/dist_ts/tsmdb/server/handlers/InsertHandler.js +79 -0
  39. package/dist_ts/{congodb → tsmdb}/server/handlers/UpdateHandler.d.ts +1 -1
  40. package/dist_ts/tsmdb/server/handlers/UpdateHandler.js +296 -0
  41. package/dist_ts/tsmdb/server/handlers/index.js +10 -0
  42. package/dist_ts/{congodb → tsmdb}/server/index.d.ts +2 -2
  43. package/dist_ts/tsmdb/server/index.js +7 -0
  44. package/dist_ts/{congodb → tsmdb}/storage/FileStorageAdapter.d.ts +27 -3
  45. package/dist_ts/tsmdb/storage/FileStorageAdapter.js +465 -0
  46. package/dist_ts/{congodb → tsmdb}/storage/IStorageAdapter.d.ts +7 -2
  47. package/dist_ts/{congodb → tsmdb}/storage/IStorageAdapter.js +1 -1
  48. package/dist_ts/{congodb → tsmdb}/storage/MemoryStorageAdapter.d.ts +3 -2
  49. package/dist_ts/tsmdb/storage/MemoryStorageAdapter.js +378 -0
  50. package/dist_ts/{congodb → tsmdb}/storage/OpLog.d.ts +1 -1
  51. package/dist_ts/tsmdb/storage/OpLog.js +221 -0
  52. package/dist_ts/tsmdb/storage/WAL.d.ts +117 -0
  53. package/dist_ts/tsmdb/storage/WAL.js +286 -0
  54. package/dist_ts/tsmdb/tsmdb.plugins.js +14 -0
  55. package/dist_ts/{congodb → tsmdb}/types/interfaces.d.ts +3 -3
  56. package/dist_ts/{congodb → tsmdb}/types/interfaces.js +1 -1
  57. package/dist_ts/tsmdb/utils/checksum.d.ts +30 -0
  58. package/dist_ts/tsmdb/utils/checksum.js +77 -0
  59. package/dist_ts/tsmdb/utils/index.d.ts +1 -0
  60. package/dist_ts/tsmdb/utils/index.js +2 -0
  61. package/package.json +1 -1
  62. package/readme.hints.md +7 -12
  63. package/readme.md +25 -25
  64. package/ts/00_commitinfo_data.ts +1 -1
  65. package/ts/index.ts +2 -2
  66. package/ts/{congodb → tsmdb}/engine/AggregationEngine.ts +1 -1
  67. package/ts/tsmdb/engine/IndexEngine.ts +798 -0
  68. package/ts/{congodb → tsmdb}/engine/QueryEngine.ts +1 -1
  69. package/ts/tsmdb/engine/QueryPlanner.ts +393 -0
  70. package/ts/tsmdb/engine/SessionEngine.ts +292 -0
  71. package/ts/{congodb → tsmdb}/engine/TransactionEngine.ts +12 -12
  72. package/ts/{congodb → tsmdb}/engine/UpdateEngine.ts +1 -1
  73. package/ts/{congodb/errors/CongoErrors.ts → tsmdb/errors/TsmdbErrors.ts} +34 -34
  74. package/ts/{congodb → tsmdb}/index.ts +16 -7
  75. package/ts/{congodb → tsmdb}/server/CommandRouter.ts +114 -5
  76. package/ts/{congodb/server/CongoServer.ts → tsmdb/server/TsmdbServer.ts} +11 -8
  77. package/ts/{congodb → tsmdb}/server/WireProtocol.ts +1 -1
  78. package/ts/{congodb → tsmdb}/server/handlers/AdminHandler.ts +116 -11
  79. package/ts/{congodb → tsmdb}/server/handlers/AggregateHandler.ts +1 -1
  80. package/ts/{congodb → tsmdb}/server/handlers/DeleteHandler.ts +18 -3
  81. package/ts/{congodb → tsmdb}/server/handlers/FindHandler.ts +43 -14
  82. package/ts/{congodb → tsmdb}/server/handlers/HelloHandler.ts +1 -1
  83. package/ts/{congodb → tsmdb}/server/handlers/IndexHandler.ts +1 -1
  84. package/ts/{congodb → tsmdb}/server/handlers/InsertHandler.ts +7 -1
  85. package/ts/{congodb → tsmdb}/server/handlers/UpdateHandler.ts +34 -5
  86. package/ts/{congodb → tsmdb}/server/index.ts +2 -2
  87. package/ts/{congodb → tsmdb}/storage/FileStorageAdapter.ts +90 -7
  88. package/ts/{congodb → tsmdb}/storage/IStorageAdapter.ts +8 -2
  89. package/ts/{congodb → tsmdb}/storage/MemoryStorageAdapter.ts +14 -2
  90. package/ts/{congodb → tsmdb}/storage/OpLog.ts +1 -1
  91. package/ts/tsmdb/storage/WAL.ts +375 -0
  92. package/ts/{congodb → tsmdb}/types/interfaces.ts +3 -3
  93. package/ts/tsmdb/utils/checksum.ts +88 -0
  94. package/ts/tsmdb/utils/index.ts +1 -0
  95. package/dist_ts/congodb/congodb.plugins.js +0 -14
  96. package/dist_ts/congodb/engine/AggregationEngine.js +0 -189
  97. package/dist_ts/congodb/engine/IndexEngine.js +0 -376
  98. package/dist_ts/congodb/engine/QueryEngine.js +0 -271
  99. package/dist_ts/congodb/engine/TransactionEngine.js +0 -287
  100. package/dist_ts/congodb/engine/UpdateEngine.js +0 -461
  101. package/dist_ts/congodb/errors/CongoErrors.js +0 -155
  102. package/dist_ts/congodb/index.js +0 -26
  103. package/dist_ts/congodb/server/CommandRouter.d.ts +0 -51
  104. package/dist_ts/congodb/server/CommandRouter.js +0 -132
  105. package/dist_ts/congodb/server/CongoServer.js +0 -227
  106. package/dist_ts/congodb/server/WireProtocol.js +0 -298
  107. package/dist_ts/congodb/server/handlers/AdminHandler.js +0 -568
  108. package/dist_ts/congodb/server/handlers/AggregateHandler.js +0 -277
  109. package/dist_ts/congodb/server/handlers/DeleteHandler.js +0 -83
  110. package/dist_ts/congodb/server/handlers/FindHandler.js +0 -261
  111. package/dist_ts/congodb/server/handlers/IndexHandler.js +0 -183
  112. package/dist_ts/congodb/server/handlers/InsertHandler.js +0 -76
  113. package/dist_ts/congodb/server/handlers/UpdateHandler.js +0 -270
  114. package/dist_ts/congodb/server/handlers/index.js +0 -10
  115. package/dist_ts/congodb/server/index.js +0 -7
  116. package/dist_ts/congodb/storage/FileStorageAdapter.js +0 -396
  117. package/dist_ts/congodb/storage/MemoryStorageAdapter.js +0 -367
  118. package/dist_ts/congodb/storage/OpLog.js +0 -221
  119. package/ts/congodb/engine/IndexEngine.ts +0 -479
  120. /package/dist_ts/{congodb → tsmdb}/engine/AggregationEngine.d.ts +0 -0
  121. /package/dist_ts/{congodb → tsmdb}/engine/QueryEngine.d.ts +0 -0
  122. /package/dist_ts/{congodb → tsmdb}/engine/UpdateEngine.d.ts +0 -0
  123. /package/dist_ts/{congodb → tsmdb}/server/handlers/index.d.ts +0 -0
  124. /package/dist_ts/{congodb/congodb.plugins.d.ts → tsmdb/tsmdb.plugins.d.ts} +0 -0
  125. /package/ts/{congodb → tsmdb}/server/handlers/index.ts +0 -0
  126. /package/ts/{congodb/congodb.plugins.ts → tsmdb/tsmdb.plugins.ts} +0 -0
@@ -0,0 +1,678 @@
1
+ import * as plugins from '../tsmdb.plugins.js';
2
+ // Simple B-Tree implementation for range queries
3
+ // Since sorted-btree has ESM/CJS interop issues, we use a simple custom implementation
4
+ class SimpleBTree {
5
+ entries = new Map();
6
+ sortedKeys = [];
7
+ comparator;
8
+ constructor(_unused, comparator) {
9
+ this.comparator = comparator || ((a, b) => {
10
+ if (a < b)
11
+ return -1;
12
+ if (a > b)
13
+ return 1;
14
+ return 0;
15
+ });
16
+ }
17
+ keyToString(key) {
18
+ return JSON.stringify(key);
19
+ }
20
+ set(key, value) {
21
+ const keyStr = this.keyToString(key);
22
+ const existed = this.entries.has(keyStr);
23
+ this.entries.set(keyStr, { key, value });
24
+ if (!existed) {
25
+ // Insert in sorted order
26
+ const idx = this.sortedKeys.findIndex(k => this.comparator(k, key) > 0);
27
+ if (idx === -1) {
28
+ this.sortedKeys.push(key);
29
+ }
30
+ else {
31
+ this.sortedKeys.splice(idx, 0, key);
32
+ }
33
+ }
34
+ return !existed;
35
+ }
36
+ get(key) {
37
+ const entry = this.entries.get(this.keyToString(key));
38
+ return entry?.value;
39
+ }
40
+ delete(key) {
41
+ const keyStr = this.keyToString(key);
42
+ if (this.entries.has(keyStr)) {
43
+ this.entries.delete(keyStr);
44
+ const idx = this.sortedKeys.findIndex(k => this.comparator(k, key) === 0);
45
+ if (idx !== -1) {
46
+ this.sortedKeys.splice(idx, 1);
47
+ }
48
+ return true;
49
+ }
50
+ return false;
51
+ }
52
+ forRange(lowKey, highKey, lowInclusive, highInclusive, callback) {
53
+ for (const key of this.sortedKeys) {
54
+ // Check low bound
55
+ if (lowKey !== undefined) {
56
+ const cmp = this.comparator(key, lowKey);
57
+ if (cmp < 0)
58
+ continue;
59
+ if (cmp === 0 && !lowInclusive)
60
+ continue;
61
+ }
62
+ // Check high bound
63
+ if (highKey !== undefined) {
64
+ const cmp = this.comparator(key, highKey);
65
+ if (cmp > 0)
66
+ break;
67
+ if (cmp === 0 && !highInclusive)
68
+ break;
69
+ }
70
+ const entry = this.entries.get(this.keyToString(key));
71
+ if (entry) {
72
+ callback(entry.value, key);
73
+ }
74
+ }
75
+ }
76
+ }
77
+ import { TsmdbDuplicateKeyError, TsmdbIndexError } from '../errors/TsmdbErrors.js';
78
+ import { QueryEngine } from './QueryEngine.js';
79
+ /**
80
+ * Comparator for B-Tree that handles mixed types consistently
81
+ */
82
+ function indexKeyComparator(a, b) {
83
+ // Handle null/undefined
84
+ if (a === null || a === undefined) {
85
+ if (b === null || b === undefined)
86
+ return 0;
87
+ return -1;
88
+ }
89
+ if (b === null || b === undefined)
90
+ return 1;
91
+ // Handle arrays (compound keys)
92
+ if (Array.isArray(a) && Array.isArray(b)) {
93
+ for (let i = 0; i < Math.max(a.length, b.length); i++) {
94
+ const cmp = indexKeyComparator(a[i], b[i]);
95
+ if (cmp !== 0)
96
+ return cmp;
97
+ }
98
+ return 0;
99
+ }
100
+ // Handle ObjectId
101
+ if (a instanceof plugins.bson.ObjectId && b instanceof plugins.bson.ObjectId) {
102
+ return a.toHexString().localeCompare(b.toHexString());
103
+ }
104
+ // Handle Date
105
+ if (a instanceof Date && b instanceof Date) {
106
+ return a.getTime() - b.getTime();
107
+ }
108
+ // Handle different types - use type ordering (null < number < string < object)
109
+ const typeOrder = (v) => {
110
+ if (v === null || v === undefined)
111
+ return 0;
112
+ if (typeof v === 'number')
113
+ return 1;
114
+ if (typeof v === 'string')
115
+ return 2;
116
+ if (typeof v === 'boolean')
117
+ return 3;
118
+ if (v instanceof Date)
119
+ return 4;
120
+ if (v instanceof plugins.bson.ObjectId)
121
+ return 5;
122
+ return 6;
123
+ };
124
+ const typeA = typeOrder(a);
125
+ const typeB = typeOrder(b);
126
+ if (typeA !== typeB)
127
+ return typeA - typeB;
128
+ // Same type comparison
129
+ if (typeof a === 'number')
130
+ return a - b;
131
+ if (typeof a === 'string')
132
+ return a.localeCompare(b);
133
+ if (typeof a === 'boolean')
134
+ return (a ? 1 : 0) - (b ? 1 : 0);
135
+ // Fallback to string comparison
136
+ return String(a).localeCompare(String(b));
137
+ }
138
+ /**
139
+ * Index engine for managing indexes and query optimization
140
+ */
141
+ export class IndexEngine {
142
+ dbName;
143
+ collName;
144
+ storage;
145
+ indexes = new Map();
146
+ initialized = false;
147
+ constructor(dbName, collName, storage) {
148
+ this.dbName = dbName;
149
+ this.collName = collName;
150
+ this.storage = storage;
151
+ }
152
+ /**
153
+ * Initialize indexes from storage
154
+ */
155
+ async initialize() {
156
+ if (this.initialized)
157
+ return;
158
+ const storedIndexes = await this.storage.getIndexes(this.dbName, this.collName);
159
+ const documents = await this.storage.findAll(this.dbName, this.collName);
160
+ for (const indexSpec of storedIndexes) {
161
+ const indexData = {
162
+ name: indexSpec.name,
163
+ key: indexSpec.key,
164
+ unique: indexSpec.unique || false,
165
+ sparse: indexSpec.sparse || false,
166
+ expireAfterSeconds: indexSpec.expireAfterSeconds,
167
+ btree: new SimpleBTree(undefined, indexKeyComparator),
168
+ hashMap: new Map(),
169
+ };
170
+ // Build index entries
171
+ for (const doc of documents) {
172
+ const keyValue = this.extractKeyValue(doc, indexSpec.key);
173
+ if (keyValue !== null || !indexData.sparse) {
174
+ const keyStr = JSON.stringify(keyValue);
175
+ // Add to hash map
176
+ if (!indexData.hashMap.has(keyStr)) {
177
+ indexData.hashMap.set(keyStr, new Set());
178
+ }
179
+ indexData.hashMap.get(keyStr).add(doc._id.toHexString());
180
+ // Add to B-tree
181
+ const existing = indexData.btree.get(keyValue);
182
+ if (existing) {
183
+ existing.add(doc._id.toHexString());
184
+ }
185
+ else {
186
+ indexData.btree.set(keyValue, new Set([doc._id.toHexString()]));
187
+ }
188
+ }
189
+ }
190
+ this.indexes.set(indexSpec.name, indexData);
191
+ }
192
+ this.initialized = true;
193
+ }
194
+ /**
195
+ * Create a new index
196
+ */
197
+ async createIndex(key, options) {
198
+ await this.initialize();
199
+ // Generate index name if not provided
200
+ const name = options?.name || this.generateIndexName(key);
201
+ // Check if index already exists
202
+ if (this.indexes.has(name)) {
203
+ return name;
204
+ }
205
+ // Create index data structure
206
+ const indexData = {
207
+ name,
208
+ key: key,
209
+ unique: options?.unique || false,
210
+ sparse: options?.sparse || false,
211
+ expireAfterSeconds: options?.expireAfterSeconds,
212
+ btree: new SimpleBTree(undefined, indexKeyComparator),
213
+ hashMap: new Map(),
214
+ };
215
+ // Build index from existing documents
216
+ const documents = await this.storage.findAll(this.dbName, this.collName);
217
+ for (const doc of documents) {
218
+ const keyValue = this.extractKeyValue(doc, key);
219
+ if (keyValue === null && indexData.sparse) {
220
+ continue;
221
+ }
222
+ const keyStr = JSON.stringify(keyValue);
223
+ if (indexData.unique && indexData.hashMap.has(keyStr)) {
224
+ throw new TsmdbDuplicateKeyError(`E11000 duplicate key error index: ${this.dbName}.${this.collName}.$${name}`, key, keyValue);
225
+ }
226
+ // Add to hash map
227
+ if (!indexData.hashMap.has(keyStr)) {
228
+ indexData.hashMap.set(keyStr, new Set());
229
+ }
230
+ indexData.hashMap.get(keyStr).add(doc._id.toHexString());
231
+ // Add to B-tree
232
+ const existing = indexData.btree.get(keyValue);
233
+ if (existing) {
234
+ existing.add(doc._id.toHexString());
235
+ }
236
+ else {
237
+ indexData.btree.set(keyValue, new Set([doc._id.toHexString()]));
238
+ }
239
+ }
240
+ // Store index
241
+ this.indexes.set(name, indexData);
242
+ await this.storage.saveIndex(this.dbName, this.collName, name, {
243
+ key,
244
+ unique: options?.unique,
245
+ sparse: options?.sparse,
246
+ expireAfterSeconds: options?.expireAfterSeconds,
247
+ });
248
+ return name;
249
+ }
250
+ /**
251
+ * Drop an index
252
+ */
253
+ async dropIndex(name) {
254
+ await this.initialize();
255
+ if (name === '_id_') {
256
+ throw new TsmdbIndexError('cannot drop _id index');
257
+ }
258
+ if (!this.indexes.has(name)) {
259
+ throw new TsmdbIndexError(`index not found: ${name}`);
260
+ }
261
+ this.indexes.delete(name);
262
+ await this.storage.dropIndex(this.dbName, this.collName, name);
263
+ }
264
+ /**
265
+ * Drop all indexes except _id
266
+ */
267
+ async dropAllIndexes() {
268
+ await this.initialize();
269
+ const names = Array.from(this.indexes.keys()).filter(n => n !== '_id_');
270
+ for (const name of names) {
271
+ this.indexes.delete(name);
272
+ await this.storage.dropIndex(this.dbName, this.collName, name);
273
+ }
274
+ }
275
+ /**
276
+ * List all indexes
277
+ */
278
+ async listIndexes() {
279
+ await this.initialize();
280
+ return Array.from(this.indexes.values()).map(idx => ({
281
+ v: 2,
282
+ key: idx.key,
283
+ name: idx.name,
284
+ unique: idx.unique || undefined,
285
+ sparse: idx.sparse || undefined,
286
+ expireAfterSeconds: idx.expireAfterSeconds,
287
+ }));
288
+ }
289
+ /**
290
+ * Check if an index exists
291
+ */
292
+ async indexExists(name) {
293
+ await this.initialize();
294
+ return this.indexes.has(name);
295
+ }
296
+ /**
297
+ * Update index entries after document insert
298
+ */
299
+ async onInsert(doc) {
300
+ await this.initialize();
301
+ for (const [name, indexData] of this.indexes) {
302
+ const keyValue = this.extractKeyValue(doc, indexData.key);
303
+ if (keyValue === null && indexData.sparse) {
304
+ continue;
305
+ }
306
+ const keyStr = JSON.stringify(keyValue);
307
+ // Check unique constraint
308
+ if (indexData.unique) {
309
+ const existing = indexData.hashMap.get(keyStr);
310
+ if (existing && existing.size > 0) {
311
+ throw new TsmdbDuplicateKeyError(`E11000 duplicate key error collection: ${this.dbName}.${this.collName} index: ${name}`, indexData.key, keyValue);
312
+ }
313
+ }
314
+ // Add to hash map
315
+ if (!indexData.hashMap.has(keyStr)) {
316
+ indexData.hashMap.set(keyStr, new Set());
317
+ }
318
+ indexData.hashMap.get(keyStr).add(doc._id.toHexString());
319
+ // Add to B-tree
320
+ const btreeSet = indexData.btree.get(keyValue);
321
+ if (btreeSet) {
322
+ btreeSet.add(doc._id.toHexString());
323
+ }
324
+ else {
325
+ indexData.btree.set(keyValue, new Set([doc._id.toHexString()]));
326
+ }
327
+ }
328
+ }
329
+ /**
330
+ * Update index entries after document update
331
+ */
332
+ async onUpdate(oldDoc, newDoc) {
333
+ await this.initialize();
334
+ for (const [name, indexData] of this.indexes) {
335
+ const oldKeyValue = this.extractKeyValue(oldDoc, indexData.key);
336
+ const newKeyValue = this.extractKeyValue(newDoc, indexData.key);
337
+ const oldKeyStr = JSON.stringify(oldKeyValue);
338
+ const newKeyStr = JSON.stringify(newKeyValue);
339
+ // Remove old entry if key changed
340
+ if (oldKeyStr !== newKeyStr) {
341
+ if (oldKeyValue !== null || !indexData.sparse) {
342
+ // Remove from hash map
343
+ const oldHashSet = indexData.hashMap.get(oldKeyStr);
344
+ if (oldHashSet) {
345
+ oldHashSet.delete(oldDoc._id.toHexString());
346
+ if (oldHashSet.size === 0) {
347
+ indexData.hashMap.delete(oldKeyStr);
348
+ }
349
+ }
350
+ // Remove from B-tree
351
+ const oldBtreeSet = indexData.btree.get(oldKeyValue);
352
+ if (oldBtreeSet) {
353
+ oldBtreeSet.delete(oldDoc._id.toHexString());
354
+ if (oldBtreeSet.size === 0) {
355
+ indexData.btree.delete(oldKeyValue);
356
+ }
357
+ }
358
+ }
359
+ // Add new entry
360
+ if (newKeyValue !== null || !indexData.sparse) {
361
+ // Check unique constraint
362
+ if (indexData.unique) {
363
+ const existing = indexData.hashMap.get(newKeyStr);
364
+ if (existing && existing.size > 0) {
365
+ throw new TsmdbDuplicateKeyError(`E11000 duplicate key error collection: ${this.dbName}.${this.collName} index: ${name}`, indexData.key, newKeyValue);
366
+ }
367
+ }
368
+ // Add to hash map
369
+ if (!indexData.hashMap.has(newKeyStr)) {
370
+ indexData.hashMap.set(newKeyStr, new Set());
371
+ }
372
+ indexData.hashMap.get(newKeyStr).add(newDoc._id.toHexString());
373
+ // Add to B-tree
374
+ const newBtreeSet = indexData.btree.get(newKeyValue);
375
+ if (newBtreeSet) {
376
+ newBtreeSet.add(newDoc._id.toHexString());
377
+ }
378
+ else {
379
+ indexData.btree.set(newKeyValue, new Set([newDoc._id.toHexString()]));
380
+ }
381
+ }
382
+ }
383
+ }
384
+ }
385
+ /**
386
+ * Update index entries after document delete
387
+ */
388
+ async onDelete(doc) {
389
+ await this.initialize();
390
+ for (const indexData of this.indexes.values()) {
391
+ const keyValue = this.extractKeyValue(doc, indexData.key);
392
+ if (keyValue === null && indexData.sparse) {
393
+ continue;
394
+ }
395
+ const keyStr = JSON.stringify(keyValue);
396
+ // Remove from hash map
397
+ const hashSet = indexData.hashMap.get(keyStr);
398
+ if (hashSet) {
399
+ hashSet.delete(doc._id.toHexString());
400
+ if (hashSet.size === 0) {
401
+ indexData.hashMap.delete(keyStr);
402
+ }
403
+ }
404
+ // Remove from B-tree
405
+ const btreeSet = indexData.btree.get(keyValue);
406
+ if (btreeSet) {
407
+ btreeSet.delete(doc._id.toHexString());
408
+ if (btreeSet.size === 0) {
409
+ indexData.btree.delete(keyValue);
410
+ }
411
+ }
412
+ }
413
+ }
414
+ /**
415
+ * Find the best index for a query
416
+ */
417
+ selectIndex(filter) {
418
+ if (!filter || Object.keys(filter).length === 0) {
419
+ return null;
420
+ }
421
+ // Get filter fields and operators
422
+ const filterInfo = this.analyzeFilter(filter);
423
+ // Score each index
424
+ let bestIndex = null;
425
+ let bestScore = 0;
426
+ for (const [name, indexData] of this.indexes) {
427
+ const indexFields = Object.keys(indexData.key);
428
+ let score = 0;
429
+ // Count how many index fields can be used
430
+ for (const field of indexFields) {
431
+ const info = filterInfo.get(field);
432
+ if (!info)
433
+ break;
434
+ // Equality is best
435
+ if (info.equality) {
436
+ score += 2;
437
+ }
438
+ else if (info.range) {
439
+ // Range queries can use B-tree
440
+ score += 1;
441
+ }
442
+ else if (info.in) {
443
+ score += 1.5;
444
+ }
445
+ else {
446
+ break;
447
+ }
448
+ }
449
+ // Prefer unique indexes
450
+ if (indexData.unique && score > 0) {
451
+ score += 0.5;
452
+ }
453
+ if (score > bestScore) {
454
+ bestScore = score;
455
+ bestIndex = { name, data: indexData };
456
+ }
457
+ }
458
+ return bestIndex;
459
+ }
460
+ /**
461
+ * Analyze filter to extract field operators
462
+ */
463
+ analyzeFilter(filter) {
464
+ const result = new Map();
465
+ for (const [key, value] of Object.entries(filter)) {
466
+ if (key.startsWith('$'))
467
+ continue;
468
+ const info = { equality: false, range: false, in: false, ops: {} };
469
+ if (typeof value !== 'object' || value === null || value instanceof plugins.bson.ObjectId || value instanceof Date) {
470
+ info.equality = true;
471
+ info.ops['$eq'] = value;
472
+ }
473
+ else {
474
+ const ops = value;
475
+ if (ops.$eq !== undefined) {
476
+ info.equality = true;
477
+ info.ops['$eq'] = ops.$eq;
478
+ }
479
+ if (ops.$in !== undefined) {
480
+ info.in = true;
481
+ info.ops['$in'] = ops.$in;
482
+ }
483
+ if (ops.$gt !== undefined || ops.$gte !== undefined || ops.$lt !== undefined || ops.$lte !== undefined) {
484
+ info.range = true;
485
+ if (ops.$gt !== undefined)
486
+ info.ops['$gt'] = ops.$gt;
487
+ if (ops.$gte !== undefined)
488
+ info.ops['$gte'] = ops.$gte;
489
+ if (ops.$lt !== undefined)
490
+ info.ops['$lt'] = ops.$lt;
491
+ if (ops.$lte !== undefined)
492
+ info.ops['$lte'] = ops.$lte;
493
+ }
494
+ }
495
+ result.set(key, info);
496
+ }
497
+ return result;
498
+ }
499
+ /**
500
+ * Use index to find candidate document IDs (supports range queries with B-tree)
501
+ */
502
+ async findCandidateIds(filter) {
503
+ await this.initialize();
504
+ const index = this.selectIndex(filter);
505
+ if (!index)
506
+ return null;
507
+ const filterInfo = this.analyzeFilter(filter);
508
+ const indexFields = Object.keys(index.data.key);
509
+ // For single-field indexes with range queries, use B-tree
510
+ if (indexFields.length === 1) {
511
+ const field = indexFields[0];
512
+ const info = filterInfo.get(field);
513
+ if (info) {
514
+ // Handle equality using hash map (faster)
515
+ if (info.equality) {
516
+ const keyStr = JSON.stringify(info.ops['$eq']);
517
+ return index.data.hashMap.get(keyStr) || new Set();
518
+ }
519
+ // Handle $in using hash map
520
+ if (info.in) {
521
+ const results = new Set();
522
+ for (const val of info.ops['$in']) {
523
+ const keyStr = JSON.stringify(val);
524
+ const ids = index.data.hashMap.get(keyStr);
525
+ if (ids) {
526
+ for (const id of ids) {
527
+ results.add(id);
528
+ }
529
+ }
530
+ }
531
+ return results;
532
+ }
533
+ // Handle range queries using B-tree
534
+ if (info.range) {
535
+ return this.findRangeCandidates(index.data, info.ops);
536
+ }
537
+ }
538
+ }
539
+ else {
540
+ // For compound indexes, use hash map with partial key matching
541
+ const equalityValues = {};
542
+ for (const field of indexFields) {
543
+ const info = filterInfo.get(field);
544
+ if (!info)
545
+ break;
546
+ if (info.equality) {
547
+ equalityValues[field] = info.ops['$eq'];
548
+ }
549
+ else if (info.in) {
550
+ // Handle $in with multiple lookups
551
+ const results = new Set();
552
+ for (const val of info.ops['$in']) {
553
+ equalityValues[field] = val;
554
+ const keyStr = JSON.stringify(this.buildKeyValue(equalityValues, index.data.key));
555
+ const ids = index.data.hashMap.get(keyStr);
556
+ if (ids) {
557
+ for (const id of ids) {
558
+ results.add(id);
559
+ }
560
+ }
561
+ }
562
+ return results;
563
+ }
564
+ else {
565
+ break; // Non-equality/in operator, stop here
566
+ }
567
+ }
568
+ if (Object.keys(equalityValues).length > 0) {
569
+ const keyStr = JSON.stringify(this.buildKeyValue(equalityValues, index.data.key));
570
+ return index.data.hashMap.get(keyStr) || new Set();
571
+ }
572
+ }
573
+ return null;
574
+ }
575
+ /**
576
+ * Find candidates using B-tree range scan
577
+ */
578
+ findRangeCandidates(indexData, ops) {
579
+ const results = new Set();
580
+ let lowKey = undefined;
581
+ let highKey = undefined;
582
+ let lowInclusive = true;
583
+ let highInclusive = true;
584
+ if (ops['$gt'] !== undefined) {
585
+ lowKey = ops['$gt'];
586
+ lowInclusive = false;
587
+ }
588
+ if (ops['$gte'] !== undefined) {
589
+ lowKey = ops['$gte'];
590
+ lowInclusive = true;
591
+ }
592
+ if (ops['$lt'] !== undefined) {
593
+ highKey = ops['$lt'];
594
+ highInclusive = false;
595
+ }
596
+ if (ops['$lte'] !== undefined) {
597
+ highKey = ops['$lte'];
598
+ highInclusive = true;
599
+ }
600
+ // Use B-tree range iteration
601
+ indexData.btree.forRange(lowKey, highKey, lowInclusive, highInclusive, (value, key) => {
602
+ if (value) {
603
+ for (const id of value) {
604
+ results.add(id);
605
+ }
606
+ }
607
+ });
608
+ return results;
609
+ }
610
+ // ============================================================================
611
+ // Helper Methods
612
+ // ============================================================================
613
+ generateIndexName(key) {
614
+ return Object.entries(key)
615
+ .map(([field, dir]) => `${field}_${dir}`)
616
+ .join('_');
617
+ }
618
+ extractKeyValue(doc, key) {
619
+ const values = [];
620
+ for (const field of Object.keys(key)) {
621
+ const value = QueryEngine.getNestedValue(doc, field);
622
+ values.push(value === undefined ? null : value);
623
+ }
624
+ // For single-field index, return the value directly
625
+ if (values.length === 1) {
626
+ return values[0];
627
+ }
628
+ return values;
629
+ }
630
+ buildKeyValue(values, key) {
631
+ const result = [];
632
+ for (const field of Object.keys(key)) {
633
+ result.push(values[field] !== undefined ? values[field] : null);
634
+ }
635
+ if (result.length === 1) {
636
+ return result[0];
637
+ }
638
+ return result;
639
+ }
640
+ getFilterFields(filter, prefix = '') {
641
+ const fields = [];
642
+ for (const [key, value] of Object.entries(filter)) {
643
+ if (key.startsWith('$')) {
644
+ // Logical operator
645
+ if (key === '$and' || key === '$or' || key === '$nor') {
646
+ for (const subFilter of value) {
647
+ fields.push(...this.getFilterFields(subFilter, prefix));
648
+ }
649
+ }
650
+ }
651
+ else {
652
+ const fullKey = prefix ? `${prefix}.${key}` : key;
653
+ fields.push(fullKey);
654
+ // Check for nested filters
655
+ if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
656
+ const subKeys = Object.keys(value);
657
+ if (subKeys.length > 0 && !subKeys[0].startsWith('$')) {
658
+ fields.push(...this.getFilterFields(value, fullKey));
659
+ }
660
+ }
661
+ }
662
+ }
663
+ return fields;
664
+ }
665
+ getFilterValue(filter, field) {
666
+ // Handle dot notation
667
+ const parts = field.split('.');
668
+ let current = filter;
669
+ for (const part of parts) {
670
+ if (current === null || current === undefined) {
671
+ return undefined;
672
+ }
673
+ current = current[part];
674
+ }
675
+ return current;
676
+ }
677
+ }
678
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"IndexEngine.js","sourceRoot":"","sources":["../../../ts/tsmdb/engine/IndexEngine.ts"],"names":[],"mappings":"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"}