@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.
- 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/{congodb → tsmdb}/engine/IndexEngine.d.ts +23 -3
- package/dist_ts/tsmdb/engine/IndexEngine.js +678 -0
- package/dist_ts/tsmdb/engine/QueryEngine.js +271 -0
- package/dist_ts/tsmdb/engine/QueryPlanner.d.ts +64 -0
- package/dist_ts/tsmdb/engine/QueryPlanner.js +308 -0
- package/dist_ts/tsmdb/engine/SessionEngine.d.ts +117 -0
- package/dist_ts/tsmdb/engine/SessionEngine.js +232 -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 +11 -4
- package/dist_ts/tsmdb/index.js +31 -0
- package/dist_ts/tsmdb/server/CommandRouter.d.ts +87 -0
- package/dist_ts/tsmdb/server/CommandRouter.js +222 -0
- package/dist_ts/{congodb/server/CongoServer.d.ts → tsmdb/server/TsmdbServer.d.ts} +6 -6
- package/dist_ts/tsmdb/server/TsmdbServer.js +229 -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 +668 -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 +95 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/FindHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/FindHandler.js +291 -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 +79 -0
- package/dist_ts/{congodb → tsmdb}/server/handlers/UpdateHandler.d.ts +1 -1
- package/dist_ts/tsmdb/server/handlers/UpdateHandler.js +296 -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 +27 -3
- package/dist_ts/tsmdb/storage/FileStorageAdapter.js +465 -0
- package/dist_ts/{congodb → tsmdb}/storage/IStorageAdapter.d.ts +7 -2
- package/dist_ts/{congodb → tsmdb}/storage/IStorageAdapter.js +1 -1
- package/dist_ts/{congodb → tsmdb}/storage/MemoryStorageAdapter.d.ts +3 -2
- package/dist_ts/tsmdb/storage/MemoryStorageAdapter.js +378 -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/storage/WAL.d.ts +117 -0
- package/dist_ts/tsmdb/storage/WAL.js +286 -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/dist_ts/tsmdb/utils/checksum.d.ts +30 -0
- package/dist_ts/tsmdb/utils/checksum.js +77 -0
- package/dist_ts/tsmdb/utils/index.d.ts +1 -0
- package/dist_ts/tsmdb/utils/index.js +2 -0
- package/package.json +1 -1
- package/readme.hints.md +7 -12
- package/readme.md +25 -25
- 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/tsmdb/engine/IndexEngine.ts +798 -0
- package/ts/{congodb → tsmdb}/engine/QueryEngine.ts +1 -1
- package/ts/tsmdb/engine/QueryPlanner.ts +393 -0
- package/ts/tsmdb/engine/SessionEngine.ts +292 -0
- 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 +16 -7
- package/ts/{congodb → tsmdb}/server/CommandRouter.ts +114 -5
- package/ts/{congodb/server/CongoServer.ts → tsmdb/server/TsmdbServer.ts} +11 -8
- package/ts/{congodb → tsmdb}/server/WireProtocol.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/AdminHandler.ts +116 -11
- package/ts/{congodb → tsmdb}/server/handlers/AggregateHandler.ts +1 -1
- package/ts/{congodb → tsmdb}/server/handlers/DeleteHandler.ts +18 -3
- package/ts/{congodb → tsmdb}/server/handlers/FindHandler.ts +43 -14
- 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 +7 -1
- package/ts/{congodb → tsmdb}/server/handlers/UpdateHandler.ts +34 -5
- package/ts/{congodb → tsmdb}/server/index.ts +2 -2
- package/ts/{congodb → tsmdb}/storage/FileStorageAdapter.ts +90 -7
- package/ts/{congodb → tsmdb}/storage/IStorageAdapter.ts +8 -2
- package/ts/{congodb → tsmdb}/storage/MemoryStorageAdapter.ts +14 -2
- package/ts/{congodb → tsmdb}/storage/OpLog.ts +1 -1
- package/ts/tsmdb/storage/WAL.ts +375 -0
- package/ts/{congodb → tsmdb}/types/interfaces.ts +3 -3
- package/ts/tsmdb/utils/checksum.ts +88 -0
- package/ts/tsmdb/utils/index.ts +1 -0
- 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.d.ts +0 -51
- 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/ts/congodb/engine/IndexEngine.ts +0 -479
- /package/dist_ts/{congodb → tsmdb}/engine/AggregationEngine.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,465 @@
|
|
|
1
|
+
import * as plugins from '../tsmdb.plugins.js';
|
|
2
|
+
import { calculateDocumentChecksum, verifyChecksum } from '../utils/checksum.js';
|
|
3
|
+
/**
|
|
4
|
+
* File-based storage adapter for TsmDB
|
|
5
|
+
* Stores data in JSON files on disk for persistence
|
|
6
|
+
*/
|
|
7
|
+
export class FileStorageAdapter {
|
|
8
|
+
basePath;
|
|
9
|
+
opLogCounter = 0;
|
|
10
|
+
initialized = false;
|
|
11
|
+
fs = new plugins.smartfs.SmartFs(new plugins.smartfs.SmartFsProviderNode());
|
|
12
|
+
enableChecksums;
|
|
13
|
+
strictChecksums;
|
|
14
|
+
constructor(basePath, options) {
|
|
15
|
+
this.basePath = basePath;
|
|
16
|
+
this.enableChecksums = options?.enableChecksums ?? false;
|
|
17
|
+
this.strictChecksums = options?.strictChecksums ?? false;
|
|
18
|
+
}
|
|
19
|
+
// ============================================================================
|
|
20
|
+
// Helper Methods
|
|
21
|
+
// ============================================================================
|
|
22
|
+
getDbPath(dbName) {
|
|
23
|
+
return plugins.smartpath.join(this.basePath, dbName);
|
|
24
|
+
}
|
|
25
|
+
getCollectionPath(dbName, collName) {
|
|
26
|
+
return plugins.smartpath.join(this.basePath, dbName, `${collName}.json`);
|
|
27
|
+
}
|
|
28
|
+
getIndexPath(dbName, collName) {
|
|
29
|
+
return plugins.smartpath.join(this.basePath, dbName, `${collName}.indexes.json`);
|
|
30
|
+
}
|
|
31
|
+
getOpLogPath() {
|
|
32
|
+
return plugins.smartpath.join(this.basePath, '_oplog.json');
|
|
33
|
+
}
|
|
34
|
+
getMetaPath() {
|
|
35
|
+
return plugins.smartpath.join(this.basePath, '_meta.json');
|
|
36
|
+
}
|
|
37
|
+
async readJsonFile(filePath, defaultValue) {
|
|
38
|
+
try {
|
|
39
|
+
const exists = await this.fs.file(filePath).exists();
|
|
40
|
+
if (!exists)
|
|
41
|
+
return defaultValue;
|
|
42
|
+
const content = await this.fs.file(filePath).encoding('utf8').read();
|
|
43
|
+
return JSON.parse(content);
|
|
44
|
+
}
|
|
45
|
+
catch {
|
|
46
|
+
return defaultValue;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
async writeJsonFile(filePath, data) {
|
|
50
|
+
const dir = filePath.substring(0, filePath.lastIndexOf('/'));
|
|
51
|
+
await this.fs.directory(dir).recursive().create();
|
|
52
|
+
await this.fs.file(filePath).encoding('utf8').write(JSON.stringify(data, null, 2));
|
|
53
|
+
}
|
|
54
|
+
restoreObjectIds(doc) {
|
|
55
|
+
if (doc._id) {
|
|
56
|
+
if (typeof doc._id === 'string') {
|
|
57
|
+
doc._id = new plugins.bson.ObjectId(doc._id);
|
|
58
|
+
}
|
|
59
|
+
else if (typeof doc._id === 'object' && doc._id.$oid) {
|
|
60
|
+
doc._id = new plugins.bson.ObjectId(doc._id.$oid);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return doc;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Verify document checksum and handle errors
|
|
67
|
+
*/
|
|
68
|
+
verifyDocumentChecksum(doc) {
|
|
69
|
+
if (!this.enableChecksums || !doc._checksum) {
|
|
70
|
+
return true;
|
|
71
|
+
}
|
|
72
|
+
const isValid = verifyChecksum(doc);
|
|
73
|
+
if (!isValid) {
|
|
74
|
+
const errorMsg = `Checksum mismatch for document ${doc._id}`;
|
|
75
|
+
if (this.strictChecksums) {
|
|
76
|
+
throw new Error(errorMsg);
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
console.warn(`WARNING: ${errorMsg}`);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return isValid;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Add checksum to document before storing
|
|
86
|
+
*/
|
|
87
|
+
prepareDocumentForStorage(doc) {
|
|
88
|
+
if (!this.enableChecksums) {
|
|
89
|
+
return doc;
|
|
90
|
+
}
|
|
91
|
+
const checksum = calculateDocumentChecksum(doc);
|
|
92
|
+
return { ...doc, _checksum: checksum };
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Remove internal checksum field before returning to user
|
|
96
|
+
*/
|
|
97
|
+
cleanDocumentForReturn(doc) {
|
|
98
|
+
const { _checksum, ...cleanDoc } = doc;
|
|
99
|
+
return this.restoreObjectIds(cleanDoc);
|
|
100
|
+
}
|
|
101
|
+
// ============================================================================
|
|
102
|
+
// Initialization
|
|
103
|
+
// ============================================================================
|
|
104
|
+
async initialize() {
|
|
105
|
+
if (this.initialized)
|
|
106
|
+
return;
|
|
107
|
+
await this.fs.directory(this.basePath).recursive().create();
|
|
108
|
+
// Load metadata
|
|
109
|
+
const meta = await this.readJsonFile(this.getMetaPath(), { opLogCounter: 0 });
|
|
110
|
+
this.opLogCounter = meta.opLogCounter || 0;
|
|
111
|
+
this.initialized = true;
|
|
112
|
+
}
|
|
113
|
+
async close() {
|
|
114
|
+
// Save metadata
|
|
115
|
+
await this.writeJsonFile(this.getMetaPath(), { opLogCounter: this.opLogCounter });
|
|
116
|
+
this.initialized = false;
|
|
117
|
+
}
|
|
118
|
+
// ============================================================================
|
|
119
|
+
// Database Operations
|
|
120
|
+
// ============================================================================
|
|
121
|
+
async listDatabases() {
|
|
122
|
+
await this.initialize();
|
|
123
|
+
try {
|
|
124
|
+
const entries = await this.fs.directory(this.basePath).list();
|
|
125
|
+
return entries
|
|
126
|
+
.filter(entry => entry.isDirectory && !entry.name.startsWith('_'))
|
|
127
|
+
.map(entry => entry.name);
|
|
128
|
+
}
|
|
129
|
+
catch {
|
|
130
|
+
return [];
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
async createDatabase(dbName) {
|
|
134
|
+
await this.initialize();
|
|
135
|
+
const dbPath = this.getDbPath(dbName);
|
|
136
|
+
await this.fs.directory(dbPath).recursive().create();
|
|
137
|
+
}
|
|
138
|
+
async dropDatabase(dbName) {
|
|
139
|
+
await this.initialize();
|
|
140
|
+
const dbPath = this.getDbPath(dbName);
|
|
141
|
+
try {
|
|
142
|
+
const exists = await this.fs.directory(dbPath).exists();
|
|
143
|
+
if (exists) {
|
|
144
|
+
await this.fs.directory(dbPath).recursive().delete();
|
|
145
|
+
return true;
|
|
146
|
+
}
|
|
147
|
+
return false;
|
|
148
|
+
}
|
|
149
|
+
catch {
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
async databaseExists(dbName) {
|
|
154
|
+
await this.initialize();
|
|
155
|
+
const dbPath = this.getDbPath(dbName);
|
|
156
|
+
return this.fs.directory(dbPath).exists();
|
|
157
|
+
}
|
|
158
|
+
// ============================================================================
|
|
159
|
+
// Collection Operations
|
|
160
|
+
// ============================================================================
|
|
161
|
+
async listCollections(dbName) {
|
|
162
|
+
await this.initialize();
|
|
163
|
+
const dbPath = this.getDbPath(dbName);
|
|
164
|
+
try {
|
|
165
|
+
const entries = await this.fs.directory(dbPath).list();
|
|
166
|
+
return entries
|
|
167
|
+
.filter(entry => entry.isFile && entry.name.endsWith('.json') && !entry.name.endsWith('.indexes.json'))
|
|
168
|
+
.map(entry => entry.name.replace('.json', ''));
|
|
169
|
+
}
|
|
170
|
+
catch {
|
|
171
|
+
return [];
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
async createCollection(dbName, collName) {
|
|
175
|
+
await this.createDatabase(dbName);
|
|
176
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
177
|
+
const exists = await this.fs.file(collPath).exists();
|
|
178
|
+
if (!exists) {
|
|
179
|
+
await this.writeJsonFile(collPath, []);
|
|
180
|
+
// Create default _id index
|
|
181
|
+
await this.writeJsonFile(this.getIndexPath(dbName, collName), [
|
|
182
|
+
{ name: '_id_', key: { _id: 1 }, unique: true }
|
|
183
|
+
]);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
async dropCollection(dbName, collName) {
|
|
187
|
+
await this.initialize();
|
|
188
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
189
|
+
const indexPath = this.getIndexPath(dbName, collName);
|
|
190
|
+
try {
|
|
191
|
+
const exists = await this.fs.file(collPath).exists();
|
|
192
|
+
if (exists) {
|
|
193
|
+
await this.fs.file(collPath).delete();
|
|
194
|
+
try {
|
|
195
|
+
await this.fs.file(indexPath).delete();
|
|
196
|
+
}
|
|
197
|
+
catch { }
|
|
198
|
+
return true;
|
|
199
|
+
}
|
|
200
|
+
return false;
|
|
201
|
+
}
|
|
202
|
+
catch {
|
|
203
|
+
return false;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
async collectionExists(dbName, collName) {
|
|
207
|
+
await this.initialize();
|
|
208
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
209
|
+
return this.fs.file(collPath).exists();
|
|
210
|
+
}
|
|
211
|
+
async renameCollection(dbName, oldName, newName) {
|
|
212
|
+
await this.initialize();
|
|
213
|
+
const oldPath = this.getCollectionPath(dbName, oldName);
|
|
214
|
+
const newPath = this.getCollectionPath(dbName, newName);
|
|
215
|
+
const oldIndexPath = this.getIndexPath(dbName, oldName);
|
|
216
|
+
const newIndexPath = this.getIndexPath(dbName, newName);
|
|
217
|
+
const exists = await this.fs.file(oldPath).exists();
|
|
218
|
+
if (!exists) {
|
|
219
|
+
throw new Error(`Collection ${oldName} not found`);
|
|
220
|
+
}
|
|
221
|
+
// Read, write to new, delete old
|
|
222
|
+
const docs = await this.readJsonFile(oldPath, []);
|
|
223
|
+
await this.writeJsonFile(newPath, docs);
|
|
224
|
+
await this.fs.file(oldPath).delete();
|
|
225
|
+
// Handle indexes
|
|
226
|
+
const indexes = await this.readJsonFile(oldIndexPath, []);
|
|
227
|
+
await this.writeJsonFile(newIndexPath, indexes);
|
|
228
|
+
try {
|
|
229
|
+
await this.fs.file(oldIndexPath).delete();
|
|
230
|
+
}
|
|
231
|
+
catch { }
|
|
232
|
+
}
|
|
233
|
+
// ============================================================================
|
|
234
|
+
// Document Operations
|
|
235
|
+
// ============================================================================
|
|
236
|
+
async insertOne(dbName, collName, doc) {
|
|
237
|
+
await this.createCollection(dbName, collName);
|
|
238
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
239
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
240
|
+
const storedDoc = {
|
|
241
|
+
...doc,
|
|
242
|
+
_id: doc._id ? (doc._id instanceof plugins.bson.ObjectId ? doc._id : new plugins.bson.ObjectId(doc._id)) : new plugins.bson.ObjectId(),
|
|
243
|
+
};
|
|
244
|
+
// Check for duplicate
|
|
245
|
+
const idStr = storedDoc._id.toHexString();
|
|
246
|
+
if (docs.some(d => d._id === idStr || (d._id && d._id.toString() === idStr))) {
|
|
247
|
+
throw new Error(`Duplicate key error: _id ${idStr}`);
|
|
248
|
+
}
|
|
249
|
+
// Add checksum if enabled
|
|
250
|
+
const docToStore = this.prepareDocumentForStorage(storedDoc);
|
|
251
|
+
docs.push(docToStore);
|
|
252
|
+
await this.writeJsonFile(collPath, docs);
|
|
253
|
+
return storedDoc;
|
|
254
|
+
}
|
|
255
|
+
async insertMany(dbName, collName, docsToInsert) {
|
|
256
|
+
await this.createCollection(dbName, collName);
|
|
257
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
258
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
259
|
+
const results = [];
|
|
260
|
+
const existingIds = new Set(docs.map(d => d._id?.toString?.() || d._id));
|
|
261
|
+
for (const doc of docsToInsert) {
|
|
262
|
+
const storedDoc = {
|
|
263
|
+
...doc,
|
|
264
|
+
_id: doc._id ? (doc._id instanceof plugins.bson.ObjectId ? doc._id : new plugins.bson.ObjectId(doc._id)) : new plugins.bson.ObjectId(),
|
|
265
|
+
};
|
|
266
|
+
const idStr = storedDoc._id.toHexString();
|
|
267
|
+
if (existingIds.has(idStr)) {
|
|
268
|
+
throw new Error(`Duplicate key error: _id ${idStr}`);
|
|
269
|
+
}
|
|
270
|
+
existingIds.add(idStr);
|
|
271
|
+
// Add checksum if enabled
|
|
272
|
+
const docToStore = this.prepareDocumentForStorage(storedDoc);
|
|
273
|
+
docs.push(docToStore);
|
|
274
|
+
results.push(storedDoc);
|
|
275
|
+
}
|
|
276
|
+
await this.writeJsonFile(collPath, docs);
|
|
277
|
+
return results;
|
|
278
|
+
}
|
|
279
|
+
async findAll(dbName, collName) {
|
|
280
|
+
await this.createCollection(dbName, collName);
|
|
281
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
282
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
283
|
+
return docs.map(doc => {
|
|
284
|
+
// Verify checksum if enabled
|
|
285
|
+
this.verifyDocumentChecksum(doc);
|
|
286
|
+
// Clean and return document without internal checksum field
|
|
287
|
+
return this.cleanDocumentForReturn(doc);
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
async findByIds(dbName, collName, ids) {
|
|
291
|
+
await this.createCollection(dbName, collName);
|
|
292
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
293
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
294
|
+
const results = [];
|
|
295
|
+
for (const doc of docs) {
|
|
296
|
+
// Verify checksum if enabled
|
|
297
|
+
this.verifyDocumentChecksum(doc);
|
|
298
|
+
// Clean and restore document
|
|
299
|
+
const cleaned = this.cleanDocumentForReturn(doc);
|
|
300
|
+
if (ids.has(cleaned._id.toHexString())) {
|
|
301
|
+
results.push(cleaned);
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
return results;
|
|
305
|
+
}
|
|
306
|
+
async findById(dbName, collName, id) {
|
|
307
|
+
// Use findAll which already handles checksum verification
|
|
308
|
+
const docs = await this.findAll(dbName, collName);
|
|
309
|
+
const idStr = id.toHexString();
|
|
310
|
+
return docs.find(d => d._id.toHexString() === idStr) || null;
|
|
311
|
+
}
|
|
312
|
+
async updateById(dbName, collName, id, doc) {
|
|
313
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
314
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
315
|
+
const idStr = id.toHexString();
|
|
316
|
+
const idx = docs.findIndex(d => {
|
|
317
|
+
const docId = d._id?.toHexString?.() || d._id?.toString?.() || d._id;
|
|
318
|
+
return docId === idStr;
|
|
319
|
+
});
|
|
320
|
+
if (idx === -1)
|
|
321
|
+
return false;
|
|
322
|
+
// Add checksum if enabled
|
|
323
|
+
const docToStore = this.prepareDocumentForStorage(doc);
|
|
324
|
+
docs[idx] = docToStore;
|
|
325
|
+
await this.writeJsonFile(collPath, docs);
|
|
326
|
+
return true;
|
|
327
|
+
}
|
|
328
|
+
async deleteById(dbName, collName, id) {
|
|
329
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
330
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
331
|
+
const idStr = id.toHexString();
|
|
332
|
+
const idx = docs.findIndex(d => {
|
|
333
|
+
const docId = d._id?.toHexString?.() || d._id?.toString?.() || d._id;
|
|
334
|
+
return docId === idStr;
|
|
335
|
+
});
|
|
336
|
+
if (idx === -1)
|
|
337
|
+
return false;
|
|
338
|
+
docs.splice(idx, 1);
|
|
339
|
+
await this.writeJsonFile(collPath, docs);
|
|
340
|
+
return true;
|
|
341
|
+
}
|
|
342
|
+
async deleteByIds(dbName, collName, ids) {
|
|
343
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
344
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
345
|
+
const idStrs = new Set(ids.map(id => id.toHexString()));
|
|
346
|
+
const originalLength = docs.length;
|
|
347
|
+
const filtered = docs.filter(d => {
|
|
348
|
+
const docId = d._id?.toHexString?.() || d._id?.toString?.() || d._id;
|
|
349
|
+
return !idStrs.has(docId);
|
|
350
|
+
});
|
|
351
|
+
await this.writeJsonFile(collPath, filtered);
|
|
352
|
+
return originalLength - filtered.length;
|
|
353
|
+
}
|
|
354
|
+
async count(dbName, collName) {
|
|
355
|
+
const collPath = this.getCollectionPath(dbName, collName);
|
|
356
|
+
const docs = await this.readJsonFile(collPath, []);
|
|
357
|
+
return docs.length;
|
|
358
|
+
}
|
|
359
|
+
// ============================================================================
|
|
360
|
+
// Index Operations
|
|
361
|
+
// ============================================================================
|
|
362
|
+
async saveIndex(dbName, collName, indexName, indexSpec) {
|
|
363
|
+
await this.createCollection(dbName, collName);
|
|
364
|
+
const indexPath = this.getIndexPath(dbName, collName);
|
|
365
|
+
const indexes = await this.readJsonFile(indexPath, [
|
|
366
|
+
{ name: '_id_', key: { _id: 1 }, unique: true }
|
|
367
|
+
]);
|
|
368
|
+
const existingIdx = indexes.findIndex(i => i.name === indexName);
|
|
369
|
+
if (existingIdx >= 0) {
|
|
370
|
+
indexes[existingIdx] = { name: indexName, ...indexSpec };
|
|
371
|
+
}
|
|
372
|
+
else {
|
|
373
|
+
indexes.push({ name: indexName, ...indexSpec });
|
|
374
|
+
}
|
|
375
|
+
await this.writeJsonFile(indexPath, indexes);
|
|
376
|
+
}
|
|
377
|
+
async getIndexes(dbName, collName) {
|
|
378
|
+
const indexPath = this.getIndexPath(dbName, collName);
|
|
379
|
+
return this.readJsonFile(indexPath, [{ name: '_id_', key: { _id: 1 }, unique: true }]);
|
|
380
|
+
}
|
|
381
|
+
async dropIndex(dbName, collName, indexName) {
|
|
382
|
+
if (indexName === '_id_') {
|
|
383
|
+
throw new Error('Cannot drop _id index');
|
|
384
|
+
}
|
|
385
|
+
const indexPath = this.getIndexPath(dbName, collName);
|
|
386
|
+
const indexes = await this.readJsonFile(indexPath, []);
|
|
387
|
+
const idx = indexes.findIndex(i => i.name === indexName);
|
|
388
|
+
if (idx >= 0) {
|
|
389
|
+
indexes.splice(idx, 1);
|
|
390
|
+
await this.writeJsonFile(indexPath, indexes);
|
|
391
|
+
return true;
|
|
392
|
+
}
|
|
393
|
+
return false;
|
|
394
|
+
}
|
|
395
|
+
// ============================================================================
|
|
396
|
+
// OpLog Operations
|
|
397
|
+
// ============================================================================
|
|
398
|
+
async appendOpLog(entry) {
|
|
399
|
+
const opLogPath = this.getOpLogPath();
|
|
400
|
+
const opLog = await this.readJsonFile(opLogPath, []);
|
|
401
|
+
opLog.push(entry);
|
|
402
|
+
// Trim oplog if it gets too large
|
|
403
|
+
if (opLog.length > 10000) {
|
|
404
|
+
opLog.splice(0, opLog.length - 10000);
|
|
405
|
+
}
|
|
406
|
+
await this.writeJsonFile(opLogPath, opLog);
|
|
407
|
+
}
|
|
408
|
+
async getOpLogAfter(ts, limit = 1000) {
|
|
409
|
+
const opLogPath = this.getOpLogPath();
|
|
410
|
+
const opLog = await this.readJsonFile(opLogPath, []);
|
|
411
|
+
const tsValue = ts.toNumber();
|
|
412
|
+
const entries = opLog.filter(e => {
|
|
413
|
+
const entryTs = e.ts.toNumber ? e.ts.toNumber() : (e.ts.t * 4294967296 + e.ts.i);
|
|
414
|
+
return entryTs > tsValue;
|
|
415
|
+
});
|
|
416
|
+
return entries.slice(0, limit);
|
|
417
|
+
}
|
|
418
|
+
async getLatestOpLogTimestamp() {
|
|
419
|
+
const opLogPath = this.getOpLogPath();
|
|
420
|
+
const opLog = await this.readJsonFile(opLogPath, []);
|
|
421
|
+
if (opLog.length === 0)
|
|
422
|
+
return null;
|
|
423
|
+
const last = opLog[opLog.length - 1];
|
|
424
|
+
if (last.ts instanceof plugins.bson.Timestamp) {
|
|
425
|
+
return last.ts;
|
|
426
|
+
}
|
|
427
|
+
return new plugins.bson.Timestamp({ t: last.ts.t, i: last.ts.i });
|
|
428
|
+
}
|
|
429
|
+
generateTimestamp() {
|
|
430
|
+
this.opLogCounter++;
|
|
431
|
+
return new plugins.bson.Timestamp({ t: Math.floor(Date.now() / 1000), i: this.opLogCounter });
|
|
432
|
+
}
|
|
433
|
+
// ============================================================================
|
|
434
|
+
// Transaction Support
|
|
435
|
+
// ============================================================================
|
|
436
|
+
async createSnapshot(dbName, collName) {
|
|
437
|
+
const docs = await this.findAll(dbName, collName);
|
|
438
|
+
return docs.map(doc => JSON.parse(JSON.stringify(doc)));
|
|
439
|
+
}
|
|
440
|
+
async hasConflicts(dbName, collName, ids, snapshotTime) {
|
|
441
|
+
const opLogPath = this.getOpLogPath();
|
|
442
|
+
const opLog = await this.readJsonFile(opLogPath, []);
|
|
443
|
+
const ns = `${dbName}.${collName}`;
|
|
444
|
+
const snapshotTs = snapshotTime.toNumber();
|
|
445
|
+
const modifiedIds = new Set();
|
|
446
|
+
for (const entry of opLog) {
|
|
447
|
+
const entryTs = entry.ts.toNumber ? entry.ts.toNumber() : (entry.ts.t * 4294967296 + entry.ts.i);
|
|
448
|
+
if (entryTs > snapshotTs && entry.ns === ns) {
|
|
449
|
+
if (entry.o._id) {
|
|
450
|
+
modifiedIds.add(entry.o._id.toString());
|
|
451
|
+
}
|
|
452
|
+
if (entry.o2?._id) {
|
|
453
|
+
modifiedIds.add(entry.o2._id.toString());
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
for (const id of ids) {
|
|
458
|
+
if (modifiedIds.has(id.toString())) {
|
|
459
|
+
return true;
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
return false;
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FileStorageAdapter.js","sourceRoot":"","sources":["../../../ts/tsmdb/storage/FileStorageAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type * as plugins from '../
|
|
1
|
+
import type * as plugins from '../tsmdb.plugins.js';
|
|
2
2
|
import type { IStoredDocument, IOpLogEntry, Document } from '../types/interfaces.js';
|
|
3
3
|
/**
|
|
4
|
-
* Storage adapter interface for
|
|
4
|
+
* Storage adapter interface for TsmDB
|
|
5
5
|
* Implementations can provide different storage backends (memory, file, etc.)
|
|
6
6
|
*/
|
|
7
7
|
export interface IStorageAdapter {
|
|
@@ -63,6 +63,11 @@ export interface IStorageAdapter {
|
|
|
63
63
|
* Find all documents in a collection
|
|
64
64
|
*/
|
|
65
65
|
findAll(dbName: string, collName: string): Promise<IStoredDocument[]>;
|
|
66
|
+
/**
|
|
67
|
+
* Find documents by a set of _id strings (hex format)
|
|
68
|
+
* Used for index-accelerated queries
|
|
69
|
+
*/
|
|
70
|
+
findByIds(dbName: string, collName: string, ids: Set<string>): Promise<IStoredDocument[]>;
|
|
66
71
|
/**
|
|
67
72
|
* Find a document by _id
|
|
68
73
|
*/
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSVN0b3JhZ2VBZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vdHMvdHNtZGIvc3RvcmFnZS9JU3RvcmFnZUFkYXB0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
|
|
@@ -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
|
-
* In-memory storage adapter for
|
|
5
|
+
* In-memory storage adapter for TsmDB
|
|
6
6
|
* Optionally supports persistence to a file
|
|
7
7
|
*/
|
|
8
8
|
export declare class MemoryStorageAdapter implements IStorageAdapter {
|
|
@@ -33,6 +33,7 @@ export declare class MemoryStorageAdapter implements IStorageAdapter {
|
|
|
33
33
|
insertOne(dbName: string, collName: string, doc: Document): Promise<IStoredDocument>;
|
|
34
34
|
insertMany(dbName: string, collName: string, docs: Document[]): Promise<IStoredDocument[]>;
|
|
35
35
|
findAll(dbName: string, collName: string): Promise<IStoredDocument[]>;
|
|
36
|
+
findByIds(dbName: string, collName: string, ids: Set<string>): Promise<IStoredDocument[]>;
|
|
36
37
|
findById(dbName: string, collName: string, id: plugins.bson.ObjectId): Promise<IStoredDocument | null>;
|
|
37
38
|
updateById(dbName: string, collName: string, id: plugins.bson.ObjectId, doc: IStoredDocument): Promise<boolean>;
|
|
38
39
|
deleteById(dbName: string, collName: string, id: plugins.bson.ObjectId): Promise<boolean>;
|