@xyo-network/module-abstract-mongodb 4.0.2 → 4.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/build/node/Module.d.ts.map +1 -0
  2. package/{dist/types → build/node}/ModuleV2.d.ts.map +1 -1
  3. package/dist/node/index.d.ts +148 -0
  4. package/dist/node/index.mjs.map +1 -1
  5. package/package.json +17 -19
  6. package/src/Module.ts +2 -2
  7. package/xy.config.ts +11 -0
  8. package/dist/browser/index.mjs +0 -356
  9. package/dist/browser/index.mjs.map +0 -1
  10. package/dist/neutral/index.mjs +0 -356
  11. package/dist/neutral/index.mjs.map +0 -1
  12. package/dist/types/Module.d.ts.map +0 -1
  13. /package/{dist/types → build/node}/AnyAbstractModule.d.ts +0 -0
  14. /package/{dist/types → build/node}/AnyAbstractModule.d.ts.map +0 -0
  15. /package/{dist/types → build/node}/Collections.d.ts +0 -0
  16. /package/{dist/types → build/node}/Collections.d.ts.map +0 -0
  17. /package/{dist/types → build/node}/Databases.d.ts +0 -0
  18. /package/{dist/types → build/node}/Databases.d.ts.map +0 -0
  19. /package/{dist/types → build/node}/Defaults.d.ts +0 -0
  20. /package/{dist/types → build/node}/Defaults.d.ts.map +0 -0
  21. /package/{dist/types → build/node}/IndexDescription.d.ts +0 -0
  22. /package/{dist/types → build/node}/IndexDescription.d.ts.map +0 -0
  23. /package/{dist/types → build/node}/Indexes/CollectionIndexFunction.d.ts +0 -0
  24. /package/{dist/types → build/node}/Indexes/CollectionIndexFunction.d.ts.map +0 -0
  25. /package/{dist/types → build/node}/Indexes/index.d.ts +0 -0
  26. /package/{dist/types → build/node}/Indexes/index.d.ts.map +0 -0
  27. /package/{dist/types → build/node}/Module.d.ts +0 -0
  28. /package/{dist/types → build/node}/ModuleV2.d.ts +0 -0
  29. /package/{dist/types → build/node}/config/getBaseMongoSdk.d.ts +0 -0
  30. /package/{dist/types → build/node}/config/getBaseMongoSdk.d.ts.map +0 -0
  31. /package/{dist/types → build/node}/config/getMongoDBConfig.d.ts +0 -0
  32. /package/{dist/types → build/node}/config/getMongoDBConfig.d.ts.map +0 -0
  33. /package/{dist/types → build/node}/config/hasMongoDBConfig.d.ts +0 -0
  34. /package/{dist/types → build/node}/config/hasMongoDBConfig.d.ts.map +0 -0
  35. /package/{dist/types → build/node}/config/index.d.ts +0 -0
  36. /package/{dist/types → build/node}/config/index.d.ts.map +0 -0
  37. /package/{dist/types → build/node}/index.d.ts +0 -0
  38. /package/{dist/types → build/node}/index.d.ts.map +0 -0
  39. /package/{dist/types → build/node}/merge.d.ts +0 -0
  40. /package/{dist/types → build/node}/merge.d.ts.map +0 -0
  41. /package/{dist/types → build/node}/util/dbProperty.d.ts +0 -0
  42. /package/{dist/types → build/node}/util/dbProperty.d.ts.map +0 -0
  43. /package/{dist/types → build/node}/util/index.d.ts +0 -0
  44. /package/{dist/types → build/node}/util/index.d.ts.map +0 -0
