@push.rocks/smartdb 1.0.1 → 2.1.1

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/.smartconfig.json +18 -4
  2. package/dist_rust/rustdb_linux_amd64 +0 -0
  3. package/dist_rust/rustdb_linux_arm64 +0 -0
  4. package/dist_ts/00_commitinfo_data.js +3 -3
  5. package/dist_ts/index.d.ts +1 -0
  6. package/dist_ts/ts_local/classes.localsmartdb.d.ts +5 -5
  7. package/dist_ts/ts_local/classes.localsmartdb.js +7 -9
  8. package/dist_ts/ts_local/plugins.d.ts +1 -2
  9. package/dist_ts/ts_local/plugins.js +3 -3
  10. package/dist_ts/ts_smartdb/index.d.ts +2 -24
  11. package/dist_ts/ts_smartdb/index.js +4 -29
  12. package/dist_ts/ts_smartdb/plugins.d.ts +2 -10
  13. package/dist_ts/ts_smartdb/plugins.js +3 -13
  14. package/dist_ts/ts_smartdb/rust-db-bridge.d.ts +122 -0
  15. package/dist_ts/ts_smartdb/rust-db-bridge.js +113 -0
  16. package/dist_ts/ts_smartdb/server/SmartdbServer.d.ts +39 -37
  17. package/dist_ts/ts_smartdb/server/SmartdbServer.js +87 -206
  18. package/dist_ts/ts_smartdb/server/index.d.ts +0 -4
  19. package/dist_ts/ts_smartdb/server/index.js +1 -5
  20. package/dist_ts_debugserver/bundled.d.ts +4 -0
  21. package/dist_ts_debugserver/bundled.js +12 -0
  22. package/dist_ts_debugserver/classes.debugserver.d.ts +36 -0
  23. package/dist_ts_debugserver/classes.debugserver.js +95 -0
  24. package/dist_ts_debugserver/index.d.ts +2 -0
  25. package/dist_ts_debugserver/index.js +2 -0
  26. package/dist_ts_debugserver/plugins.d.ts +2 -0
  27. package/dist_ts_debugserver/plugins.js +3 -0
  28. package/dist_ts_debugui/index.d.ts +2 -0
  29. package/dist_ts_debugui/index.js +2 -0
  30. package/dist_ts_debugui/plugins.d.ts +1 -0
  31. package/dist_ts_debugui/plugins.js +2 -0
  32. package/dist_ts_debugui/smartdb-debugui.d.ts +62 -0
  33. package/dist_ts_debugui/smartdb-debugui.js +1132 -0
  34. package/license +3 -1
  35. package/package.json +14 -13
  36. package/readme.md +209 -177
  37. package/ts/00_commitinfo_data.ts +2 -2
  38. package/ts/index.ts +11 -0
  39. package/ts/ts_local/classes.localsmartdb.ts +5 -6
  40. package/ts/ts_local/plugins.ts +1 -3
  41. package/ts/ts_smartdb/index.ts +14 -41
  42. package/ts/ts_smartdb/plugins.ts +2 -15
  43. package/ts/ts_smartdb/rust-db-bridge.ts +262 -0
  44. package/ts/ts_smartdb/server/SmartdbServer.ts +115 -246
  45. package/ts/ts_smartdb/server/index.ts +0 -7
  46. package/dist_ts/ts_smartdb/engine/AggregationEngine.d.ts +0 -66
  47. package/dist_ts/ts_smartdb/engine/AggregationEngine.js +0 -189
  48. package/dist_ts/ts_smartdb/engine/IndexEngine.d.ts +0 -97
  49. package/dist_ts/ts_smartdb/engine/IndexEngine.js +0 -678
  50. package/dist_ts/ts_smartdb/engine/QueryEngine.d.ts +0 -54
  51. package/dist_ts/ts_smartdb/engine/QueryEngine.js +0 -271
  52. package/dist_ts/ts_smartdb/engine/QueryPlanner.d.ts +0 -64
  53. package/dist_ts/ts_smartdb/engine/QueryPlanner.js +0 -308
  54. package/dist_ts/ts_smartdb/engine/SessionEngine.d.ts +0 -117
  55. package/dist_ts/ts_smartdb/engine/SessionEngine.js +0 -232
  56. package/dist_ts/ts_smartdb/engine/TransactionEngine.d.ts +0 -85
  57. package/dist_ts/ts_smartdb/engine/TransactionEngine.js +0 -287
  58. package/dist_ts/ts_smartdb/engine/UpdateEngine.d.ts +0 -47
  59. package/dist_ts/ts_smartdb/engine/UpdateEngine.js +0 -461
  60. package/dist_ts/ts_smartdb/errors/SmartdbErrors.d.ts +0 -100
  61. package/dist_ts/ts_smartdb/errors/SmartdbErrors.js +0 -155
  62. package/dist_ts/ts_smartdb/server/CommandRouter.d.ts +0 -87
  63. package/dist_ts/ts_smartdb/server/CommandRouter.js +0 -222
  64. package/dist_ts/ts_smartdb/server/WireProtocol.d.ts +0 -117
  65. package/dist_ts/ts_smartdb/server/WireProtocol.js +0 -298
  66. package/dist_ts/ts_smartdb/server/handlers/AdminHandler.d.ts +0 -100
  67. package/dist_ts/ts_smartdb/server/handlers/AdminHandler.js +0 -668
  68. package/dist_ts/ts_smartdb/server/handlers/AggregateHandler.d.ts +0 -31
  69. package/dist_ts/ts_smartdb/server/handlers/AggregateHandler.js +0 -277
  70. package/dist_ts/ts_smartdb/server/handlers/DeleteHandler.d.ts +0 -8
  71. package/dist_ts/ts_smartdb/server/handlers/DeleteHandler.js +0 -95
  72. package/dist_ts/ts_smartdb/server/handlers/FindHandler.d.ts +0 -31
  73. package/dist_ts/ts_smartdb/server/handlers/FindHandler.js +0 -291
  74. package/dist_ts/ts_smartdb/server/handlers/HelloHandler.d.ts +0 -11
  75. package/dist_ts/ts_smartdb/server/handlers/HelloHandler.js +0 -62
  76. package/dist_ts/ts_smartdb/server/handlers/IndexHandler.d.ts +0 -20
  77. package/dist_ts/ts_smartdb/server/handlers/IndexHandler.js +0 -183
  78. package/dist_ts/ts_smartdb/server/handlers/InsertHandler.d.ts +0 -8
  79. package/dist_ts/ts_smartdb/server/handlers/InsertHandler.js +0 -79
  80. package/dist_ts/ts_smartdb/server/handlers/UpdateHandler.d.ts +0 -24
  81. package/dist_ts/ts_smartdb/server/handlers/UpdateHandler.js +0 -296
  82. package/dist_ts/ts_smartdb/server/handlers/index.d.ts +0 -8
  83. package/dist_ts/ts_smartdb/server/handlers/index.js +0 -10
  84. package/dist_ts/ts_smartdb/storage/FileStorageAdapter.d.ts +0 -85
  85. package/dist_ts/ts_smartdb/storage/FileStorageAdapter.js +0 -465
  86. package/dist_ts/ts_smartdb/storage/IStorageAdapter.d.ts +0 -145
  87. package/dist_ts/ts_smartdb/storage/IStorageAdapter.js +0 -2
  88. package/dist_ts/ts_smartdb/storage/MemoryStorageAdapter.d.ts +0 -67
  89. package/dist_ts/ts_smartdb/storage/MemoryStorageAdapter.js +0 -378
  90. package/dist_ts/ts_smartdb/storage/OpLog.d.ts +0 -93
  91. package/dist_ts/ts_smartdb/storage/OpLog.js +0 -221
  92. package/dist_ts/ts_smartdb/storage/WAL.d.ts +0 -117
  93. package/dist_ts/ts_smartdb/storage/WAL.js +0 -286
  94. package/dist_ts/ts_smartdb/types/interfaces.d.ts +0 -363
  95. package/dist_ts/ts_smartdb/types/interfaces.js +0 -2
  96. package/dist_ts/ts_smartdb/utils/checksum.d.ts +0 -30
  97. package/dist_ts/ts_smartdb/utils/checksum.js +0 -77
  98. package/dist_ts/ts_smartdb/utils/index.d.ts +0 -1
  99. package/dist_ts/ts_smartdb/utils/index.js +0 -2
  100. package/ts/ts_smartdb/engine/AggregationEngine.ts +0 -283
  101. package/ts/ts_smartdb/engine/IndexEngine.ts +0 -798
  102. package/ts/ts_smartdb/engine/QueryEngine.ts +0 -301
  103. package/ts/ts_smartdb/engine/QueryPlanner.ts +0 -393
  104. package/ts/ts_smartdb/engine/SessionEngine.ts +0 -292
  105. package/ts/ts_smartdb/engine/TransactionEngine.ts +0 -351
  106. package/ts/ts_smartdb/engine/UpdateEngine.ts +0 -506
  107. package/ts/ts_smartdb/errors/SmartdbErrors.ts +0 -181
  108. package/ts/ts_smartdb/server/CommandRouter.ts +0 -289
  109. package/ts/ts_smartdb/server/WireProtocol.ts +0 -416
  110. package/ts/ts_smartdb/server/handlers/AdminHandler.ts +0 -719
  111. package/ts/ts_smartdb/server/handlers/AggregateHandler.ts +0 -342
  112. package/ts/ts_smartdb/server/handlers/DeleteHandler.ts +0 -115
  113. package/ts/ts_smartdb/server/handlers/FindHandler.ts +0 -330
  114. package/ts/ts_smartdb/server/handlers/HelloHandler.ts +0 -78
  115. package/ts/ts_smartdb/server/handlers/IndexHandler.ts +0 -207
  116. package/ts/ts_smartdb/server/handlers/InsertHandler.ts +0 -97
  117. package/ts/ts_smartdb/server/handlers/UpdateHandler.ts +0 -344
  118. package/ts/ts_smartdb/server/handlers/index.ts +0 -10
  119. package/ts/ts_smartdb/storage/FileStorageAdapter.ts +0 -562
  120. package/ts/ts_smartdb/storage/IStorageAdapter.ts +0 -208
  121. package/ts/ts_smartdb/storage/MemoryStorageAdapter.ts +0 -455
  122. package/ts/ts_smartdb/storage/OpLog.ts +0 -282
  123. package/ts/ts_smartdb/storage/WAL.ts +0 -375
  124. package/ts/ts_smartdb/types/interfaces.ts +0 -433
  125. package/ts/ts_smartdb/utils/checksum.ts +0 -88
  126. package/ts/ts_smartdb/utils/index.ts +0 -1
@@ -1,678 +0,0 @@
1
- import * as plugins from '../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 { SmartdbDuplicateKeyError, SmartdbIndexError } from '../errors/SmartdbErrors.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 SmartdbDuplicateKeyError(`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 SmartdbIndexError('cannot drop _id index');
257
- }
258
- if (!this.indexes.has(name)) {
259
- throw new SmartdbIndexError(`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 SmartdbDuplicateKeyError(`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 SmartdbDuplicateKeyError(`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/ts_smartdb/engine/IndexEngine.ts"],"names":[],"mappings":"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"}