@xyo-network/archivist-mongodb 2.72.9

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.
@@ -0,0 +1,80 @@
1
+ import { assertEx } from '@xylabs/assert';
2
+ import { exists } from '@xylabs/exists';
3
+ import { fulfilledValues } from '@xylabs/promise';
4
+ import { AbstractArchivist } from '@xyo-network/archivist-abstract';
5
+ import { ArchivistConfigSchema, ArchivistInsertQuerySchema } from '@xyo-network/archivist-model';
6
+ import { PayloadWrapper } from '@xyo-network/payload-wrapper';
7
+ import { BaseMongoSdk } from '@xyo-network/sdk-xyo-mongo-js';
8
+ import merge from 'lodash/merge';
9
+ import { validByType } from './validByType';
10
+ export const MongoDBArchivistConfigSchema = 'network.xyo.archivist.mongodb.config';
11
+ const toBoundWitnessWithMeta = async (wrapper) => {
12
+ const bw = wrapper.boundwitness;
13
+ return { ...bw, _hash: await wrapper.hashAsync(), _timestamp: Date.now() };
14
+ };
15
+ const toReturnValue = (value) => {
16
+ const _signatures = value?._signatures;
17
+ if (_signatures) {
18
+ return { ...PayloadWrapper.wrap(value).body(), _signatures };
19
+ }
20
+ else {
21
+ return { ...PayloadWrapper.wrap(value).body() };
22
+ }
23
+ };
24
+ const toPayloadWithMeta = async (wrapper) => {
25
+ return { ...wrapper.payload(), _hash: await wrapper.hashAsync(), _timestamp: Date.now() };
26
+ };
27
+ export class MongoDBArchivist extends AbstractArchivist {
28
+ static configSchemas = [MongoDBArchivistConfigSchema, ArchivistConfigSchema];
29
+ _boundWitnessSdk;
30
+ _payloadSdk;
31
+ get boundWitnessSdkConfig() {
32
+ return merge({}, this.params.boundWitnessSdkConfig, this.config.boundWitnessSdkConfig, {
33
+ collection: this.config.boundWitnessSdkConfig?.collection ?? this.params.boundWitnessSdkConfig?.collection ?? 'bound_witnesses',
34
+ });
35
+ }
36
+ get boundWitnesses() {
37
+ this._boundWitnessSdk = this._boundWitnessSdk ?? new BaseMongoSdk(this.boundWitnessSdkConfig);
38
+ return assertEx(this._boundWitnessSdk);
39
+ }
40
+ get payloadSdkConfig() {
41
+ return merge({}, this.params.payloadSdkConfig, this.config.payloadSdkConfig, {
42
+ collection: this.config.payloadSdkConfig?.collection ?? this.params.payloadSdkConfig?.collection ?? 'payload',
43
+ });
44
+ }
45
+ get payloads() {
46
+ this._payloadSdk = this._payloadSdk ?? new BaseMongoSdk(this.payloadSdkConfig);
47
+ return assertEx(this._payloadSdk);
48
+ }
49
+ get queries() {
50
+ return [ArchivistInsertQuerySchema, ...super.queries];
51
+ }
52
+ async head() {
53
+ const head = await (await this.payloads.find({})).sort({ _timestamp: -1 }).limit(1).toArray();
54
+ return head[0] ? PayloadWrapper.wrap(head[0]).body() : undefined;
55
+ }
56
+ async getHandler(hashes) {
57
+ const payloads = hashes.map((_hash) => this.payloads.findOne({ _hash }));
58
+ const bws = hashes.map((_hash) => this.boundWitnesses.findOne({ _hash }));
59
+ const gets = await Promise.allSettled([payloads, bws].flat());
60
+ const succeeded = gets.reduce(fulfilledValues, []);
61
+ return succeeded.filter(exists).map(toReturnValue);
62
+ }
63
+ async insertHandler(payloads) {
64
+ const [bw, p] = await validByType(payloads);
65
+ const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)));
66
+ const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)));
67
+ if (boundWitnesses.length) {
68
+ const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses);
69
+ if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)
70
+ throw new Error('MongoDBDeterministicArchivist: Error inserting BoundWitnesses');
71
+ }
72
+ if (payloadsWithMeta.length) {
73
+ const payloadsResult = await this.payloads.insertMany(payloadsWithMeta);
74
+ if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithMeta.length)
75
+ throw new Error('MongoDBDeterministicArchivist: Error inserting Payloads');
76
+ }
77
+ return payloads ?? [];
78
+ }
79
+ }
80
+ //# sourceMappingURL=Archivist.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Archivist.js","sourceRoot":"","sources":["../../src/Archivist.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './Archivist';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAA"}
@@ -0,0 +1,24 @@
1
+ import { isQueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder';
2
+ import { isBoundWitness } from '@xyo-network/boundwitness-model';
3
+ import { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper';
4
+ import { PayloadWrapper } from '@xyo-network/payload-wrapper';
5
+ export const validByType = async (payloads = []) => {
6
+ const results = [[], []];
7
+ await Promise.all(payloads.map(async (payload) => {
8
+ if (isBoundWitness(payload)) {
9
+ const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper;
10
+ const bw = wrapper.parse(payload);
11
+ if (await bw.getValid()) {
12
+ results[0].push(bw);
13
+ }
14
+ }
15
+ else {
16
+ const payloadWrapper = PayloadWrapper.wrap(payload);
17
+ if (await payloadWrapper.getValid()) {
18
+ results[1].push(payloadWrapper);
19
+ }
20
+ }
21
+ }));
22
+ return results;
23
+ };
24
+ //# sourceMappingURL=validByType.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validByType.js","sourceRoot":"","sources":["../../src/validByType.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAA;AACjG,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAA;AAChE,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAA;AAEvE,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAE7D,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,EAAE,WAAsB,EAAE,EAAE,EAAE;IAC5D,MAAM,OAAO,GAA8C,CAAC,EAAE,EAAE,EAAE,CAAC,CAAA;IACnE,MAAM,OAAO,CAAC,GAAG,CACf,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QAC7B,IAAI,cAAc,CAAC,OAAO,CAAC,EAAE;YAC3B,MAAM,OAAO,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,mBAAmB,CAAA;YAC7F,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YACjC,IAAI,MAAM,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACvB,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;aACpB;SACF;aAAM;YACL,MAAM,cAAc,GAAG,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YACnD,IAAI,MAAM,cAAc,CAAC,QAAQ,EAAE,EAAE;gBACnC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;aAChC;SACF;IACH,CAAC,CAAC,CACH,CAAA;IACD,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA"}
@@ -0,0 +1,33 @@
1
+ import { AbstractArchivist } from '@xyo-network/archivist-abstract';
2
+ import { ArchivistConfig, ArchivistParams } from '@xyo-network/archivist-model';
3
+ import { AnyConfigSchema } from '@xyo-network/module';
4
+ import { BoundWitnessWithMeta } from '@xyo-network/node-core-model';
5
+ import { Payload } from '@xyo-network/payload-model';
6
+ import { BaseMongoSdk, BaseMongoSdkConfig, BaseMongoSdkPrivateConfig, BaseMongoSdkPublicConfig } from '@xyo-network/sdk-xyo-mongo-js';
7
+ export declare const MongoDBArchivistConfigSchema = "network.xyo.archivist.mongodb.config";
8
+ export type MongoDBArchivistConfigSchema = typeof MongoDBArchivistConfigSchema;
9
+ export type MongoDBArchivistConfig = ArchivistConfig<{
10
+ boundWitnessSdkConfig?: Partial<BaseMongoSdkPublicConfig>;
11
+ payloadSdkConfig?: Partial<BaseMongoSdkPublicConfig>;
12
+ schema: MongoDBArchivistConfigSchema;
13
+ }>;
14
+ export type MongoDBArchivistParams = ArchivistParams<AnyConfigSchema<MongoDBArchivistConfig>, {
15
+ boundWitnessSdkConfig: BaseMongoSdkPrivateConfig & Partial<BaseMongoSdkPublicConfig>;
16
+ payloadSdkConfig: BaseMongoSdkPrivateConfig & Partial<BaseMongoSdkPublicConfig>;
17
+ }>;
18
+ export declare class MongoDBArchivist<TParams extends MongoDBArchivistParams = MongoDBArchivistParams> extends AbstractArchivist<TParams> {
19
+ static configSchemas: string[];
20
+ private _boundWitnessSdk;
21
+ private _payloadSdk;
22
+ get boundWitnessSdkConfig(): BaseMongoSdkConfig;
23
+ get boundWitnesses(): BaseMongoSdk<BoundWitnessWithMeta>;
24
+ get payloadSdkConfig(): BaseMongoSdkConfig;
25
+ get payloads(): BaseMongoSdk<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/node-core-model").PayloadMetaBase & {
26
+ schema: string;
27
+ }>;
28
+ get queries(): string[];
29
+ head(): Promise<Payload | undefined>;
30
+ protected getHandler(hashes: string[]): Promise<Payload[]>;
31
+ protected insertHandler(payloads?: Payload[]): Promise<Payload[]>;
32
+ }
33
+ //# sourceMappingURL=Archivist.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Archivist.d.ts","sourceRoot":"","sources":["../../src/Archivist.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAAE,eAAe,EAAqD,eAAe,EAAE,MAAM,8BAA8B,CAAA;AAIlI,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,oBAAoB,EAA2C,MAAM,8BAA8B,CAAA;AAC5G,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,yBAAyB,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAA;AAKrI,eAAO,MAAM,4BAA4B,yCAAyC,CAAA;AAClF,MAAM,MAAM,4BAA4B,GAAG,OAAO,4BAA4B,CAAA;AAE9E,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC;IACnD,qBAAqB,CAAC,EAAE,OAAO,CAAC,wBAAwB,CAAC,CAAA;IACzD,gBAAgB,CAAC,EAAE,OAAO,CAAC,wBAAwB,CAAC,CAAA;IACpD,MAAM,EAAE,4BAA4B,CAAA;CACrC,CAAC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAClD,eAAe,CAAC,sBAAsB,CAAC,EACvC;IACE,qBAAqB,EAAE,yBAAyB,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAA;IACpF,gBAAgB,EAAE,yBAAyB,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAA;CAChF,CACF,CAAA;AAoBD,qBAAa,gBAAgB,CAAC,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,CAAE,SAAQ,iBAAiB,CAAC,OAAO,CAAC;IAC/H,OAAgB,aAAa,WAAwD;IAErF,OAAO,CAAC,gBAAgB,CAAgD;IACxE,OAAO,CAAC,WAAW,CAA2C;IAE9D,IAAI,qBAAqB,IAAI,kBAAkB,CAI9C;IAED,IAAI,cAAc,uCAGjB;IAED,IAAI,gBAAgB,IAAI,kBAAkB,CAIzC;IAED,IAAI,QAAQ;;OAGX;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAEc,IAAI,IAAI,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC;cAK1B,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;cAQhD,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAgBjF"}
@@ -0,0 +1,2 @@
1
+ export * from './Archivist';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAA"}
@@ -0,0 +1,11 @@
1
+ import { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ import { PayloadWrapper } from '@xyo-network/payload-wrapper';
4
+ export declare const validByType: (payloads?: Payload[]) => Promise<[BoundWitnessWrapper<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/boundwitness-model").BoundWitnessFields & {
5
+ schema: "network.xyo.boundwitness";
6
+ }, import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
7
+ schema: string;
8
+ }>[], PayloadWrapper<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
9
+ schema: string;
10
+ }>[]]>;
11
+ //# sourceMappingURL=validByType.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validByType.d.ts","sourceRoot":"","sources":["../../src/validByType.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAA;AACvE,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAE7D,eAAO,MAAM,WAAW,cAAoB,OAAO,EAAE;;;;;;MAmBpD,CAAA"}
package/package.json ADDED
@@ -0,0 +1,71 @@
1
+ {
2
+ "name": "@xyo-network/archivist-mongodb",
3
+ "author": {
4
+ "email": "support@xyo.network",
5
+ "name": "XYO Development Team",
6
+ "url": "https://xyo.network"
7
+ },
8
+ "bugs": {
9
+ "email": "support@xyo.network",
10
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
+ },
12
+ "dependencies": {
13
+ "@xylabs/assert": "^2.9.3",
14
+ "@xylabs/exists": "^2.9.3",
15
+ "@xylabs/promise": "^2.9.3",
16
+ "@xyo-network/archivist-abstract": "~2.72.9",
17
+ "@xyo-network/archivist-model": "~2.72.9",
18
+ "@xyo-network/boundwitness-builder": "~2.72.9",
19
+ "@xyo-network/boundwitness-model": "~2.72.9",
20
+ "@xyo-network/boundwitness-wrapper": "~2.72.9",
21
+ "@xyo-network/module": "~2.72.9",
22
+ "@xyo-network/node-core-model": "~2.72.9",
23
+ "@xyo-network/payload-model": "~2.72.9",
24
+ "@xyo-network/payload-wrapper": "~2.72.9",
25
+ "lodash": "^4.17.21"
26
+ },
27
+ "optionalDependencies": {
28
+ "@xyo-network/sdk-xyo-mongo-js": "~2.72.9"
29
+ },
30
+ "devDependencies": {
31
+ "@xylabs/ts-scripts-yarn3": "^2.19.3",
32
+ "@xylabs/tsconfig": "^2.19.3",
33
+ "@xyo-network/sdk-xyo-mongo-js": "~2.72.9",
34
+ "fake-indexeddb": "^4.0.2",
35
+ "typescript": "^5.2.2"
36
+ },
37
+ "description": "Primary SDK for using XYO Protocol 2.0",
38
+ "browser": "dist/esm/index.js",
39
+ "docs": "dist/docs.json",
40
+ "exports": {
41
+ ".": {
42
+ "node": {
43
+ "import": "./dist/esm/index.js",
44
+ "require": "./dist/cjs/index.js"
45
+ },
46
+ "browser": {
47
+ "import": "./dist/esm/index.js",
48
+ "require": "./dist/cjs/index.js"
49
+ },
50
+ "default": "./dist/esm/index.js"
51
+ },
52
+ "./dist/docs.json": {
53
+ "default": "./dist/docs.json"
54
+ },
55
+ "./package.json": "./package.json"
56
+ },
57
+ "main": "dist/cjs/index.js",
58
+ "module": "dist/esm/index.js",
59
+ "homepage": "https://xyo.network",
60
+ "license": "LGPL-3.0",
61
+ "publishConfig": {
62
+ "access": "public"
63
+ },
64
+ "repository": {
65
+ "type": "git",
66
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
67
+ },
68
+ "sideEffects": false,
69
+ "types": "dist/types/index.d.ts",
70
+ "version": "2.72.9"
71
+ }
@@ -0,0 +1,114 @@
1
+ import { assertEx } from '@xylabs/assert'
2
+ import { exists } from '@xylabs/exists'
3
+ import { fulfilledValues } from '@xylabs/promise'
4
+ import { AbstractArchivist } from '@xyo-network/archivist-abstract'
5
+ import { ArchivistConfig, ArchivistConfigSchema, ArchivistInsertQuerySchema, ArchivistParams } from '@xyo-network/archivist-model'
6
+ import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'
7
+ import { BoundWitness } from '@xyo-network/boundwitness-model'
8
+ import { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'
9
+ import { AnyConfigSchema } from '@xyo-network/module'
10
+ import { BoundWitnessWithMeta, PayloadWithMeta, PayloadWithPartialMeta } from '@xyo-network/node-core-model'
11
+ import { Payload } from '@xyo-network/payload-model'
12
+ import { PayloadWrapper } from '@xyo-network/payload-wrapper'
13
+ import { BaseMongoSdk, BaseMongoSdkConfig, BaseMongoSdkPrivateConfig, BaseMongoSdkPublicConfig } from '@xyo-network/sdk-xyo-mongo-js'
14
+ import merge from 'lodash/merge'
15
+
16
+ import { validByType } from './validByType'
17
+
18
+ export const MongoDBArchivistConfigSchema = 'network.xyo.archivist.mongodb.config'
19
+ export type MongoDBArchivistConfigSchema = typeof MongoDBArchivistConfigSchema
20
+
21
+ export type MongoDBArchivistConfig = ArchivistConfig<{
22
+ boundWitnessSdkConfig?: Partial<BaseMongoSdkPublicConfig>
23
+ payloadSdkConfig?: Partial<BaseMongoSdkPublicConfig>
24
+ schema: MongoDBArchivistConfigSchema
25
+ }>
26
+
27
+ export type MongoDBArchivistParams = ArchivistParams<
28
+ AnyConfigSchema<MongoDBArchivistConfig>,
29
+ {
30
+ boundWitnessSdkConfig: BaseMongoSdkPrivateConfig & Partial<BaseMongoSdkPublicConfig>
31
+ payloadSdkConfig: BaseMongoSdkPrivateConfig & Partial<BaseMongoSdkPublicConfig>
32
+ }
33
+ >
34
+
35
+ const toBoundWitnessWithMeta = async (wrapper: BoundWitnessWrapper | QueryBoundWitnessWrapper): Promise<BoundWitnessWithMeta> => {
36
+ const bw = wrapper.boundwitness as BoundWitness
37
+ return { ...bw, _hash: await wrapper.hashAsync(), _timestamp: Date.now() }
38
+ }
39
+
40
+ const toReturnValue = (value: Payload | BoundWitness): Payload => {
41
+ const _signatures = (value as BoundWitness)?._signatures
42
+ if (_signatures) {
43
+ return { ...PayloadWrapper.wrap(value).body(), _signatures } as BoundWitness
44
+ } else {
45
+ return { ...PayloadWrapper.wrap(value).body() }
46
+ }
47
+ }
48
+
49
+ const toPayloadWithMeta = async (wrapper: PayloadWrapper): Promise<PayloadWithMeta> => {
50
+ return { ...wrapper.payload(), _hash: await wrapper.hashAsync(), _timestamp: Date.now() }
51
+ }
52
+
53
+ export class MongoDBArchivist<TParams extends MongoDBArchivistParams = MongoDBArchivistParams> extends AbstractArchivist<TParams> {
54
+ static override configSchemas = [MongoDBArchivistConfigSchema, ArchivistConfigSchema]
55
+
56
+ private _boundWitnessSdk: BaseMongoSdk<BoundWitnessWithMeta> | undefined
57
+ private _payloadSdk: BaseMongoSdk<PayloadWithMeta> | undefined
58
+
59
+ get boundWitnessSdkConfig(): BaseMongoSdkConfig {
60
+ return merge({}, this.params.boundWitnessSdkConfig, this.config.boundWitnessSdkConfig, {
61
+ collection: this.config.boundWitnessSdkConfig?.collection ?? this.params.boundWitnessSdkConfig?.collection ?? 'bound_witnesses',
62
+ })
63
+ }
64
+
65
+ get boundWitnesses() {
66
+ this._boundWitnessSdk = this._boundWitnessSdk ?? new BaseMongoSdk<BoundWitnessWithMeta>(this.boundWitnessSdkConfig)
67
+ return assertEx(this._boundWitnessSdk)
68
+ }
69
+
70
+ get payloadSdkConfig(): BaseMongoSdkConfig {
71
+ return merge({}, this.params.payloadSdkConfig, this.config.payloadSdkConfig, {
72
+ collection: this.config.payloadSdkConfig?.collection ?? this.params.payloadSdkConfig?.collection ?? 'payload',
73
+ })
74
+ }
75
+
76
+ get payloads() {
77
+ this._payloadSdk = this._payloadSdk ?? new BaseMongoSdk<PayloadWithMeta>(this.payloadSdkConfig)
78
+ return assertEx(this._payloadSdk)
79
+ }
80
+
81
+ override get queries(): string[] {
82
+ return [ArchivistInsertQuerySchema, ...super.queries]
83
+ }
84
+
85
+ override async head(): Promise<Payload | undefined> {
86
+ const head = await (await this.payloads.find({})).sort({ _timestamp: -1 }).limit(1).toArray()
87
+ return head[0] ? PayloadWrapper.wrap(head[0]).body() : undefined
88
+ }
89
+
90
+ protected override async getHandler(hashes: string[]): Promise<Payload[]> {
91
+ const payloads = hashes.map((_hash) => this.payloads.findOne({ _hash }))
92
+ const bws = hashes.map((_hash) => this.boundWitnesses.findOne({ _hash }))
93
+ const gets = await Promise.allSettled([payloads, bws].flat())
94
+ const succeeded = gets.reduce<(PayloadWithPartialMeta | null)[]>(fulfilledValues, [])
95
+ return succeeded.filter(exists).map(toReturnValue)
96
+ }
97
+
98
+ protected override async insertHandler(payloads?: Payload[]): Promise<Payload[]> {
99
+ const [bw, p] = await validByType(payloads)
100
+ const boundWitnesses = await Promise.all(bw.map((x) => toBoundWitnessWithMeta(x)))
101
+ const payloadsWithMeta = await Promise.all(p.map((x) => toPayloadWithMeta(x)))
102
+ if (boundWitnesses.length) {
103
+ const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnesses)
104
+ if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnesses.length)
105
+ throw new Error('MongoDBDeterministicArchivist: Error inserting BoundWitnesses')
106
+ }
107
+ if (payloadsWithMeta.length) {
108
+ const payloadsResult = await this.payloads.insertMany(payloadsWithMeta)
109
+ if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithMeta.length)
110
+ throw new Error('MongoDBDeterministicArchivist: Error inserting Payloads')
111
+ }
112
+ return payloads ?? []
113
+ }
114
+ }
package/src/index.ts ADDED
@@ -0,0 +1 @@
1
+ export * from './Archivist'
@@ -0,0 +1,26 @@
1
+ import { isQueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'
2
+ import { isBoundWitness } from '@xyo-network/boundwitness-model'
3
+ import { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'
4
+ import { Payload } from '@xyo-network/payload-model'
5
+ import { PayloadWrapper } from '@xyo-network/payload-wrapper'
6
+
7
+ export const validByType = async (payloads: Payload[] = []) => {
8
+ const results: [BoundWitnessWrapper[], PayloadWrapper[]] = [[], []]
9
+ await Promise.all(
10
+ payloads.map(async (payload) => {
11
+ if (isBoundWitness(payload)) {
12
+ const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper
13
+ const bw = wrapper.parse(payload)
14
+ if (await bw.getValid()) {
15
+ results[0].push(bw)
16
+ }
17
+ } else {
18
+ const payloadWrapper = PayloadWrapper.wrap(payload)
19
+ if (await payloadWrapper.getValid()) {
20
+ results[1].push(payloadWrapper)
21
+ }
22
+ }
23
+ }),
24
+ )
25
+ return results
26
+ }
package/typedoc.json ADDED
@@ -0,0 +1,5 @@
1
+ {
2
+ "$schema": "https://typedoc.org/schema.json",
3
+ "entryPoints": ["src/index.ts"],
4
+ "tsconfig": "./tsconfig.typedoc.json"
5
+ }