@@ -1,356 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
4
- var __decorateClass = (decorators, target, key, kind) => {
5
- var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
6
- for (var i = decorators.length - 1, decorator; i >= 0; i--)
7
- if (decorator = decorators[i])
8
- result = (kind ? decorator(target, key, result) : decorator(result)) || result;
9
- if (kind && result) __defProp(target, key, result);
10
- return result;
11
- };
12
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
13
-
14
- // src/Collections.ts
15
- var COLLECTIONS = {
16
- AddressInfo: "address_info",
17
- ArchivistStats: "archivist_stats",
18
- BoundWitnesses: "bound_witnesses",
19
- Payloads: "payloads",
20
- Thumbnails: "thumbnails",
21
- Users: "users"
22
- };
23
-
24
- // src/config/getBaseMongoSdk.ts
25
- import { assertEx } from "@xylabs/assert";
26
- import { BaseMongoSdk } from "@xylabs/mongo";
27
-
28
- // src/config/getMongoDBConfig.ts
29
- var getMongoDBConfig = () => {
30
- const env = {};
31
- if (process.env.MONGO_CONNECTION_STRING) {
32
- env.MONGO_CONNECTION_STRING = process.env.MONGO_CONNECTION_STRING;
33
- }
34
- if (process.env.MONGO_DOMAIN) {
35
- env.MONGO_DATABASE = process.env.MONGO_DATABASE;
36
- env.MONGO_DOMAIN = process.env.MONGO_DOMAIN;
37
- env.MONGO_PASSWORD = process.env.MONGO_PASSWORD;
38
- env.MONGO_USERNAME = process.env.MONGO_USERNAME;
39
- }
40
- return env;
41
- };
42
-
43
- // src/config/getBaseMongoSdk.ts
44
- var getBaseMongoSdkPrivateConfig = () => {
45
- const env = getMongoDBConfig();
46
- return {
47
- dbConnectionString: env.MONGO_CONNECTION_STRING,
48
- dbDomain: assertEx(env.MONGO_DOMAIN, () => "Missing Mongo Domain"),
49
- dbName: assertEx(env.MONGO_DATABASE, () => "Missing Mongo Database"),
50
- dbPassword: assertEx(env.MONGO_PASSWORD, () => "Missing Mongo Password"),
51
- dbUserName: assertEx(env.MONGO_USERNAME, () => "Missing Mongo Username")
52
- };
53
- };
54
- var getBaseMongoSdk = (collection) => {
55
- return new BaseMongoSdk({ ...getBaseMongoSdkPrivateConfig(), collection });
56
- };
57
-
58
- // src/config/hasMongoDBConfig.ts
59
- import { exists } from "@xylabs/exists";
60
- var hasMongoDBConfig = () => {
61
- const env = getMongoDBConfig();
62
- const requiredValues = [env.MONGO_CONNECTION_STRING, env.MONGO_DATABASE, env.MONGO_DOMAIN, env.MONGO_PASSWORD, env.MONGO_USERNAME];
63
- return requiredValues.every(exists);
64
- };
65
-
66
- // src/Databases.ts
67
- var DATABASES = { Archivist: "archivist" };
68
-
69
- // src/Defaults.ts
70
- var DefaultAggregateTimeoutMs = 1e4;
71
- var DefaultLimit = 20;
72
- var DefaultMaxTimeMS = 2e3;
73
- var DefaultOrder = "desc";
74
-
75
- // src/Module.ts
76
- import { assertEx as assertEx2 } from "@xylabs/assert";
77
- import { BaseMongoSdk as BaseMongoSdk2 } from "@xylabs/mongo";
78
- import { staticImplements } from "@xylabs/static-implements";
79
- import {
80
- MongoDBStorageClassLabels
81
- } from "@xyo-network/module-model-mongodb";
82
-
83
- // src/merge.ts
84
- function isObject(val) {
85
- return val !== null && typeof val === "object";
86
- }
87
- function merge(target, ...sources) {
88
- if (!isObject(target)) {
89
- throw new TypeError("Target must be an object");
90
- }
91
- for (const source of sources) {
92
- if (!isObject(source)) {
93
- continue;
94
- }
95
- for (const key of Object.keys(source)) {
96
- const sourceVal = source[key];
97
- const targetVal = target[key];
98
- if (Array.isArray(sourceVal)) {
99
- target[key] = [...sourceVal];
100
- } else if (isObject(sourceVal)) {
101
- if (!isObject(targetVal)) {
102
- target[key] = {};
103
- }
104
- merge(target[key], sourceVal);
105
- } else {
106
- target[key] = sourceVal;
107
- }
108
- }
109
- }
110
- return target;
111
- }
112
-
113
- // src/Module.ts
114
- var standardIndexes = [
115
- {
116
- name: "IX__hash",
117
- key: { _hash: 1 },
118
- unique: false
119
- },
120
- {
121
- name: "IX__dataHash",
122
- key: { _dataHash: 1 },
123
- unique: false
124
- },
125
- {
126
- name: "IX__sequence",
127
- key: { _sequence: 1 },
128
- unique: false
129
- }
130
- ];
131
- var MongoDBModuleMixin = (ModuleBase) => {
132
- let MongoModuleBase = class extends ModuleBase {
133
- _boundWitnessSdk;
134
- _payloadSdk;
135
- get boundWitnessSdkConfig() {
136
- const config = { collection: COLLECTIONS.BoundWitnesses, ...getBaseMongoSdkPrivateConfig() };
137
- return merge(
138
- config,
139
- this.params.boundWitnessSdkConfig,
140
- this.config.boundWitnessSdkConfig,
141
- { collection: this.config.boundWitnessSdkConfig?.collection ?? this.params.boundWitnessSdkConfig?.collection ?? COLLECTIONS.BoundWitnesses }
142
- );
143
- }
144
- get boundWitnesses() {
145
- this._boundWitnessSdk = this._boundWitnessSdk ?? new BaseMongoSdk2(this.boundWitnessSdkConfig);
146
- return assertEx2(this._boundWitnessSdk);
147
- }
148
- get jobQueue() {
149
- return assertEx2(this.params.jobQueue, () => "MongoDBModule Error: jobQueue required for this module but is not defined");
150
- }
151
- get payloadSdkConfig() {
152
- const config = { collection: COLLECTIONS.Payloads, ...getBaseMongoSdkPrivateConfig() };
153
- return merge(
154
- config,
155
- this.params.payloadSdkConfig,
156
- this.config.payloadSdkConfig,
157
- { collection: this.config.payloadSdkConfig?.collection ?? this.params.payloadSdkConfig?.collection ?? COLLECTIONS.Payloads }
158
- );
159
- }
160
- get payloads() {
161
- this._payloadSdk = this._payloadSdk ?? new BaseMongoSdk2(this.payloadSdkConfig);
162
- return assertEx2(this._payloadSdk);
163
- }
164
- /**
165
- * Ensures any indexes specified within the config are created. This method should be idempotent
166
- * allowing for multiple calls without causing errors while ensuring the desired state.
167
- */
168
- async ensureIndexes() {
169
- const configIndexes = this.config?.storage?.indexes ?? [];
170
- const boundWitnessesCollectionName = this.boundWitnessSdkConfig.collection;
171
- const payloadCollectionName = this.payloadSdkConfig.collection;
172
- const bwStandardIndexes = standardIndexes.map((ix) => ({ ...ix, name: `${boundWitnessesCollectionName}.${ix.name}` }));
173
- await ensureIndexesExistOnCollection(this.boundWitnesses, [...bwStandardIndexes, ...configIndexes]);
174
- const payloadStandardIndexes = standardIndexes.map((ix) => ({ ...ix, name: `${payloadCollectionName}.${ix.name}` }));
175
- await ensureIndexesExistOnCollection(this.payloads, [...payloadStandardIndexes, ...configIndexes]);
176
- }
177
- };
178
- __publicField(MongoModuleBase, "labels", MongoDBStorageClassLabels);
179
- MongoModuleBase = __decorateClass([
180
- staticImplements()
181
- ], MongoModuleBase);
182
- return MongoModuleBase;
183
- };
184
- var ensureIndexesExistOnCollection = async (sdk, configIndexes) => {
185
- await sdk.useCollection(async (collection) => {
186
- const collectionName = collection.collectionName.toLowerCase();
187
- const indexes = configIndexes.filter((ix) => ix?.name?.toLowerCase().startsWith(collectionName));
188
- if (indexes.length === 0) return;
189
- for (const ix of indexes) {
190
- try {
191
- await collection.createIndexes([ix]);
192
- } catch (error) {
193
- const mongoServerError = error;
194
- const { codeName } = mongoServerError;
195
- if (codeName === "IndexKeySpecsConflict" || codeName === "IndexOptionsConflict") {
196
- continue;
197
- }
198
- console.error(`Error creating index ${ix.name} for collection ${collectionName}: ${error}`);
199
- throw error;
200
- }
201
- }
202
- });
203
- };
204
-
205
- // src/ModuleV2.ts
206
- import { assertEx as assertEx3 } from "@xylabs/assert";
207
- import { BaseMongoSdk as BaseMongoSdk3 } from "@xylabs/mongo";
208
- import { staticImplements as staticImplements2 } from "@xylabs/static-implements";
209
- import {
210
- MongoDBStorageClassLabels as MongoDBStorageClassLabels2
211
- } from "@xyo-network/module-model-mongodb";
212
- var standardIndexes2 = [
213
- {
214
- name: "UX__hash",
215
- key: { _hash: 1 },
216
- unique: true
217
- },
218
- {
219
- name: "IX__dataHash",
220
- key: { _dataHash: 1 },
221
- unique: false
222
- },
223
- {
224
- name: "UX__sequence",
225
- key: { _sequence: 1 },
226
- unique: true
227
- }
228
- ];
229
- var MongoDBModuleMixinV2 = (ModuleBase) => {
230
- let MongoModuleBase = class extends ModuleBase {
231
- _payloadSdk;
232
- get jobQueue() {
233
- return assertEx3(this.params.jobQueue, () => "MongoDBModule Error: jobQueue required for this module but is not defined");
234
- }
235
- get payloadSdkConfig() {
236
- const config = { collection: COLLECTIONS.Payloads, ...getBaseMongoSdkPrivateConfig() };
237
- return merge(
238
- config,
239
- this.params.payloadSdkConfig,
240
- this.config.payloadSdkConfig,
241
- { collection: this.config.payloadSdkConfig?.collection ?? this.params.payloadSdkConfig?.collection ?? COLLECTIONS.Payloads }
242
- );
243
- }
244
- get payloads() {
245
- this._payloadSdk = this._payloadSdk ?? new BaseMongoSdk3(this.payloadSdkConfig);
246
- return assertEx3(this._payloadSdk);
247
- }
248
- /**
249
- * Ensures any indexes specified within the config are created. This method should be idempotent
250
- * allowing for multiple calls without causing errors while ensuring the desired state.
251
- */
252
- async ensureCollection() {
253
- const { max } = this.config;
254
- const payloadCollectionName = this.payloadSdkConfig.collection;
255
- const payloadStandardIndexes = standardIndexes2.map((ix) => ({ ...ix, name: `${payloadCollectionName}.${ix.name}` }));
256
- if (max) {
257
- await ensureCappedCollection(this.payloads, max);
258
- await ensureIndexesExistOnCollection2(this.payloads, [...payloadStandardIndexes]);
259
- } else {
260
- await ensureIndexesExistOnCollection2(this.payloads, [...payloadStandardIndexes]);
261
- }
262
- }
263
- };
264
- __publicField(MongoModuleBase, "labels", MongoDBStorageClassLabels2);
265
- MongoModuleBase = __decorateClass([
266
- staticImplements2()
267
- ], MongoModuleBase);
268
- return MongoModuleBase;
269
- };
270
- var collectionExists = async (db, name) => {
271
- const collections = await db.listCollections({ name }).toArray();
272
- return collections.length > 0;
273
- };
274
- var ensureIndexesExistOnCollection2 = async (sdk, configIndexes) => {
275
- await sdk.useCollection(async (collection) => {
276
- const collectionName = collection.collectionName.toLowerCase();
277
- const indexes = configIndexes.filter((ix) => ix?.name?.toLowerCase().startsWith(collectionName));
278
- if (indexes.length === 0) return;
279
- for (const ix of indexes) {
280
- try {
281
- await collection.createIndexes([ix]);
282
- } catch (error) {
283
- const mongoServerError = error;
284
- const { codeName } = mongoServerError;
285
- if (codeName === "IndexKeySpecsConflict" || codeName === "IndexOptionsConflict") {
286
- continue;
287
- }
288
- console.error(`Error creating index ${ix.name} for collection ${collectionName}: ${error}`);
289
- throw error;
290
- }
291
- }
292
- });
293
- };
294
- var ensureCappedCollection = async (sdk, max, docSize = 1024) => {
295
- await sdk.useCollection(async (collection) => {
296
- const name = collection.collectionName.toLowerCase();
297
- await sdk.useMongo(async (client) => {
298
- const db = client.db(collection.dbName);
299
- const exists2 = await collectionExists(db, name);
300
- const size = docSize * max;
301
- return exists2 ? await ensureExistingCollectionIsCapped(sdk, max, size) : await db.createCollection(name, {
302
- capped: true,
303
- size,
304
- max
305
- });
306
- });
307
- });
308
- };
309
- var ensureExistingCollectionIsCapped = async (sdk, max, docSize = 1024) => {
310
- await sdk.useCollection(async (collection) => {
311
- const name = collection.collectionName.toLowerCase();
312
- await sdk.useMongo(async (client) => {
313
- const db = client.db(collection.dbName);
314
- const exists2 = await collectionExists(db, name);
315
- if (!exists2) throw new Error(`Collection '${name}' does not exist`);
316
- const size = docSize * max;
317
- const stats = await db.command({ collStats: name });
318
- if (stats.capped && stats.max === max && stats.maxSize === size) {
319
- return;
320
- }
321
- const tmpName = `${name}_tmp_capped`;
322
- await db.createCollection(tmpName, {
323
- capped: true,
324
- size,
325
- max
326
- });
327
- const docs = await collection.find().sort({ $natural: -1 }).limit(max).toArray();
328
- if (docs.length > 0) await db.collection(tmpName).insertMany(docs.toReversed());
329
- await collection.drop();
330
- await db.collection(tmpName).rename(name);
331
- });
332
- });
333
- };
334
-
335
- // src/util/dbProperty.ts
336
- var escapeChar = "#";
337
- var toDbProperty = (value) => value.replaceAll(".", escapeChar);
338
- var fromDbProperty = (value) => value.replaceAll(escapeChar, ".");
339
- export {
340
- COLLECTIONS,
341
- DATABASES,
342
- DefaultAggregateTimeoutMs,
343
- DefaultLimit,
344
- DefaultMaxTimeMS,
345
- DefaultOrder,
346
- MongoDBModuleMixin,
347
- MongoDBModuleMixinV2,
348
- escapeChar,
349
- fromDbProperty,
350
- getBaseMongoSdk,
351
- getBaseMongoSdkPrivateConfig,
352
- getMongoDBConfig,
353
- hasMongoDBConfig,
354
- toDbProperty
355
- };
356
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Collections.ts","../../src/config/getBaseMongoSdk.ts","../../src/config/getMongoDBConfig.ts","../../src/config/hasMongoDBConfig.ts","../../src/Databases.ts","../../src/Defaults.ts","../../src/Module.ts","../../src/merge.ts","../../src/ModuleV2.ts","../../src/util/dbProperty.ts"],"sourcesContent":["// TODO: By DB\nexport const COLLECTIONS = {\n AddressInfo: 'address_info' as const,\n ArchivistStats: 'archivist_stats' as const,\n BoundWitnesses: 'bound_witnesses' as const,\n Payloads: 'payloads' as const,\n Thumbnails: 'thumbnails' as const,\n Users: 'users' as const,\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { BaseMongoSdkPrivateConfig } from '@xylabs/mongo'\nimport { BaseMongoSdk } from '@xylabs/mongo'\nimport type { Document } from 'mongodb'\n\nimport { getMongoDBConfig } from './getMongoDBConfig.ts'\n\nexport const getBaseMongoSdkPrivateConfig = (): BaseMongoSdkPrivateConfig => {\n const env = getMongoDBConfig()\n return {\n dbConnectionString: env.MONGO_CONNECTION_STRING,\n dbDomain: assertEx(env.MONGO_DOMAIN, () => 'Missing Mongo Domain'),\n dbName: assertEx(env.MONGO_DATABASE, () => 'Missing Mongo Database'),\n dbPassword: assertEx(env.MONGO_PASSWORD, () => 'Missing Mongo Password'),\n dbUserName: assertEx(env.MONGO_USERNAME, () => 'Missing Mongo Username'),\n }\n}\n\nexport const getBaseMongoSdk = <T extends Document>(collection: string) => {\n return new BaseMongoSdk<T>({ ...getBaseMongoSdkPrivateConfig(), collection })\n}\n","export type MongoDbConnectionStringEnvVar = 'MONGO_CONNECTION_STRING'\nexport type MongoDbEnvVars = 'MONGO_DATABASE' | 'MONGO_DOMAIN' | 'MONGO_PASSWORD' | 'MONGO_USERNAME'\n\nexport type MongoEnv = Record<MongoDbEnvVars | MongoDbConnectionStringEnvVar, string | undefined>\n\nexport const getMongoDBConfig = (): MongoEnv => {\n const env: MongoEnv = {} as MongoEnv\n if (process.env.MONGO_CONNECTION_STRING) {\n env.MONGO_CONNECTION_STRING = process.env.MONGO_CONNECTION_STRING\n }\n if (process.env.MONGO_DOMAIN) {\n env.MONGO_DATABASE = process.env.MONGO_DATABASE\n env.MONGO_DOMAIN = process.env.MONGO_DOMAIN\n env.MONGO_PASSWORD = process.env.MONGO_PASSWORD\n env.MONGO_USERNAME = process.env.MONGO_USERNAME\n }\n return env\n}\n","import { exists } from '@xylabs/exists'\n\nimport { getMongoDBConfig } from './getMongoDBConfig.ts'\n\nexport const hasMongoDBConfig = (): boolean => {\n const env = getMongoDBConfig()\n const requiredValues = [env.MONGO_CONNECTION_STRING, env.MONGO_DATABASE, env.MONGO_DOMAIN, env.MONGO_PASSWORD, env.MONGO_USERNAME]\n return requiredValues.every(exists)\n}\n","export const DATABASES = { Archivist: 'archivist' as const }\n","export const DefaultAggregateTimeoutMs = 10_000\nexport const DefaultLimit = 20\nexport const DefaultMaxTimeMS = 2000\nexport const DefaultOrder = 'desc'\n","import { assertEx } from '@xylabs/assert'\nimport { BaseMongoSdk, BaseMongoSdkConfig } from '@xylabs/mongo'\nimport { staticImplements } from '@xylabs/static-implements'\nimport {\n MongoDBModule, MongoDBModuleParams, MongoDBModuleStatic, MongoDBStorageClassLabels,\n} from '@xyo-network/module-model-mongodb'\nimport { BoundWitnessWithMongoMeta, PayloadWithMongoMeta } from '@xyo-network/payload-mongodb'\nimport { MongoServerError } from 'mongodb'\n\nimport { AnyAbstractModule } from './AnyAbstractModule.ts'\nimport { COLLECTIONS } from './Collections.ts'\nimport { getBaseMongoSdkPrivateConfig } from './config/index.ts'\nimport { IndexDescription } from './IndexDescription.ts'\nimport { merge } from './merge.ts'\n\nconst standardIndexes: IndexDescription[] = [\n {\n name: 'IX__hash', key: { _hash: 1 }, unique: false,\n },\n {\n name: 'IX__dataHash', key: { _dataHash: 1 }, unique: false,\n },\n {\n name: 'IX__sequence', key: { _sequence: 1 }, unique: false,\n },\n]\n\nexport const MongoDBModuleMixin = <\n TParams extends MongoDBModuleParams = MongoDBModuleParams,\n TModule extends AnyAbstractModule<TParams> = AnyAbstractModule<TParams>,\n>(\n ModuleBase: TModule,\n) => {\n @staticImplements<MongoDBModuleStatic>()\n abstract class MongoModuleBase extends ModuleBase implements MongoDBModule {\n static readonly labels = MongoDBStorageClassLabels\n _boundWitnessSdk: BaseMongoSdk<BoundWitnessWithMongoMeta> | undefined\n _payloadSdk: BaseMongoSdk<PayloadWithMongoMeta> | undefined\n\n get boundWitnessSdkConfig(): BaseMongoSdkConfig {\n const config = { collection: COLLECTIONS.BoundWitnesses, ...getBaseMongoSdkPrivateConfig() }\n return merge(\n config,\n this.params.boundWitnessSdkConfig,\n this.config.boundWitnessSdkConfig,\n { collection: this.config.boundWitnessSdkConfig?.collection ?? this.params.boundWitnessSdkConfig?.collection ?? COLLECTIONS.BoundWitnesses },\n )\n }\n\n get boundWitnesses() {\n this._boundWitnessSdk = this._boundWitnessSdk ?? new BaseMongoSdk<BoundWitnessWithMongoMeta>(this.boundWitnessSdkConfig)\n return assertEx(this._boundWitnessSdk)\n }\n\n get jobQueue() {\n return assertEx(this.params.jobQueue, () => 'MongoDBModule Error: jobQueue required for this module but is not defined')\n }\n\n get payloadSdkConfig(): BaseMongoSdkConfig {\n const config = { collection: COLLECTIONS.Payloads, ...getBaseMongoSdkPrivateConfig() }\n return merge(\n config,\n this.params.payloadSdkConfig,\n this.config.payloadSdkConfig,\n { collection: this.config.payloadSdkConfig?.collection ?? this.params.payloadSdkConfig?.collection ?? COLLECTIONS.Payloads },\n )\n }\n\n get payloads() {\n this._payloadSdk = this._payloadSdk ?? new BaseMongoSdk<PayloadWithMongoMeta>(this.payloadSdkConfig)\n return assertEx(this._payloadSdk)\n }\n\n /**\n * Ensures any indexes specified within the config are created. This method should be idempotent\n * allowing for multiple calls without causing errors while ensuring the desired state.\n */\n async ensureIndexes(): Promise<void> {\n const configIndexes = (this.config as { storage?: { indexes?: IndexDescription[] } })?.storage?.indexes ?? []\n const boundWitnessesCollectionName = this.boundWitnessSdkConfig.collection\n const payloadCollectionName = this.payloadSdkConfig.collection\n\n const bwStandardIndexes = standardIndexes.map(ix => ({ ...ix, name: `${boundWitnessesCollectionName}.${ix.name}` }))\n await ensureIndexesExistOnCollection(this.boundWitnesses, [...bwStandardIndexes, ...configIndexes])\n const payloadStandardIndexes = standardIndexes.map(ix => ({ ...ix, name: `${payloadCollectionName}.${ix.name}` }))\n await ensureIndexesExistOnCollection(this.payloads, [...payloadStandardIndexes, ...configIndexes])\n }\n }\n return MongoModuleBase\n}\n\n/**\n * Ensures the specified indexes exist on the collection\n * @param sdk The sdk to use for the collection\n * @param configIndexes The indexes to ensure exist on the collection\n */\nconst ensureIndexesExistOnCollection = async (\n sdk: BaseMongoSdk<PayloadWithMongoMeta> | BaseMongoSdk<BoundWitnessWithMongoMeta>,\n configIndexes: IndexDescription[],\n) => {\n await sdk.useCollection(async (collection) => {\n const collectionName = collection.collectionName.toLowerCase()\n const indexes = configIndexes.filter(ix => ix?.name?.toLowerCase().startsWith(collectionName))\n if (indexes.length === 0) return\n for (const ix of indexes) {\n try {\n await collection.createIndexes([ix])\n } catch (error) {\n const mongoServerError = error as MongoServerError\n const { codeName } = mongoServerError\n if (codeName === 'IndexKeySpecsConflict' || codeName === 'IndexOptionsConflict') {\n // Index already exists which is fine OR index exists with another name which is fine\n // TODO: For the latter case (IndexOptionsConflict) we could get into this case\n // if we change the TTL an existing index. We currently don't support TTLs so\n // we'll need to revisit this assumption if we do.\n continue\n }\n console.error(`Error creating index ${ix.name} for collection ${collectionName}: ${error}`)\n throw error\n }\n }\n })\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nfunction isObject(val: unknown): val is Record<string, any> {\n return val !== null && typeof val === 'object'\n}\n\nexport function merge<T extends object>(target: T, ...sources: any[]): T {\n if (!isObject(target)) {\n throw new TypeError('Target must be an object')\n }\n\n for (const source of sources) {\n if (!isObject(source)) {\n continue\n }\n\n for (const key of Object.keys(source)) {\n const sourceVal = source[key]\n const targetVal = (target as any)[key]\n\n if (Array.isArray(sourceVal)) {\n // Arrays are replaced, not deeply merged (lodash behavior)\n (target as any)[key] = [...sourceVal]\n } else if (isObject(sourceVal)) {\n if (!isObject(targetVal)) {\n (target as any)[key] = {}\n }\n merge((target as any)[key], sourceVal)\n } else {\n (target as any)[key] = sourceVal\n }\n }\n }\n\n return target\n}\n","import { assertEx } from '@xylabs/assert'\nimport { BaseMongoSdk, BaseMongoSdkConfig } from '@xylabs/mongo'\nimport { staticImplements } from '@xylabs/static-implements'\nimport {\n MongoDBModuleParamsV2, MongoDBModuleStatic, MongoDBModuleV2, MongoDBStorageClassLabels,\n} from '@xyo-network/module-model-mongodb'\nimport { PayloadWithMongoMeta } from '@xyo-network/payload-mongodb'\nimport { Db, MongoServerError } from 'mongodb'\n\nimport { AnyAbstractModule } from './AnyAbstractModule.ts'\nimport { COLLECTIONS } from './Collections.ts'\nimport { getBaseMongoSdkPrivateConfig } from './config/index.ts'\nimport { IndexDescription } from './IndexDescription.ts'\nimport { merge } from './merge.ts'\n\nconst standardIndexes: IndexDescription[] = [\n {\n name: 'UX__hash', key: { _hash: 1 }, unique: true,\n },\n {\n name: 'IX__dataHash', key: { _dataHash: 1 }, unique: false,\n },\n {\n name: 'UX__sequence', key: { _sequence: 1 }, unique: true,\n },\n]\n\nexport const MongoDBModuleMixinV2 = <\n TParams extends MongoDBModuleParamsV2 = MongoDBModuleParamsV2,\n TModule extends AnyAbstractModule<TParams> = AnyAbstractModule<TParams>,\n>(\n ModuleBase: TModule,\n) => {\n @staticImplements<MongoDBModuleStatic>()\n abstract class MongoModuleBase extends ModuleBase implements MongoDBModuleV2 {\n static readonly labels = MongoDBStorageClassLabels\n _payloadSdk: BaseMongoSdk<PayloadWithMongoMeta> | undefined\n\n get jobQueue() {\n return assertEx(this.params.jobQueue, () => 'MongoDBModule Error: jobQueue required for this module but is not defined')\n }\n\n get payloadSdkConfig(): BaseMongoSdkConfig {\n const config = { collection: COLLECTIONS.Payloads, ...getBaseMongoSdkPrivateConfig() }\n return merge(\n config,\n this.params.payloadSdkConfig,\n this.config.payloadSdkConfig,\n { collection: this.config.payloadSdkConfig?.collection ?? this.params.payloadSdkConfig?.collection ?? COLLECTIONS.Payloads },\n )\n }\n\n get payloads() {\n this._payloadSdk = this._payloadSdk ?? new BaseMongoSdk<PayloadWithMongoMeta>(this.payloadSdkConfig)\n return assertEx(this._payloadSdk)\n }\n\n /**\n * Ensures any indexes specified within the config are created. This method should be idempotent\n * allowing for multiple calls without causing errors while ensuring the desired state.\n */\n async ensureCollection(): Promise<void> {\n const { max } = this.config\n const payloadCollectionName = this.payloadSdkConfig.collection\n\n const payloadStandardIndexes = standardIndexes.map(ix => ({ ...ix, name: `${payloadCollectionName}.${ix.name}` }))\n\n if (max) {\n // Create capped collection if it doesn't exist or convert it if it does\n await ensureCappedCollection(this.payloads, max)\n // Recreate indexes after creating/converting a capped collection as\n // capped will remove all indexes on existing collections.\n // https://www.mongodb.com/docs/manual/reference/command/convertToCapped/\n await ensureIndexesExistOnCollection(this.payloads, [...payloadStandardIndexes])\n } else {\n // Create indexes (creates collection without having to write data to it)\n await ensureIndexesExistOnCollection(this.payloads, [...payloadStandardIndexes])\n }\n }\n }\n return MongoModuleBase\n}\n\nconst collectionExists = async (db: Db, name: string): Promise<boolean> => {\n const collections = await db.listCollections({ name }).toArray()\n return collections.length > 0\n}\n\n/**\n * Ensures the specified indexes exist on the collection\n * @param sdk The sdk to use for the collection\n * @param configIndexes The indexes to ensure exist on the collection\n */\nconst ensureIndexesExistOnCollection = async (\n sdk: BaseMongoSdk<PayloadWithMongoMeta>,\n configIndexes: IndexDescription[],\n) => {\n await sdk.useCollection(async (collection) => {\n const collectionName = collection.collectionName.toLowerCase()\n const indexes = configIndexes.filter(ix => ix?.name?.toLowerCase().startsWith(collectionName))\n if (indexes.length === 0) return\n for (const ix of indexes) {\n try {\n await collection.createIndexes([ix])\n } catch (error) {\n const mongoServerError = error as MongoServerError\n const { codeName } = mongoServerError\n if (codeName === 'IndexKeySpecsConflict' || codeName === 'IndexOptionsConflict') {\n // Index already exists which is fine OR index exists with another name which is fine\n // TODO: For the latter case (IndexOptionsConflict) we could get into this case\n // if we change the TTL an existing index. We currently don't support TTLs so\n // we'll need to revisit this assumption if we do.\n continue\n }\n console.error(`Error creating index ${ix.name} for collection ${collectionName}: ${error}`)\n throw error\n }\n }\n })\n}\n\n/**\n * Ensures that a collection is capped with a max document count and a reasonable size.\n * If the collection exists and is not capped, it will be converted.\n * If it doesn't exist, it will be created.\n *\n * @param name The name of the collection.\n * @param count The maximum number of documents to retain.\n * @param documentSize Estimated average document size in bytes if collection is empty.\n */\nconst ensureCappedCollection = async (sdk: BaseMongoSdk<PayloadWithMongoMeta>, max: number, docSize = 1024) => {\n await sdk.useCollection(async (collection) => {\n const name = collection.collectionName.toLowerCase()\n await sdk.useMongo(async (client) => {\n const db = client.db(collection.dbName)\n const exists = await collectionExists(db, name)\n const size = docSize * max\n return exists\n ? await ensureExistingCollectionIsCapped(sdk, max, size)\n // Create capped collection\n : await db.createCollection(name, {\n capped: true, size, max,\n })\n })\n })\n}\n\n/**\n * Converts an existing collection to a capped collection with a max document count.\n * Since MongoDB doesn't support `max` in `convertToCapped` or `cloneCollectionAsCapped`,\n * this function recreates the collection to work around Mongo's limitations.\n * https://www.mongodb.com/docs/manual/reference/command/convertToCapped/\n * https://www.mongodb.com/docs/manual/reference/command/clonecollectionascapped/\n * @param db - The MongoDB database instance\n * @param name - The name of the collection to convert\n * @param max - The maximum number of documents to retain\n * @param docSize - Fallback size (in bytes) to use if no documents exist (default 1KB)\n */\nconst ensureExistingCollectionIsCapped = async (\n sdk: BaseMongoSdk<PayloadWithMongoMeta>,\n max: number,\n docSize = 1024,\n): Promise<void> => {\n await sdk.useCollection(async (collection) => {\n const name = collection.collectionName.toLowerCase()\n await sdk.useMongo(async (client) => {\n const db = client.db(collection.dbName)\n const exists = await collectionExists(db, name)\n if (!exists) throw new Error(`Collection '${name}' does not exist`)\n\n const size = docSize * max\n\n const stats = await db.command({ collStats: name })\n if (stats.capped && stats.max === max && stats.maxSize === size) {\n return\n }\n\n const tmpName = `${name}_tmp_capped`\n\n // Create new capped collection\n await db.createCollection(tmpName, {\n capped: true, size, max,\n })\n\n // Copy most recent documents\n const docs = await collection\n .find()\n .sort({ $natural: -1 })\n .limit(max)\n .toArray()\n\n if (docs.length > 0) await db.collection(tmpName).insertMany(docs.toReversed())\n\n // Replace old collection\n await collection.drop()\n await db.collection(tmpName).rename(name)\n })\n })\n}\n","export const escapeChar = '#'\n\nexport const toDbProperty = (value: string) => value.replaceAll('.', escapeChar)\n\nexport const fromDbProperty = (value: string) => value.replaceAll(escapeChar, '.')\n"],"mappings":"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","names":["assertEx","BaseMongoSdk","BaseMongoSdk","assertEx","assertEx","BaseMongoSdk","staticImplements","MongoDBStorageClassLabels","standardIndexes","assertEx","BaseMongoSdk","ensureIndexesExistOnCollection","MongoDBStorageClassLabels","staticImplements","exists"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Module.d.ts","sourceRoot":"","sources":["../../src/Module.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAA;AAEhE,OAAO,EACU,mBAAmB,EAAuB,yBAAyB,EACnF,MAAM,mCAAmC,CAAA;AAC1C,OAAO,EAAE,yBAAyB,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAA;AAG9F,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAkB1D,eAAO,MAAM,kBAAkB,GAC7B,OAAO,SAAS,mBAAmB,GAAG,mBAAmB,EACzD,OAAO,SAAS,iBAAiB,CAAC,OAAO,CAAC,GAAG,iBAAiB,CAAC,OAAO,CAAC,EAEvE,YAAY,OAAO;sBAKC,YAAY,CAAC,yBAAyB,CAAC,GAAG,SAAS;iBACxD,YAAY,CAAC,oBAAoB,CAAC,GAAG,SAAS;oCAE9B,kBAAkB;;;+BAmBvB,kBAAkB;;IAe1C;;;OAGG;qBACoB,OAAO,CAAC,IAAI,CAAC;;;;;;;;sRAtDnB,CAAC,6DAAwB,CAAC;4RAMA,CAAC,6DAAwB,CAAC;;;;;;;;;;;;;;;YA4DxE,CAAA"}
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes