@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,291 @@
|
|
|
1
|
+
import * as plugins from '../../tsmdb.plugins.js';
|
|
2
|
+
import { QueryEngine } from '../../engine/QueryEngine.js';
|
|
3
|
+
/**
|
|
4
|
+
* FindHandler - Handles find, getMore, killCursors, count, distinct commands
|
|
5
|
+
*/
|
|
6
|
+
export class FindHandler {
|
|
7
|
+
cursors;
|
|
8
|
+
nextCursorId;
|
|
9
|
+
constructor(cursors, nextCursorId) {
|
|
10
|
+
this.cursors = cursors;
|
|
11
|
+
this.nextCursorId = nextCursorId;
|
|
12
|
+
}
|
|
13
|
+
async handle(context) {
|
|
14
|
+
const { command } = context;
|
|
15
|
+
// Determine which operation to perform
|
|
16
|
+
if (command.find) {
|
|
17
|
+
return this.handleFind(context);
|
|
18
|
+
}
|
|
19
|
+
else if (command.getMore !== undefined) {
|
|
20
|
+
return this.handleGetMore(context);
|
|
21
|
+
}
|
|
22
|
+
else if (command.killCursors) {
|
|
23
|
+
return this.handleKillCursors(context);
|
|
24
|
+
}
|
|
25
|
+
else if (command.count) {
|
|
26
|
+
return this.handleCount(context);
|
|
27
|
+
}
|
|
28
|
+
else if (command.distinct) {
|
|
29
|
+
return this.handleDistinct(context);
|
|
30
|
+
}
|
|
31
|
+
return {
|
|
32
|
+
ok: 0,
|
|
33
|
+
errmsg: 'Unknown find-related command',
|
|
34
|
+
code: 59,
|
|
35
|
+
codeName: 'CommandNotFound',
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Handle find command
|
|
40
|
+
*/
|
|
41
|
+
async handleFind(context) {
|
|
42
|
+
const { storage, database, command, getIndexEngine } = context;
|
|
43
|
+
const collection = command.find;
|
|
44
|
+
const filter = command.filter || {};
|
|
45
|
+
const projection = command.projection;
|
|
46
|
+
const sort = command.sort;
|
|
47
|
+
const skip = command.skip || 0;
|
|
48
|
+
const limit = command.limit || 0;
|
|
49
|
+
const batchSize = command.batchSize || 101;
|
|
50
|
+
const singleBatch = command.singleBatch || false;
|
|
51
|
+
// Ensure collection exists
|
|
52
|
+
const exists = await storage.collectionExists(database, collection);
|
|
53
|
+
if (!exists) {
|
|
54
|
+
// Return empty cursor for non-existent collection
|
|
55
|
+
return {
|
|
56
|
+
ok: 1,
|
|
57
|
+
cursor: {
|
|
58
|
+
id: plugins.bson.Long.fromNumber(0),
|
|
59
|
+
ns: `${database}.${collection}`,
|
|
60
|
+
firstBatch: [],
|
|
61
|
+
},
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
// Try to use index-accelerated query
|
|
65
|
+
const indexEngine = getIndexEngine(collection);
|
|
66
|
+
const candidateIds = await indexEngine.findCandidateIds(filter);
|
|
67
|
+
let documents;
|
|
68
|
+
if (candidateIds !== null) {
|
|
69
|
+
// Index hit - fetch only candidate documents
|
|
70
|
+
documents = await storage.findByIds(database, collection, candidateIds);
|
|
71
|
+
// Still apply filter for any conditions the index couldn't fully satisfy
|
|
72
|
+
documents = QueryEngine.filter(documents, filter);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
// No suitable index - full collection scan
|
|
76
|
+
documents = await storage.findAll(database, collection);
|
|
77
|
+
// Apply filter
|
|
78
|
+
documents = QueryEngine.filter(documents, filter);
|
|
79
|
+
}
|
|
80
|
+
// Apply sort
|
|
81
|
+
if (sort) {
|
|
82
|
+
documents = QueryEngine.sort(documents, sort);
|
|
83
|
+
}
|
|
84
|
+
// Apply skip
|
|
85
|
+
if (skip > 0) {
|
|
86
|
+
documents = documents.slice(skip);
|
|
87
|
+
}
|
|
88
|
+
// Apply limit
|
|
89
|
+
if (limit > 0) {
|
|
90
|
+
documents = documents.slice(0, limit);
|
|
91
|
+
}
|
|
92
|
+
// Apply projection
|
|
93
|
+
if (projection) {
|
|
94
|
+
documents = QueryEngine.project(documents, projection);
|
|
95
|
+
}
|
|
96
|
+
// Determine how many documents to return in first batch
|
|
97
|
+
const effectiveBatchSize = Math.min(batchSize, documents.length);
|
|
98
|
+
const firstBatch = documents.slice(0, effectiveBatchSize);
|
|
99
|
+
const remaining = documents.slice(effectiveBatchSize);
|
|
100
|
+
// Create cursor if there are more documents
|
|
101
|
+
let cursorId = BigInt(0);
|
|
102
|
+
if (remaining.length > 0 && !singleBatch) {
|
|
103
|
+
cursorId = this.nextCursorId();
|
|
104
|
+
this.cursors.set(cursorId, {
|
|
105
|
+
id: cursorId,
|
|
106
|
+
database,
|
|
107
|
+
collection,
|
|
108
|
+
documents: remaining,
|
|
109
|
+
position: 0,
|
|
110
|
+
batchSize,
|
|
111
|
+
createdAt: new Date(),
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
return {
|
|
115
|
+
ok: 1,
|
|
116
|
+
cursor: {
|
|
117
|
+
id: plugins.bson.Long.fromBigInt(cursorId),
|
|
118
|
+
ns: `${database}.${collection}`,
|
|
119
|
+
firstBatch,
|
|
120
|
+
},
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Handle getMore command
|
|
125
|
+
*/
|
|
126
|
+
async handleGetMore(context) {
|
|
127
|
+
const { database, command } = context;
|
|
128
|
+
const cursorIdInput = command.getMore;
|
|
129
|
+
const collection = command.collection;
|
|
130
|
+
const batchSize = command.batchSize || 101;
|
|
131
|
+
// Convert cursorId to bigint
|
|
132
|
+
let cursorId;
|
|
133
|
+
if (typeof cursorIdInput === 'bigint') {
|
|
134
|
+
cursorId = cursorIdInput;
|
|
135
|
+
}
|
|
136
|
+
else if (cursorIdInput instanceof plugins.bson.Long) {
|
|
137
|
+
cursorId = cursorIdInput.toBigInt();
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
cursorId = BigInt(cursorIdInput);
|
|
141
|
+
}
|
|
142
|
+
const cursor = this.cursors.get(cursorId);
|
|
143
|
+
if (!cursor) {
|
|
144
|
+
return {
|
|
145
|
+
ok: 0,
|
|
146
|
+
errmsg: `cursor id ${cursorId} not found`,
|
|
147
|
+
code: 43,
|
|
148
|
+
codeName: 'CursorNotFound',
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
// Verify namespace
|
|
152
|
+
if (cursor.database !== database || cursor.collection !== collection) {
|
|
153
|
+
return {
|
|
154
|
+
ok: 0,
|
|
155
|
+
errmsg: 'cursor namespace mismatch',
|
|
156
|
+
code: 43,
|
|
157
|
+
codeName: 'CursorNotFound',
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
// Get next batch
|
|
161
|
+
const start = cursor.position;
|
|
162
|
+
const end = Math.min(start + batchSize, cursor.documents.length);
|
|
163
|
+
const nextBatch = cursor.documents.slice(start, end);
|
|
164
|
+
cursor.position = end;
|
|
165
|
+
// Check if cursor is exhausted
|
|
166
|
+
let returnCursorId = cursorId;
|
|
167
|
+
if (cursor.position >= cursor.documents.length) {
|
|
168
|
+
this.cursors.delete(cursorId);
|
|
169
|
+
returnCursorId = BigInt(0);
|
|
170
|
+
}
|
|
171
|
+
return {
|
|
172
|
+
ok: 1,
|
|
173
|
+
cursor: {
|
|
174
|
+
id: plugins.bson.Long.fromBigInt(returnCursorId),
|
|
175
|
+
ns: `${database}.${collection}`,
|
|
176
|
+
nextBatch,
|
|
177
|
+
},
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Handle killCursors command
|
|
182
|
+
*/
|
|
183
|
+
async handleKillCursors(context) {
|
|
184
|
+
const { command } = context;
|
|
185
|
+
const collection = command.killCursors;
|
|
186
|
+
const cursorIds = command.cursors || [];
|
|
187
|
+
const cursorsKilled = [];
|
|
188
|
+
const cursorsNotFound = [];
|
|
189
|
+
const cursorsUnknown = [];
|
|
190
|
+
for (const idInput of cursorIds) {
|
|
191
|
+
let cursorId;
|
|
192
|
+
if (typeof idInput === 'bigint') {
|
|
193
|
+
cursorId = idInput;
|
|
194
|
+
}
|
|
195
|
+
else if (idInput instanceof plugins.bson.Long) {
|
|
196
|
+
cursorId = idInput.toBigInt();
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
cursorId = BigInt(idInput);
|
|
200
|
+
}
|
|
201
|
+
if (this.cursors.has(cursorId)) {
|
|
202
|
+
this.cursors.delete(cursorId);
|
|
203
|
+
cursorsKilled.push(plugins.bson.Long.fromBigInt(cursorId));
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
cursorsNotFound.push(plugins.bson.Long.fromBigInt(cursorId));
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
return {
|
|
210
|
+
ok: 1,
|
|
211
|
+
cursorsKilled,
|
|
212
|
+
cursorsNotFound,
|
|
213
|
+
cursorsUnknown,
|
|
214
|
+
cursorsAlive: [],
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Handle count command
|
|
219
|
+
*/
|
|
220
|
+
async handleCount(context) {
|
|
221
|
+
const { storage, database, command, getIndexEngine } = context;
|
|
222
|
+
const collection = command.count;
|
|
223
|
+
const query = command.query || {};
|
|
224
|
+
const skip = command.skip || 0;
|
|
225
|
+
const limit = command.limit || 0;
|
|
226
|
+
// Check if collection exists
|
|
227
|
+
const exists = await storage.collectionExists(database, collection);
|
|
228
|
+
if (!exists) {
|
|
229
|
+
return { ok: 1, n: 0 };
|
|
230
|
+
}
|
|
231
|
+
// Try to use index-accelerated query
|
|
232
|
+
const indexEngine = getIndexEngine(collection);
|
|
233
|
+
const candidateIds = await indexEngine.findCandidateIds(query);
|
|
234
|
+
let documents;
|
|
235
|
+
if (candidateIds !== null) {
|
|
236
|
+
// Index hit - fetch only candidate documents
|
|
237
|
+
documents = await storage.findByIds(database, collection, candidateIds);
|
|
238
|
+
documents = QueryEngine.filter(documents, query);
|
|
239
|
+
}
|
|
240
|
+
else {
|
|
241
|
+
// No suitable index - full collection scan
|
|
242
|
+
documents = await storage.findAll(database, collection);
|
|
243
|
+
documents = QueryEngine.filter(documents, query);
|
|
244
|
+
}
|
|
245
|
+
// Apply skip
|
|
246
|
+
if (skip > 0) {
|
|
247
|
+
documents = documents.slice(skip);
|
|
248
|
+
}
|
|
249
|
+
// Apply limit
|
|
250
|
+
if (limit > 0) {
|
|
251
|
+
documents = documents.slice(0, limit);
|
|
252
|
+
}
|
|
253
|
+
return { ok: 1, n: documents.length };
|
|
254
|
+
}
|
|
255
|
+
/**
|
|
256
|
+
* Handle distinct command
|
|
257
|
+
*/
|
|
258
|
+
async handleDistinct(context) {
|
|
259
|
+
const { storage, database, command, getIndexEngine } = context;
|
|
260
|
+
const collection = command.distinct;
|
|
261
|
+
const key = command.key;
|
|
262
|
+
const query = command.query || {};
|
|
263
|
+
if (!key) {
|
|
264
|
+
return {
|
|
265
|
+
ok: 0,
|
|
266
|
+
errmsg: 'distinct requires a key',
|
|
267
|
+
code: 2,
|
|
268
|
+
codeName: 'BadValue',
|
|
269
|
+
};
|
|
270
|
+
}
|
|
271
|
+
// Check if collection exists
|
|
272
|
+
const exists = await storage.collectionExists(database, collection);
|
|
273
|
+
if (!exists) {
|
|
274
|
+
return { ok: 1, values: [] };
|
|
275
|
+
}
|
|
276
|
+
// Try to use index-accelerated query
|
|
277
|
+
const indexEngine = getIndexEngine(collection);
|
|
278
|
+
const candidateIds = await indexEngine.findCandidateIds(query);
|
|
279
|
+
let documents;
|
|
280
|
+
if (candidateIds !== null) {
|
|
281
|
+
documents = await storage.findByIds(database, collection, candidateIds);
|
|
282
|
+
}
|
|
283
|
+
else {
|
|
284
|
+
documents = await storage.findAll(database, collection);
|
|
285
|
+
}
|
|
286
|
+
// Get distinct values
|
|
287
|
+
const values = QueryEngine.distinct(documents, key, query);
|
|
288
|
+
return { ok: 1, values };
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRmluZEhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90cy90c21kYi9zZXJ2ZXIvaGFuZGxlcnMvRmluZEhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSx3QkFBd0IsQ0FBQztBQUdsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFMUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sV0FBVztJQUNkLE9BQU8sQ0FBNEI7SUFDbkMsWUFBWSxDQUFlO0lBRW5DLFlBQ0UsT0FBa0MsRUFDbEMsWUFBMEI7UUFFMUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFDdkIsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDbkMsQ0FBQztJQUVELEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBd0I7UUFDbkMsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUU1Qix1Q0FBdUM7UUFDdkMsSUFBSSxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDakIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2xDLENBQUM7YUFBTSxJQUFJLE9BQU8sQ0FBQyxPQUFPLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDekMsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3JDLENBQUM7YUFBTSxJQUFJLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUMvQixPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN6QyxDQUFDO2FBQU0sSUFBSSxPQUFPLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDekIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ25DLENBQUM7YUFBTSxJQUFJLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUM1QixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdEMsQ0FBQztRQUVELE9BQU87WUFDTCxFQUFFLEVBQUUsQ0FBQztZQUNMLE1BQU0sRUFBRSw4QkFBOEI7WUFDdEMsSUFBSSxFQUFFLEVBQUU7WUFDUixRQUFRLEVBQUUsaUJBQWlCO1NBQzVCLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSyxLQUFLLENBQUMsVUFBVSxDQUFDLE9BQXdCO1FBQy9DLE1BQU0sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFFL0QsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQztRQUNoQyxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQztRQUNwQyxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDO1FBQ3RDLE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUM7UUFDMUIsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUM7UUFDL0IsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUM7UUFDakMsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLFNBQVMsSUFBSSxHQUFHLENBQUM7UUFDM0MsTUFBTSxXQUFXLEdBQUcsT0FBTyxDQUFDLFdBQVcsSUFBSSxLQUFLLENBQUM7UUFFakQsMkJBQTJCO1FBQzNCLE1BQU0sTUFBTSxHQUFHLE1BQU0sT0FBTyxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUNwRSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDWixrREFBa0Q7WUFDbEQsT0FBTztnQkFDTCxFQUFFLEVBQUUsQ0FBQztnQkFDTCxNQUFNLEVBQUU7b0JBQ04sRUFBRSxFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7b0JBQ25DLEVBQUUsRUFBRSxHQUFHLFFBQVEsSUFBSSxVQUFVLEVBQUU7b0JBQy9CLFVBQVUsRUFBRSxFQUFFO2lCQUNmO2FBQ0YsQ0FBQztRQUNKLENBQUM7UUFFRCxxQ0FBcUM7UUFDckMsTUFBTSxXQUFXLEdBQUcsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQy9DLE1BQU0sWUFBWSxHQUFHLE1BQU0sV0FBVyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRWhFLElBQUksU0FBNEIsQ0FBQztRQUNqQyxJQUFJLFlBQVksS0FBSyxJQUFJLEVBQUUsQ0FBQztZQUMxQiw2Q0FBNkM7WUFDN0MsU0FBUyxHQUFHLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLFlBQVksQ0FBQyxDQUFDO1lBQ3hFLHlFQUF5RTtZQUN6RSxTQUFTLEdBQUcsV0FBVyxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDcEQsQ0FBQzthQUFNLENBQUM7WUFDTiwyQ0FBMkM7WUFDM0MsU0FBUyxHQUFHLE1BQU0sT0FBTyxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDeEQsZUFBZTtZQUNmLFNBQVMsR0FBRyxXQUFXLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNwRCxDQUFDO1FBRUQsYUFBYTtRQUNiLElBQUksSUFBSSxFQUFFLENBQUM7WUFDVCxTQUFTLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDaEQsQ0FBQztRQUVELGFBQWE7UUFDYixJQUFJLElBQUksR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUNiLFNBQVMsR0FBRyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BDLENBQUM7UUFFRCxjQUFjO1FBQ2QsSUFBSSxLQUFLLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDZCxTQUFTLEdBQUcsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDeEMsQ0FBQztRQUVELG1CQUFtQjtRQUNuQixJQUFJLFVBQVUsRUFBRSxDQUFDO1lBQ2YsU0FBUyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBVSxDQUFDO1FBQ2xFLENBQUM7UUFFRCx3REFBd0Q7UUFDeEQsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDakUsTUFBTSxVQUFVLEdBQUcsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztRQUMxRCxNQUFNLFNBQVMsR0FBRyxTQUFTLENBQUMsS0FBSyxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFFdEQsNENBQTRDO1FBQzVDLElBQUksUUFBUSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN6QixJQUFJLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDekMsUUFBUSxHQUFHLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUU7Z0JBQ3pCLEVBQUUsRUFBRSxRQUFRO2dCQUNaLFFBQVE7Z0JBQ1IsVUFBVTtnQkFDVixTQUFTLEVBQUUsU0FBUztnQkFDcEIsUUFBUSxFQUFFLENBQUM7Z0JBQ1gsU0FBUztnQkFDVCxTQUFTLEVBQUUsSUFBSSxJQUFJLEVBQUU7YUFDdEIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUVELE9BQU87WUFDTCxFQUFFLEVBQUUsQ0FBQztZQUNMLE1BQU0sRUFBRTtnQkFDTixFQUFFLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztnQkFDMUMsRUFBRSxFQUFFLEdBQUcsUUFBUSxJQUFJLFVBQVUsRUFBRTtnQkFDL0IsVUFBVTthQUNYO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNLLEtBQUssQ0FBQyxhQUFhLENBQUMsT0FBd0I7UUFDbEQsTUFBTSxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFFdEMsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQztRQUN0QyxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDO1FBQ3RDLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLElBQUksR0FBRyxDQUFDO1FBRTNDLDZCQUE2QjtRQUM3QixJQUFJLFFBQWdCLENBQUM7UUFDckIsSUFBSSxPQUFPLGFBQWEsS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN0QyxRQUFRLEdBQUcsYUFBYSxDQUFDO1FBQzNCLENBQUM7YUFBTSxJQUFJLGFBQWEsWUFBWSxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3RELFFBQVEsR0FBRyxhQUFhLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDdEMsQ0FBQzthQUFNLENBQUM7WUFDTixRQUFRLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ25DLENBQUM7UUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDWixPQUFPO2dCQUNMLEVBQUUsRUFBRSxDQUFDO2dCQUNMLE1BQU0sRUFBRSxhQUFhLFFBQVEsWUFBWTtnQkFDekMsSUFBSSxFQUFFLEVBQUU7Z0JBQ1IsUUFBUSxFQUFFLGdCQUFnQjthQUMzQixDQUFDO1FBQ0osQ0FBQztRQUVELG1CQUFtQjtRQUNuQixJQUFJLE1BQU0sQ0FBQyxRQUFRLEtBQUssUUFBUSxJQUFJLE1BQU0sQ0FBQyxVQUFVLEtBQUssVUFBVSxFQUFFLENBQUM7WUFDckUsT0FBTztnQkFDTCxFQUFFLEVBQUUsQ0FBQztnQkFDTCxNQUFNLEVBQUUsMkJBQTJCO2dCQUNuQyxJQUFJLEVBQUUsRUFBRTtnQkFDUixRQUFRLEVBQUUsZ0JBQWdCO2FBQzNCLENBQUM7UUFDSixDQUFDO1FBRUQsaUJBQWlCO1FBQ2pCLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDOUIsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEdBQUcsU0FBUyxFQUFFLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDakUsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ3JELE1BQU0sQ0FBQyxRQUFRLEdBQUcsR0FBRyxDQUFDO1FBRXRCLCtCQUErQjtRQUMvQixJQUFJLGNBQWMsR0FBRyxRQUFRLENBQUM7UUFDOUIsSUFBSSxNQUFNLENBQUMsUUFBUSxJQUFJLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDOUIsY0FBYyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBRUQsT0FBTztZQUNMLEVBQUUsRUFBRSxDQUFDO1lBQ0wsTUFBTSxFQUFFO2dCQUNOLEVBQUUsRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsY0FBYyxDQUFDO2dCQUNoRCxFQUFFLEVBQUUsR0FBRyxRQUFRLElBQUksVUFBVSxFQUFFO2dCQUMvQixTQUFTO2FBQ1Y7U0FDRixDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0ssS0FBSyxDQUFDLGlCQUFpQixDQUFDLE9BQXdCO1FBQ3RELE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFFNUIsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUN2QyxNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQztRQUV4QyxNQUFNLGFBQWEsR0FBd0IsRUFBRSxDQUFDO1FBQzlDLE1BQU0sZUFBZSxHQUF3QixFQUFFLENBQUM7UUFDaEQsTUFBTSxjQUFjLEdBQXdCLEVBQUUsQ0FBQztRQUUvQyxLQUFLLE1BQU0sT0FBTyxJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ2hDLElBQUksUUFBZ0IsQ0FBQztZQUNyQixJQUFJLE9BQU8sT0FBTyxLQUFLLFFBQVEsRUFBRSxDQUFDO2dCQUNoQyxRQUFRLEdBQUcsT0FBTyxDQUFDO1lBQ3JCLENBQUM7aUJBQU0sSUFBSSxPQUFPLFlBQVksT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDaEQsUUFBUSxHQUFHLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNoQyxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sUUFBUSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM3QixDQUFDO1lBRUQsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO2dCQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDOUIsYUFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztZQUM3RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sZUFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztZQUMvRCxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU87WUFDTCxFQUFFLEVBQUUsQ0FBQztZQUNMLGFBQWE7WUFDYixlQUFlO1lBQ2YsY0FBYztZQUNkLFlBQVksRUFBRSxFQUFFO1NBQ2pCLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSyxLQUFLLENBQUMsV0FBVyxDQUFDLE9BQXdCO1FBQ2hELE1BQU0sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFFL0QsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQztRQUNqQyxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQztRQUNsQyxNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQztRQUMvQixNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQztRQUVqQyw2QkFBNkI7UUFDN0IsTUFBTSxNQUFNLEdBQUcsTUFBTSxPQUFPLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQ3BFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNaLE9BQU8sRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUN6QixDQUFDO1FBRUQscUNBQXFDO1FBQ3JDLE1BQU0sV0FBVyxHQUFHLGNBQWMsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUMvQyxNQUFNLFlBQVksR0FBRyxNQUFNLFdBQVcsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUUvRCxJQUFJLFNBQTRCLENBQUM7UUFDakMsSUFBSSxZQUFZLEtBQUssSUFBSSxFQUFFLENBQUM7WUFDMUIsNkNBQTZDO1lBQzdDLFNBQVMsR0FBRyxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLFVBQVUsRUFBRSxZQUFZLENBQUMsQ0FBQztZQUN4RSxTQUFTLEdBQUcsV0FBVyxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDbkQsQ0FBQzthQUFNLENBQUM7WUFDTiwyQ0FBMkM7WUFDM0MsU0FBUyxHQUFHLE1BQU0sT0FBTyxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDeEQsU0FBUyxHQUFHLFdBQVcsQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ25ELENBQUM7UUFFRCxhQUFhO1FBQ2IsSUFBSSxJQUFJLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDYixTQUFTLEdBQUcsU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwQyxDQUFDO1FBRUQsY0FBYztRQUNkLElBQUksS0FBSyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2QsU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3hDLENBQUM7UUFFRCxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ3hDLENBQUM7SUFFRDs7T0FFRztJQUNLLEtBQUssQ0FBQyxjQUFjLENBQUMsT0FBd0I7UUFDbkQsTUFBTSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUUvRCxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDO1FBQ3BDLE1BQU0sR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUM7UUFDeEIsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUM7UUFFbEMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO1lBQ1QsT0FBTztnQkFDTCxFQUFFLEVBQUUsQ0FBQztnQkFDTCxNQUFNLEVBQUUseUJBQXlCO2dCQUNqQyxJQUFJLEVBQUUsQ0FBQztnQkFDUCxRQUFRLEVBQUUsVUFBVTthQUNyQixDQUFDO1FBQ0osQ0FBQztRQUVELDZCQUE2QjtRQUM3QixNQUFNLE1BQU0sR0FBRyxNQUFNLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDcEUsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ1osT0FBTyxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxDQUFDO1FBQy9CLENBQUM7UUFFRCxxQ0FBcUM7UUFDckMsTUFBTSxXQUFXLEdBQUcsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQy9DLE1BQU0sWUFBWSxHQUFHLE1BQU0sV0FBVyxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRS9ELElBQUksU0FBNEIsQ0FBQztRQUNqQyxJQUFJLFlBQVksS0FBSyxJQUFJLEVBQUUsQ0FBQztZQUMxQixTQUFTLEdBQUcsTUFBTSxPQUFPLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxVQUFVLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFDMUUsQ0FBQzthQUFNLENBQUM7WUFDTixTQUFTLEdBQUcsTUFBTSxPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUMxRCxDQUFDO1FBRUQsc0JBQXNCO1FBQ3RCLE1BQU0sTUFBTSxHQUFHLFdBQVcsQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUUzRCxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQztJQUMzQixDQUFDO0NBQ0YifQ==
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as plugins from '../../
|
|
1
|
+
import * as plugins from '../../tsmdb.plugins.js';
|
|
2
2
|
/**
|
|
3
3
|
* HelloHandler - Handles hello/isMaster handshake commands
|
|
4
4
|
*
|
|
@@ -59,4 +59,4 @@ export class HelloHandler {
|
|
|
59
59
|
return response;
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVsbG9IYW5kbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdHMvdHNtZGIvc2VydmVyL2hhbmRsZXJzL0hlbGxvSGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHdCQUF3QixDQUFDO0FBR2xEOzs7OztHQUtHO0FBQ0gsTUFBTSxPQUFPLFlBQVk7SUFDdkIsS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUF3QjtRQUNuQyxNQUFNLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUVwQywwQ0FBMEM7UUFDMUMsTUFBTSxRQUFRLEdBQTBCO1lBQ3RDLFFBQVEsRUFBRSxJQUFJO1lBQ2QsRUFBRSxFQUFFLENBQUM7WUFFTCxnQkFBZ0I7WUFDaEIsaUJBQWlCLEVBQUUsUUFBUSxFQUFZLFFBQVE7WUFDL0MsbUJBQW1CLEVBQUUsUUFBUSxFQUFVLFFBQVE7WUFDL0MsaUJBQWlCLEVBQUUsTUFBTSxFQUFjLDJCQUEyQjtZQUVsRSxhQUFhO1lBQ2IsU0FBUyxFQUFFLElBQUksSUFBSSxFQUFFO1lBRXJCLGtCQUFrQjtZQUNsQiw0QkFBNEIsRUFBRSxFQUFFO1lBRWhDLGtCQUFrQjtZQUNsQixZQUFZLEVBQUUsQ0FBQztZQUVmLDJEQUEyRDtZQUMzRCxjQUFjLEVBQUUsQ0FBQztZQUNqQixjQUFjLEVBQUUsRUFBRTtZQUVsQixjQUFjO1lBQ2QsUUFBUSxFQUFFLEtBQUs7WUFFZixrQ0FBa0M7WUFDbEMsaUJBQWlCLEVBQUUsSUFBSTtZQUV2QixrQkFBa0I7WUFDbEIsZUFBZSxFQUFFO2dCQUNmLFNBQVMsRUFBRSxJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUN0QyxPQUFPLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQzthQUN6QztTQUNGLENBQUM7UUFFRiwrQkFBK0I7UUFDL0IsSUFBSSxPQUFPLENBQUMsS0FBSyxJQUFJLE9BQU8sQ0FBQyxLQUFLLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDekMsUUFBUSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDMUIsQ0FBQztRQUVELHlCQUF5QjtRQUN6QixJQUFJLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNuQiw0Q0FBNEM7WUFDNUMsMERBQTBEO1FBQzVELENBQUM7UUFFRCwrQkFBK0I7UUFDL0IsSUFBSSxPQUFPLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztZQUMvQixRQUFRLENBQUMsa0JBQWtCLEdBQUc7WUFDNUIsbUVBQW1FO2FBQ3BFLENBQUM7UUFDSixDQUFDO1FBRUQscUNBQXFDO1FBQ3JDLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3hCLFFBQVEsQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1FBQzVCLENBQUM7UUFFRCxzQkFBc0I7UUFDdEIsUUFBUSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFFM0IsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztDQUNGIn0=
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import * as plugins from '../../tsmdb.plugins.js';
|
|
2
|
+
import { IndexEngine } from '../../engine/IndexEngine.js';
|
|
3
|
+
// Cache of index engines per collection
|
|
4
|
+
const indexEngines = new Map();
|
|
5
|
+
/**
|
|
6
|
+
* Get or create an IndexEngine for a collection
|
|
7
|
+
*/
|
|
8
|
+
function getIndexEngine(storage, database, collection) {
|
|
9
|
+
const key = `${database}.${collection}`;
|
|
10
|
+
let engine = indexEngines.get(key);
|
|
11
|
+
if (!engine) {
|
|
12
|
+
engine = new IndexEngine(database, collection, storage);
|
|
13
|
+
indexEngines.set(key, engine);
|
|
14
|
+
}
|
|
15
|
+
return engine;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* IndexHandler - Handles createIndexes, dropIndexes, listIndexes commands
|
|
19
|
+
*/
|
|
20
|
+
export class IndexHandler {
|
|
21
|
+
async handle(context) {
|
|
22
|
+
const { command } = context;
|
|
23
|
+
if (command.createIndexes) {
|
|
24
|
+
return this.handleCreateIndexes(context);
|
|
25
|
+
}
|
|
26
|
+
else if (command.dropIndexes) {
|
|
27
|
+
return this.handleDropIndexes(context);
|
|
28
|
+
}
|
|
29
|
+
else if (command.listIndexes) {
|
|
30
|
+
return this.handleListIndexes(context);
|
|
31
|
+
}
|
|
32
|
+
return {
|
|
33
|
+
ok: 0,
|
|
34
|
+
errmsg: 'Unknown index command',
|
|
35
|
+
code: 59,
|
|
36
|
+
codeName: 'CommandNotFound',
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Handle createIndexes command
|
|
41
|
+
*/
|
|
42
|
+
async handleCreateIndexes(context) {
|
|
43
|
+
const { storage, database, command } = context;
|
|
44
|
+
const collection = command.createIndexes;
|
|
45
|
+
const indexes = command.indexes || [];
|
|
46
|
+
if (!Array.isArray(indexes)) {
|
|
47
|
+
return {
|
|
48
|
+
ok: 0,
|
|
49
|
+
errmsg: 'indexes must be an array',
|
|
50
|
+
code: 2,
|
|
51
|
+
codeName: 'BadValue',
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
// Ensure collection exists
|
|
55
|
+
await storage.createCollection(database, collection);
|
|
56
|
+
const indexEngine = getIndexEngine(storage, database, collection);
|
|
57
|
+
const createdNames = [];
|
|
58
|
+
let numIndexesBefore = 0;
|
|
59
|
+
let numIndexesAfter = 0;
|
|
60
|
+
try {
|
|
61
|
+
const existingIndexes = await indexEngine.listIndexes();
|
|
62
|
+
numIndexesBefore = existingIndexes.length;
|
|
63
|
+
for (const indexSpec of indexes) {
|
|
64
|
+
const key = indexSpec.key;
|
|
65
|
+
const options = {
|
|
66
|
+
name: indexSpec.name,
|
|
67
|
+
unique: indexSpec.unique,
|
|
68
|
+
sparse: indexSpec.sparse,
|
|
69
|
+
expireAfterSeconds: indexSpec.expireAfterSeconds,
|
|
70
|
+
background: indexSpec.background,
|
|
71
|
+
partialFilterExpression: indexSpec.partialFilterExpression,
|
|
72
|
+
};
|
|
73
|
+
const name = await indexEngine.createIndex(key, options);
|
|
74
|
+
createdNames.push(name);
|
|
75
|
+
}
|
|
76
|
+
const finalIndexes = await indexEngine.listIndexes();
|
|
77
|
+
numIndexesAfter = finalIndexes.length;
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
return {
|
|
81
|
+
ok: 0,
|
|
82
|
+
errmsg: error.message || 'Failed to create index',
|
|
83
|
+
code: error.code || 1,
|
|
84
|
+
codeName: error.codeName || 'InternalError',
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
return {
|
|
88
|
+
ok: 1,
|
|
89
|
+
numIndexesBefore,
|
|
90
|
+
numIndexesAfter,
|
|
91
|
+
createdCollectionAutomatically: false,
|
|
92
|
+
commitQuorum: 'votingMembers',
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Handle dropIndexes command
|
|
97
|
+
*/
|
|
98
|
+
async handleDropIndexes(context) {
|
|
99
|
+
const { storage, database, command } = context;
|
|
100
|
+
const collection = command.dropIndexes;
|
|
101
|
+
const indexName = command.index;
|
|
102
|
+
// Check if collection exists
|
|
103
|
+
const exists = await storage.collectionExists(database, collection);
|
|
104
|
+
if (!exists) {
|
|
105
|
+
return {
|
|
106
|
+
ok: 0,
|
|
107
|
+
errmsg: `ns not found ${database}.${collection}`,
|
|
108
|
+
code: 26,
|
|
109
|
+
codeName: 'NamespaceNotFound',
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
const indexEngine = getIndexEngine(storage, database, collection);
|
|
113
|
+
try {
|
|
114
|
+
if (indexName === '*') {
|
|
115
|
+
// Drop all indexes except _id
|
|
116
|
+
await indexEngine.dropAllIndexes();
|
|
117
|
+
}
|
|
118
|
+
else if (typeof indexName === 'string') {
|
|
119
|
+
// Drop specific index by name
|
|
120
|
+
await indexEngine.dropIndex(indexName);
|
|
121
|
+
}
|
|
122
|
+
else if (typeof indexName === 'object') {
|
|
123
|
+
// Drop index by key specification
|
|
124
|
+
const indexes = await indexEngine.listIndexes();
|
|
125
|
+
const keyStr = JSON.stringify(indexName);
|
|
126
|
+
for (const idx of indexes) {
|
|
127
|
+
if (JSON.stringify(idx.key) === keyStr) {
|
|
128
|
+
await indexEngine.dropIndex(idx.name);
|
|
129
|
+
break;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return { ok: 1, nIndexesWas: 1 };
|
|
134
|
+
}
|
|
135
|
+
catch (error) {
|
|
136
|
+
return {
|
|
137
|
+
ok: 0,
|
|
138
|
+
errmsg: error.message || 'Failed to drop index',
|
|
139
|
+
code: error.code || 27,
|
|
140
|
+
codeName: error.codeName || 'IndexNotFound',
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Handle listIndexes command
|
|
146
|
+
*/
|
|
147
|
+
async handleListIndexes(context) {
|
|
148
|
+
const { storage, database, command } = context;
|
|
149
|
+
const collection = command.listIndexes;
|
|
150
|
+
const cursor = command.cursor || {};
|
|
151
|
+
const batchSize = cursor.batchSize || 101;
|
|
152
|
+
// Check if collection exists
|
|
153
|
+
const exists = await storage.collectionExists(database, collection);
|
|
154
|
+
if (!exists) {
|
|
155
|
+
return {
|
|
156
|
+
ok: 0,
|
|
157
|
+
errmsg: `ns not found ${database}.${collection}`,
|
|
158
|
+
code: 26,
|
|
159
|
+
codeName: 'NamespaceNotFound',
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
const indexEngine = getIndexEngine(storage, database, collection);
|
|
163
|
+
const indexes = await indexEngine.listIndexes();
|
|
164
|
+
// Format indexes for response
|
|
165
|
+
const indexDocs = indexes.map(idx => ({
|
|
166
|
+
v: idx.v || 2,
|
|
167
|
+
key: idx.key,
|
|
168
|
+
name: idx.name,
|
|
169
|
+
...(idx.unique ? { unique: idx.unique } : {}),
|
|
170
|
+
...(idx.sparse ? { sparse: idx.sparse } : {}),
|
|
171
|
+
...(idx.expireAfterSeconds !== undefined ? { expireAfterSeconds: idx.expireAfterSeconds } : {}),
|
|
172
|
+
}));
|
|
173
|
+
return {
|
|
174
|
+
ok: 1,
|
|
175
|
+
cursor: {
|
|
176
|
+
id: plugins.bson.Long.fromNumber(0),
|
|
177
|
+
ns: `${database}.${collection}`,
|
|
178
|
+
firstBatch: indexDocs,
|
|
179
|
+
},
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5kZXhIYW5kbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdHMvdHNtZGIvc2VydmVyL2hhbmRsZXJzL0luZGV4SGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHdCQUF3QixDQUFDO0FBRWxELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUUxRCx3Q0FBd0M7QUFDeEMsTUFBTSxZQUFZLEdBQTZCLElBQUksR0FBRyxFQUFFLENBQUM7QUFFekQ7O0dBRUc7QUFDSCxTQUFTLGNBQWMsQ0FBQyxPQUFZLEVBQUUsUUFBZ0IsRUFBRSxVQUFrQjtJQUN4RSxNQUFNLEdBQUcsR0FBRyxHQUFHLFFBQVEsSUFBSSxVQUFVLEVBQUUsQ0FBQztJQUN4QyxJQUFJLE1BQU0sR0FBRyxZQUFZLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRW5DLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNaLE1BQU0sR0FBRyxJQUFJLFdBQVcsQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ3hELFlBQVksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sWUFBWTtJQUN2QixLQUFLLENBQUMsTUFBTSxDQUFDLE9BQXdCO1FBQ25DLE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFFNUIsSUFBSSxPQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDMUIsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDM0MsQ0FBQzthQUFNLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQy9CLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFD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
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import * as plugins from '../../tsmdb.plugins.js';
|
|
2
|
+
/**
|
|
3
|
+
* InsertHandler - Handles insert commands
|
|
4
|
+
*/
|
|
5
|
+
export class InsertHandler {
|
|
6
|
+
async handle(context) {
|
|
7
|
+
const { storage, database, command, documentSequences } = context;
|
|
8
|
+
const collection = command.insert;
|
|
9
|
+
if (typeof collection !== 'string') {
|
|
10
|
+
return {
|
|
11
|
+
ok: 0,
|
|
12
|
+
errmsg: 'insert command requires a collection name',
|
|
13
|
+
code: 2,
|
|
14
|
+
codeName: 'BadValue',
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
// Get documents from command or document sequences
|
|
18
|
+
let documents = command.documents || [];
|
|
19
|
+
// Check for OP_MSG document sequences (for bulk inserts)
|
|
20
|
+
if (documentSequences && documentSequences.has('documents')) {
|
|
21
|
+
documents = documentSequences.get('documents');
|
|
22
|
+
}
|
|
23
|
+
if (!Array.isArray(documents) || documents.length === 0) {
|
|
24
|
+
return {
|
|
25
|
+
ok: 0,
|
|
26
|
+
errmsg: 'insert command requires documents array',
|
|
27
|
+
code: 2,
|
|
28
|
+
codeName: 'BadValue',
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
const ordered = command.ordered !== false;
|
|
32
|
+
const writeErrors = [];
|
|
33
|
+
let insertedCount = 0;
|
|
34
|
+
// Ensure collection exists
|
|
35
|
+
await storage.createCollection(database, collection);
|
|
36
|
+
const indexEngine = context.getIndexEngine(collection);
|
|
37
|
+
// Insert documents
|
|
38
|
+
for (let i = 0; i < documents.length; i++) {
|
|
39
|
+
const doc = documents[i];
|
|
40
|
+
try {
|
|
41
|
+
// Ensure _id exists
|
|
42
|
+
if (!doc._id) {
|
|
43
|
+
doc._id = new plugins.bson.ObjectId();
|
|
44
|
+
}
|
|
45
|
+
// Check index constraints before insert (doc now has _id)
|
|
46
|
+
await indexEngine.onInsert(doc);
|
|
47
|
+
await storage.insertOne(database, collection, doc);
|
|
48
|
+
insertedCount++;
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
const writeError = {
|
|
52
|
+
index: i,
|
|
53
|
+
code: error.code || 11000,
|
|
54
|
+
errmsg: error.message || 'Insert failed',
|
|
55
|
+
};
|
|
56
|
+
// Check for duplicate key error
|
|
57
|
+
if (error.message?.includes('Duplicate key')) {
|
|
58
|
+
writeError.code = 11000;
|
|
59
|
+
writeError.keyPattern = { _id: 1 };
|
|
60
|
+
writeError.keyValue = { _id: doc._id };
|
|
61
|
+
}
|
|
62
|
+
writeErrors.push(writeError);
|
|
63
|
+
if (ordered) {
|
|
64
|
+
// Stop on first error for ordered inserts
|
|
65
|
+
break;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
const response = {
|
|
70
|
+
ok: 1,
|
|
71
|
+
n: insertedCount,
|
|
72
|
+
};
|
|
73
|
+
if (writeErrors.length > 0) {
|
|
74
|
+
response.writeErrors = writeErrors;
|
|
75
|
+
}
|
|
76
|
+
return response;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5zZXJ0SGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3RzL3RzbWRiL3NlcnZlci9oYW5kbGVycy9JbnNlcnRIYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sd0JBQXdCLENBQUM7QUFJbEQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sYUFBYTtJQUN4QixLQUFLLENBQUMsTUFBTSxDQUFDLE9BQXdCO1FBQ25DLE1BQU0sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUVsRSxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDO1FBQ2xDLElBQUksT0FBTyxVQUFVLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDbkMsT0FBTztnQkFDTCxFQUFFLEVBQUUsQ0FBQztnQkFDTCxNQUFNLEVBQUUsMkNBQTJDO2dCQUNuRCxJQUFJLEVBQUUsQ0FBQztnQkFDUCxRQUFRLEVBQUUsVUFBVTthQUNyQixDQUFDO1FBQ0osQ0FBQztRQUVELG1EQUFtRDtRQUNuRCxJQUFJLFNBQVMsR0FBNEIsT0FBTyxDQUFDLFNBQVMsSUFBSSxFQUFFLENBQUM7UUFFakUseURBQXlEO1FBQ3pELElBQUksaUJBQWlCLElBQUksaUJBQWlCLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUFFLENBQUM7WUFDNUQsU0FBUyxHQUFHLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUUsQ0FBQztRQUNsRCxDQUFDO1FBRUQsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksU0FBUyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN4RCxPQUFPO2dCQUNMLEVBQUUsRUFBRSxDQUFDO2dCQUNMLE1BQU0sRUFBRSx5Q0FBeUM7Z0JBQ2pELElBQUksRUFBRSxDQUFDO2dCQUNQLFFBQVEsRUFBRSxVQUFVO2FBQ3JCLENBQUM7UUFDSixDQUFDO1FBRUQsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sS0FBSyxLQUFLLENBQUM7UUFDMUMsTUFBTSxXQUFXLEdBQTRCLEVBQUUsQ0FBQztRQUNoRCxJQUFJLGFBQWEsR0FBRyxDQUFDLENBQUM7UUFFdEIsMkJBQTJCO1FBQzNCLE1BQU0sT0FBTyxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUVyRCxNQUFNLFdBQVcsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRXZELG1CQUFtQjtRQUNuQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQzFDLE1BQU0sR0FBRyxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUV6QixJQUFJLENBQUM7Z0JBQ0gsb0JBQW9CO2dCQUNwQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO29CQUNiLEdBQUcsQ0FBQyxHQUFHLEdBQUcsSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUN4QyxDQUFDO2dCQUVELDBEQUEwRDtnQkFDMUQsTUFBTSxXQUFXLENBQUMsUUFBUSxDQUFDLEdBQXNCLENBQUMsQ0FBQztnQkFFbkQsTUFBTSxPQUFPLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUM7Z0JBQ25ELGFBQWEsRUFBRSxDQUFDO1lBQ2xCLENBQUM7WUFBQyxPQUFPLEtBQVUsRUFBRSxDQUFDO2dCQUNwQixNQUFNLFVBQVUsR0FBMEI7b0JBQ3hDLEtBQUssRUFBRSxDQUFDO29CQUNSLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSSxJQUFJLEtBQUs7b0JBQ3pCLE1BQU0sRUFBRSxLQUFLLENBQUMsT0FBTyxJQUFJLGVBQWU7aUJBQ3pDLENBQUM7Z0JBRUYsZ0NBQWdDO2dCQUNoQyxJQUFJLEtBQUssQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUM7b0JBQzdDLFVBQVUsQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO29CQUN4QixVQUFVLENBQUMsVUFBVSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDO29CQUNuQyxVQUFVLENBQUMsUUFBUSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztnQkFDekMsQ0FBQztnQkFFRCxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2dCQUU3QixJQUFJLE9BQU8sRUFBRSxDQUFDO29CQUNaLDBDQUEwQztvQkFDMUMsTUFBTTtnQkFDUixDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUM7UUFFRCxNQUFNLFFBQVEsR0FBMEI7WUFDdEMsRUFBRSxFQUFFLENBQUM7WUFDTCxDQUFDLEVBQUUsYUFBYTtTQUNqQixDQUFDO1FBRUYsSUFBSSxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzNCLFFBQVEsQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1FBQ3JDLENBQUM7UUFFRCxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDO0NBQ0YifQ==
|