@xyo-network/boundwitness-builder 2.75.2 → 2.75.4

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.
@@ -1,5 +1,271 @@
1
- export * from "./QueryBoundWitness";
2
- export * from "./QueryBoundWitnessBuilder";
3
- export * from "./QueryBoundWitnessValidator";
4
- export * from "./QueryBoundWitnessWrapper";
1
+ // src/Query/QueryBoundWitness.ts
2
+ import { BoundWitnessSchema, isBoundWitness } from "@xyo-network/boundwitness-model";
3
+ var QueryBoundWitnessSchema = BoundWitnessSchema;
4
+ var isQueryBoundWitness = (x) => isBoundWitness(x) && x?.query !== void 0;
5
+
6
+ // src/Query/QueryBoundWitnessBuilder.ts
7
+ import { assertEx as assertEx2 } from "@xylabs/assert";
8
+ import { PayloadWrapper as PayloadWrapper2 } from "@xyo-network/payload-wrapper";
9
+
10
+ // src/Builder.ts
11
+ import { assertEx } from "@xylabs/assert";
12
+ import { Buffer } from "@xylabs/buffer";
13
+ import { BoundWitnessSchema as BoundWitnessSchema2 } from "@xyo-network/boundwitness-model";
14
+ import { BoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
15
+ import { PayloadHasher, sortFields } from "@xyo-network/core";
16
+ import { PayloadWrapper } from "@xyo-network/payload";
17
+ import { Mutex } from "async-mutex";
18
+ var BoundWitnessBuilder = class _BoundWitnessBuilder {
19
+ constructor(config = { inlinePayloads: false }, logger) {
20
+ this.config = config;
21
+ this.logger = logger;
22
+ }
23
+ static _buildMutex = new Mutex();
24
+ _accounts = [];
25
+ _errorHashes;
26
+ _errors = [];
27
+ _payloadHashes;
28
+ _payloadSchemas;
29
+ _payloads = [];
30
+ _timestamp = Date.now();
31
+ get _payload_schemas() {
32
+ return this._payloadSchemas ?? this._payloads.map((payload) => {
33
+ return assertEx(payload.schema, () => this.missingSchemaMessage(payload));
34
+ });
35
+ }
36
+ async build(meta = false) {
37
+ return await _BoundWitnessBuilder._buildMutex.runExclusive(async () => {
38
+ const hashableFields = await this.hashableFields();
39
+ const _hash = await BoundWitnessWrapper.hashAsync(hashableFields);
40
+ const previousHashes = this._accounts.map((account) => account.previousHash);
41
+ const ret = {
42
+ ...hashableFields,
43
+ _signatures: await this.signatures(_hash, previousHashes)
44
+ };
45
+ if (meta ?? this.config?.meta) {
46
+ const bwWithMeta = ret;
47
+ bwWithMeta._client = "js";
48
+ bwWithMeta._hash = _hash;
49
+ bwWithMeta._timestamp = this._timestamp;
50
+ }
51
+ if (this.config.inlinePayloads) {
52
+ const anyRet = ret;
53
+ anyRet._payloads = this.inlinePayloads();
54
+ }
55
+ return [ret, this._payloads, this._errors];
56
+ });
57
+ }
58
+ error(payload) {
59
+ const unwrappedPayload = PayloadWrapper.unwrap(payload);
60
+ assertEx(this._errorHashes === void 0, "Can not set errors when hashes already set");
61
+ if (unwrappedPayload) {
62
+ this._errors.push(assertEx(sortFields(unwrappedPayload)));
63
+ }
64
+ return this;
65
+ }
66
+ errors(errors) {
67
+ errors?.forEach((error) => {
68
+ if (error !== null) {
69
+ this.error(error);
70
+ }
71
+ });
72
+ return this;
73
+ }
74
+ async hashableFields() {
75
+ const addresses = this._accounts.map((account) => account.address);
76
+ const previous_hashes = this._accounts.map((account) => account.previousHash ?? null);
77
+ const payload_hashes = assertEx(await this.getPayloadHashes(), "Missing payload_hashes");
78
+ const payload_schemas = assertEx(this._payload_schemas, "Missing payload_schemas");
79
+ const result = {
80
+ addresses: assertEx(addresses, "Missing addresses"),
81
+ payload_hashes,
82
+ payload_schemas,
83
+ previous_hashes,
84
+ schema: BoundWitnessSchema2
85
+ };
86
+ assertEx(result.payload_hashes?.length === result.payload_schemas?.length, "Payload hash/schema mismatch");
87
+ assertEx(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), "nulls found in hashes");
88
+ assertEx(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), "nulls found in schemas");
89
+ if (this.config.timestamp ?? true) {
90
+ result.timestamp = this._timestamp;
91
+ }
92
+ return result;
93
+ }
94
+ hashes(hashes, schema) {
95
+ assertEx(this.payloads.length === 0, "Can not set hashes when payloads already set");
96
+ this._payloadHashes = hashes;
97
+ this._payloadSchemas = schema;
98
+ return this;
99
+ }
100
+ payload(payload) {
101
+ const unwrappedPayload = PayloadWrapper.unwrap(payload);
102
+ assertEx(this._payloadHashes === void 0, "Can not set payloads when hashes already set");
103
+ if (unwrappedPayload) {
104
+ this._payloads.push(assertEx(sortFields(unwrappedPayload)));
105
+ }
106
+ return this;
107
+ }
108
+ payloads(payloads) {
109
+ payloads?.forEach((payload) => {
110
+ if (payload !== null) {
111
+ this.payload(payload);
112
+ }
113
+ });
114
+ return this;
115
+ }
116
+ witness(account) {
117
+ this._accounts?.push(account);
118
+ return this;
119
+ }
120
+ witnesses(accounts) {
121
+ this._accounts?.push(...accounts);
122
+ return this;
123
+ }
124
+ async signatures(_hash, previousHashes) {
125
+ const hash = Buffer.from(_hash, "hex");
126
+ return await Promise.all(
127
+ this._accounts.map(async (account, index) => Buffer.from(await account.sign(hash, previousHashes[index])).toString("hex"))
128
+ );
129
+ }
130
+ async getPayloadHashes() {
131
+ return this._payloadHashes ?? await Promise.all(this._payloads.map((payload) => PayloadHasher.hashAsync(payload)));
132
+ }
133
+ inlinePayloads() {
134
+ return this._payloads.map((payload, index) => {
135
+ return {
136
+ ...payload,
137
+ schema: this._payload_schemas[index]
138
+ };
139
+ });
140
+ }
141
+ missingSchemaMessage(payload) {
142
+ return `Builder: Missing Schema
143
+ ${JSON.stringify(payload, null, 2)}`;
144
+ }
145
+ };
146
+
147
+ // src/Query/QueryBoundWitnessBuilder.ts
148
+ var QueryBoundWitnessBuilder = class extends BoundWitnessBuilder {
149
+ _query;
150
+ _resultSet;
151
+ async hashableFields() {
152
+ return {
153
+ ...await super.hashableFields(),
154
+ query: assertEx2(await this._query?.hashAsync(), "No Query Specified"),
155
+ schema: QueryBoundWitnessSchema
156
+ };
157
+ }
158
+ query(query) {
159
+ this._query = PayloadWrapper2.wrap(query);
160
+ this.payload(this._query.payload());
161
+ return this;
162
+ }
163
+ resultSet(payloadSet) {
164
+ this._resultSet = PayloadWrapper2.wrap(payloadSet);
165
+ this.payload(this._resultSet.payload());
166
+ return this;
167
+ }
168
+ };
169
+
170
+ // src/Query/QueryBoundWitnessValidator.ts
171
+ import { assertEx as assertEx3 } from "@xylabs/assert";
172
+ import { BoundWitnessValidator } from "@xyo-network/boundwitness-validator";
173
+ import { BoundWitnessWrapper as BoundWitnessWrapper2 } from "@xyo-network/boundwitness-wrapper";
174
+ import { handleError } from "@xyo-network/error";
175
+ import { PayloadWrapper as PayloadWrapper3 } from "@xyo-network/payload-wrapper";
176
+ var QueryBoundWitnessValidator = class _QueryBoundWitnessValidator extends BoundWitnessValidator {
177
+ _query;
178
+ get expectedSchema() {
179
+ return QueryBoundWitnessSchema;
180
+ }
181
+ static isQueryBoundWitnessValidator(obj) {
182
+ return obj?.constructor === _QueryBoundWitnessValidator;
183
+ }
184
+ async validate() {
185
+ return [
186
+ ...await super.validate()
187
+ // ...this.validateResultSet()
188
+ ];
189
+ }
190
+ async validateResultSet() {
191
+ const errors = [];
192
+ try {
193
+ const resultSetHash = assertEx3(this.obj.resultSet, "Missing ResultSet");
194
+ const wrapper = BoundWitnessWrapper2.parse(this.obj);
195
+ const resultSet = PayloadWrapper3.wrap((await wrapper.payloadMap())[resultSetHash]);
196
+ const required = resultSet?.payload().required;
197
+ if (required) {
198
+ Object.entries(required).forEach(([key, value]) => {
199
+ const found = wrapper.payloadSchemas.reduce((count, schema) => {
200
+ return count + (schema === key ? 1 : 0);
201
+ }, 0);
202
+ if (found !== value) {
203
+ errors.push(Error(`validateResultSet: Missing Schema [${key}:${found}:${value}]`));
204
+ }
205
+ });
206
+ }
207
+ } catch (ex) {
208
+ handleError(ex, (error) => {
209
+ errors.push(error);
210
+ });
211
+ }
212
+ return errors;
213
+ }
214
+ };
215
+
216
+ // src/Query/QueryBoundWitnessWrapper.ts
217
+ import { assertEx as assertEx4 } from "@xylabs/assert";
218
+ import { compact } from "@xylabs/lodash";
219
+ import { BoundWitnessWrapper as BoundWitnessWrapper3 } from "@xyo-network/boundwitness-wrapper";
220
+ import { PayloadHasher as PayloadHasher2 } from "@xyo-network/core";
221
+ import { PayloadWrapper as PayloadWrapper4 } from "@xyo-network/payload-wrapper";
222
+ var QueryBoundWitnessWrapper = class _QueryBoundWitnessWrapper extends BoundWitnessWrapper3 {
223
+ _payloadsWithoutQuery;
224
+ _query;
225
+ _resultSet;
226
+ isQueryBoundWitnessWrapper = true;
227
+ static parseQuery(obj, payloads) {
228
+ assertEx4(!Array.isArray(obj), "Array can not be converted to QueryBoundWitnessWrapper");
229
+ switch (typeof obj) {
230
+ case "object": {
231
+ const castWrapper = obj;
232
+ const wrapper = castWrapper?.isQueryBoundWitnessWrapper ? castWrapper : new _QueryBoundWitnessWrapper(obj, payloads);
233
+ return wrapper;
234
+ }
235
+ }
236
+ throw Error(`Unable to parse [${typeof obj}]`);
237
+ }
238
+ getErrors() {
239
+ return new QueryBoundWitnessValidator(this.boundwitness).validate();
240
+ }
241
+ async getQuery() {
242
+ const payloadMap = await this.allPayloadMap();
243
+ this._query = this._query ?? payloadMap[this.boundwitness.query];
244
+ return assertEx4(this._query, `Missing Query [${this.boundwitness}]`);
245
+ }
246
+ async getResultSet() {
247
+ const resultSetHash = this.boundwitness.resultSet;
248
+ const payloadMap = await this.payloadMap();
249
+ return assertEx4(
250
+ this._resultSet = this._resultSet ?? (resultSetHash ? payloadMap[resultSetHash] : void 0),
251
+ `Missing resultSet [${resultSetHash}]`
252
+ );
253
+ }
254
+ async getWrappedPayloads() {
255
+ this._payloadsWithoutQuery = this._payloadsWithoutQuery ?? compact(
256
+ (await PayloadHasher2.filterExclude(
257
+ (await super.getWrappedPayloads()).map((wrapper) => wrapper.payload()),
258
+ this.payload().query
259
+ )).map((payload) => PayloadWrapper4.wrap(payload))
260
+ );
261
+ return this._payloadsWithoutQuery;
262
+ }
263
+ };
264
+ export {
265
+ QueryBoundWitnessBuilder,
266
+ QueryBoundWitnessSchema,
267
+ QueryBoundWitnessValidator,
268
+ QueryBoundWitnessWrapper,
269
+ isQueryBoundWitness
270
+ };
5
271
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Query/index.ts"],"sourcesContent":["export * from './QueryBoundWitness'\nexport * from './QueryBoundWitnessBuilder'\nexport * from './QueryBoundWitnessValidator'\nexport * from './QueryBoundWitnessWrapper'\n"],"mappings":"AAAA,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;","names":[]}
1
+ {"version":3,"sources":["../../../src/Query/QueryBoundWitness.ts","../../../src/Query/QueryBoundWitnessBuilder.ts","../../../src/Builder.ts","../../../src/Query/QueryBoundWitnessValidator.ts","../../../src/Query/QueryBoundWitnessWrapper.ts"],"sourcesContent":["import { BoundWitness, BoundWitnessSchema, isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type QueryBoundWitnessSchema = BoundWitnessSchema\nexport const QueryBoundWitnessSchema: QueryBoundWitnessSchema = BoundWitnessSchema\n\nexport type QueryBoundWitness = BoundWitness<{\n query: string\n resultSet?: string\n schema: BoundWitnessSchema\n}>\n\nexport const isQueryBoundWitness = (x?: Payload | null): x is QueryBoundWitness => isBoundWitness(x) && (x as QueryBoundWitness)?.query !== undefined\n","import { assertEx } from '@xylabs/assert'\nimport { PayloadSetPayload, Query } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { BoundWitnessBuilder } from '../Builder'\nimport { QueryBoundWitness, QueryBoundWitnessSchema } from './QueryBoundWitness'\n\nexport class QueryBoundWitnessBuilder<\n TBoundWitness extends QueryBoundWitness = QueryBoundWitness,\n TQuery extends Query = Query,\n> extends BoundWitnessBuilder<TBoundWitness> {\n private _query: PayloadWrapper<TQuery> | undefined\n private _resultSet: PayloadWrapper<PayloadSetPayload> | undefined\n\n override async hashableFields(): Promise<TBoundWitness> {\n return {\n ...(await super.hashableFields()),\n query: assertEx(await this._query?.hashAsync(), 'No Query Specified'),\n schema: QueryBoundWitnessSchema,\n }\n }\n\n query<T extends TQuery>(query: T) {\n this._query = PayloadWrapper.wrap(query)\n this.payload(this._query.payload())\n return this\n }\n\n resultSet<T extends PayloadSetPayload>(payloadSet: T) {\n this._resultSet = PayloadWrapper.wrap(payloadSet)\n this.payload(this._resultSet.payload())\n return this\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Buffer } from '@xylabs/buffer'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Data, PayloadHasher, sortFields } from '@xyo-network/core'\nimport { PayloadWrapper } from '@xyo-network/payload'\nimport { ModuleError, Payload } from '@xyo-network/payload-model'\nimport { Logger } from '@xyo-network/shared'\nimport { Mutex } from 'async-mutex'\n\nexport interface BoundWitnessBuilderConfig {\n /** Whether or not the payloads should be included in the metadata sent to and recorded by the ArchivistApi */\n readonly inlinePayloads?: boolean\n readonly meta?: boolean\n readonly timestamp?: boolean\n}\n\nexport class BoundWitnessBuilder<TBoundWitness extends BoundWitness<{ schema: string }> = BoundWitness, TPayload extends Payload = Payload> {\n private static readonly _buildMutex = new Mutex()\n private _accounts: AccountInstance[] = []\n private _errorHashes: string[] | undefined\n private _errors: ModuleError[] = []\n private _payloadHashes: string[] | undefined\n private _payloadSchemas: string[] | undefined\n private _payloads: TPayload[] = []\n private _timestamp = Date.now()\n\n constructor(\n readonly config: BoundWitnessBuilderConfig = { inlinePayloads: false },\n protected readonly logger?: Logger,\n ) {}\n\n private get _payload_schemas(): string[] {\n return (\n this._payloadSchemas ??\n this._payloads.map((payload) => {\n return assertEx(payload.schema, () => this.missingSchemaMessage(payload))\n })\n )\n }\n\n async build(meta = false): Promise<[TBoundWitness, TPayload[], ModuleError[]]> {\n return await BoundWitnessBuilder._buildMutex.runExclusive(async () => {\n const hashableFields = await this.hashableFields()\n const _hash = await BoundWitnessWrapper.hashAsync(hashableFields)\n\n /* get all the previousHashes to verify atomic signing */\n const previousHashes = this._accounts.map((account) => account.previousHash)\n\n const ret: TBoundWitness = {\n ...hashableFields,\n _signatures: await this.signatures(_hash, previousHashes),\n }\n if (meta ?? this.config?.meta) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const bwWithMeta = ret as any\n bwWithMeta._client = 'js'\n bwWithMeta._hash = _hash\n bwWithMeta._timestamp = this._timestamp\n }\n if (this.config.inlinePayloads) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const anyRet = ret as any\n //leaving this in here to prevent breaking code (for now)\n anyRet._payloads = this.inlinePayloads()\n }\n return [ret, this._payloads, this._errors]\n })\n }\n\n error(payload?: ModuleError) {\n const unwrappedPayload = PayloadWrapper.unwrap(payload)\n assertEx(this._errorHashes === undefined, 'Can not set errors when hashes already set')\n if (unwrappedPayload) {\n this._errors.push(assertEx(sortFields(unwrappedPayload)))\n }\n return this\n }\n\n errors(errors?: (ModuleError | null)[]) {\n errors?.forEach((error) => {\n if (error !== null) {\n this.error(error)\n }\n })\n return this\n }\n\n async hashableFields(): Promise<TBoundWitness> {\n const addresses = this._accounts.map((account) => account.address)\n const previous_hashes = this._accounts.map((account) => account.previousHash ?? null)\n const payload_hashes = assertEx(await this.getPayloadHashes(), 'Missing payload_hashes')\n const payload_schemas = assertEx(this._payload_schemas, 'Missing payload_schemas')\n const result: TBoundWitness = {\n addresses: assertEx(addresses, 'Missing addresses'),\n payload_hashes,\n payload_schemas,\n previous_hashes,\n schema: BoundWitnessSchema,\n } as TBoundWitness\n\n assertEx(result.payload_hashes?.length === result.payload_schemas?.length, 'Payload hash/schema mismatch')\n\n assertEx(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), 'nulls found in hashes')\n\n assertEx(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), 'nulls found in schemas')\n\n if (this.config.timestamp ?? true) {\n result.timestamp = this._timestamp\n }\n\n return result\n }\n\n hashes(hashes: string[], schema: string[]) {\n assertEx(this.payloads.length === 0, 'Can not set hashes when payloads already set')\n this._payloadHashes = hashes\n this._payloadSchemas = schema\n return this\n }\n\n payload(payload?: TPayload) {\n const unwrappedPayload = PayloadWrapper.unwrap<TPayload>(payload)\n assertEx(this._payloadHashes === undefined, 'Can not set payloads when hashes already set')\n if (unwrappedPayload) {\n this._payloads.push(assertEx(sortFields<TPayload>(unwrappedPayload)))\n }\n return this\n }\n\n payloads(payloads?: (TPayload | null)[]) {\n payloads?.forEach((payload) => {\n if (payload !== null) {\n this.payload(payload)\n }\n })\n return this\n }\n\n witness(account: AccountInstance) {\n this._accounts?.push(account)\n return this\n }\n\n witnesses(accounts: AccountInstance[]) {\n this._accounts?.push(...accounts)\n return this\n }\n\n protected async signatures(_hash: string, previousHashes: (string | Data | undefined)[]) {\n const hash = Buffer.from(_hash, 'hex')\n return await Promise.all(\n this._accounts.map(async (account, index) => Buffer.from(await account.sign(hash, previousHashes[index])).toString('hex')),\n )\n }\n\n private async getPayloadHashes(): Promise<string[]> {\n return this._payloadHashes ?? (await Promise.all(this._payloads.map((payload) => PayloadHasher.hashAsync(payload))))\n }\n\n private inlinePayloads() {\n return this._payloads.map<TPayload>((payload, index) => {\n return {\n ...payload,\n schema: this._payload_schemas[index],\n }\n })\n }\n\n private missingSchemaMessage(payload: Payload) {\n return `Builder: Missing Schema\\n${JSON.stringify(payload, null, 2)}`\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { BoundWitnessValidator } from '@xyo-network/boundwitness-validator'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { handleError } from '@xyo-network/error'\nimport { PayloadSetPayload, Query } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { QueryBoundWitness, QueryBoundWitnessSchema } from './QueryBoundWitness'\nexport class QueryBoundWitnessValidator<T extends Query = Query> extends BoundWitnessValidator<QueryBoundWitness> {\n private _query: PayloadWrapper<T> | undefined\n\n protected override get expectedSchema(): string {\n return QueryBoundWitnessSchema\n }\n\n static isQueryBoundWitnessValidator(obj: unknown) {\n return (obj as QueryBoundWitnessValidator)?.constructor === QueryBoundWitnessValidator\n }\n\n override async validate() {\n return [\n ...(await super.validate()),\n // ...this.validateResultSet()\n ]\n }\n\n async validateResultSet() {\n const errors: Error[] = []\n try {\n const resultSetHash = assertEx(this.obj.resultSet, 'Missing ResultSet')\n const wrapper = BoundWitnessWrapper.parse(this.obj)\n const resultSet = PayloadWrapper.wrap<PayloadSetPayload>((await wrapper.payloadMap())[resultSetHash] as PayloadSetPayload)\n const required = resultSet?.payload().required\n if (required) {\n Object.entries(required).forEach(([key, value]) => {\n const found = wrapper.payloadSchemas.reduce((count, schema) => {\n return count + (schema === key ? 1 : 0)\n }, 0)\n if (found !== value) {\n errors.push(Error(`validateResultSet: Missing Schema [${key}:${found}:${value}]`))\n }\n })\n }\n } catch (ex) {\n handleError(ex, (error) => {\n errors.push(error)\n })\n }\n return errors\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { Payload, PayloadSetPayload, Query } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { QueryBoundWitness } from './QueryBoundWitness'\nimport { QueryBoundWitnessValidator } from './QueryBoundWitnessValidator'\n\nexport class QueryBoundWitnessWrapper<T extends Query = Query> extends BoundWitnessWrapper<QueryBoundWitness> {\n private _payloadsWithoutQuery: PayloadWrapper<Payload>[] | undefined\n private _query: T | undefined\n private _resultSet: PayloadSetPayload | undefined\n\n private isQueryBoundWitnessWrapper = true\n\n static parseQuery<T extends Query = Query>(obj: unknown, payloads?: Payload[]): QueryBoundWitnessWrapper<T> {\n assertEx(!Array.isArray(obj), 'Array can not be converted to QueryBoundWitnessWrapper')\n switch (typeof obj) {\n case 'object': {\n const castWrapper = obj as QueryBoundWitnessWrapper<T>\n const wrapper = castWrapper?.isQueryBoundWitnessWrapper ? castWrapper : new QueryBoundWitnessWrapper<T>(obj as QueryBoundWitness, payloads)\n /*if (!wrapper.valid) {\n console.warn(`Parsed invalid QueryBoundWitness ${JSON.stringify(wrapper.errors.map((error) => error.message))}`)\n }*/\n return wrapper\n }\n }\n throw Error(`Unable to parse [${typeof obj}]`)\n }\n\n override getErrors() {\n return new QueryBoundWitnessValidator(this.boundwitness).validate()\n }\n\n async getQuery(): Promise<T> {\n const payloadMap = await this.allPayloadMap()\n this._query = this._query ?? (payloadMap[this.boundwitness.query] as T | undefined)\n return assertEx(this._query, `Missing Query [${this.boundwitness}]`)\n }\n\n async getResultSet() {\n const resultSetHash = this.boundwitness.resultSet\n const payloadMap = await this.payloadMap()\n return assertEx(\n (this._resultSet = this._resultSet ?? (resultSetHash ? (payloadMap[resultSetHash] as PayloadSetPayload | undefined) : undefined)),\n `Missing resultSet [${resultSetHash}]`,\n )\n }\n\n override async getWrappedPayloads(): Promise<PayloadWrapper<Payload>[]> {\n this._payloadsWithoutQuery =\n this._payloadsWithoutQuery ??\n compact(\n (\n await PayloadHasher.filterExclude(\n (await super.getWrappedPayloads()).map((wrapper) => wrapper.payload()),\n this.payload().query,\n )\n ).map((payload) => PayloadWrapper.wrap(payload)),\n )\n return this._payloadsWithoutQuery\n }\n}\n"],"mappings":"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","names":["assertEx","PayloadWrapper","BoundWitnessSchema","assertEx","PayloadWrapper","assertEx","BoundWitnessWrapper","PayloadWrapper","assertEx","BoundWitnessWrapper","PayloadWrapper","assertEx","BoundWitnessWrapper","PayloadHasher","PayloadWrapper","BoundWitnessWrapper","assertEx","PayloadHasher","PayloadWrapper"]}
@@ -1,3 +1,270 @@
1
- export * from "./Builder";
2
- export * from "./Query";
1
+ // src/Builder.ts
2
+ import { assertEx } from "@xylabs/assert";
3
+ import { Buffer } from "@xylabs/buffer";
4
+ import { BoundWitnessSchema } from "@xyo-network/boundwitness-model";
5
+ import { BoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
6
+ import { PayloadHasher, sortFields } from "@xyo-network/core";
7
+ import { PayloadWrapper } from "@xyo-network/payload";
8
+ import { Mutex } from "async-mutex";
9
+ var BoundWitnessBuilder = class _BoundWitnessBuilder {
10
+ constructor(config = { inlinePayloads: false }, logger) {
11
+ this.config = config;
12
+ this.logger = logger;
13
+ }
14
+ static _buildMutex = new Mutex();
15
+ _accounts = [];
16
+ _errorHashes;
17
+ _errors = [];
18
+ _payloadHashes;
19
+ _payloadSchemas;
20
+ _payloads = [];
21
+ _timestamp = Date.now();
22
+ get _payload_schemas() {
23
+ return this._payloadSchemas ?? this._payloads.map((payload) => {
24
+ return assertEx(payload.schema, () => this.missingSchemaMessage(payload));
25
+ });
26
+ }
27
+ async build(meta = false) {
28
+ return await _BoundWitnessBuilder._buildMutex.runExclusive(async () => {
29
+ const hashableFields = await this.hashableFields();
30
+ const _hash = await BoundWitnessWrapper.hashAsync(hashableFields);
31
+ const previousHashes = this._accounts.map((account) => account.previousHash);
32
+ const ret = {
33
+ ...hashableFields,
34
+ _signatures: await this.signatures(_hash, previousHashes)
35
+ };
36
+ if (meta ?? this.config?.meta) {
37
+ const bwWithMeta = ret;
38
+ bwWithMeta._client = "js";
39
+ bwWithMeta._hash = _hash;
40
+ bwWithMeta._timestamp = this._timestamp;
41
+ }
42
+ if (this.config.inlinePayloads) {
43
+ const anyRet = ret;
44
+ anyRet._payloads = this.inlinePayloads();
45
+ }
46
+ return [ret, this._payloads, this._errors];
47
+ });
48
+ }
49
+ error(payload) {
50
+ const unwrappedPayload = PayloadWrapper.unwrap(payload);
51
+ assertEx(this._errorHashes === void 0, "Can not set errors when hashes already set");
52
+ if (unwrappedPayload) {
53
+ this._errors.push(assertEx(sortFields(unwrappedPayload)));
54
+ }
55
+ return this;
56
+ }
57
+ errors(errors) {
58
+ errors?.forEach((error) => {
59
+ if (error !== null) {
60
+ this.error(error);
61
+ }
62
+ });
63
+ return this;
64
+ }
65
+ async hashableFields() {
66
+ const addresses = this._accounts.map((account) => account.address);
67
+ const previous_hashes = this._accounts.map((account) => account.previousHash ?? null);
68
+ const payload_hashes = assertEx(await this.getPayloadHashes(), "Missing payload_hashes");
69
+ const payload_schemas = assertEx(this._payload_schemas, "Missing payload_schemas");
70
+ const result = {
71
+ addresses: assertEx(addresses, "Missing addresses"),
72
+ payload_hashes,
73
+ payload_schemas,
74
+ previous_hashes,
75
+ schema: BoundWitnessSchema
76
+ };
77
+ assertEx(result.payload_hashes?.length === result.payload_schemas?.length, "Payload hash/schema mismatch");
78
+ assertEx(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), "nulls found in hashes");
79
+ assertEx(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), "nulls found in schemas");
80
+ if (this.config.timestamp ?? true) {
81
+ result.timestamp = this._timestamp;
82
+ }
83
+ return result;
84
+ }
85
+ hashes(hashes, schema) {
86
+ assertEx(this.payloads.length === 0, "Can not set hashes when payloads already set");
87
+ this._payloadHashes = hashes;
88
+ this._payloadSchemas = schema;
89
+ return this;
90
+ }
91
+ payload(payload) {
92
+ const unwrappedPayload = PayloadWrapper.unwrap(payload);
93
+ assertEx(this._payloadHashes === void 0, "Can not set payloads when hashes already set");
94
+ if (unwrappedPayload) {
95
+ this._payloads.push(assertEx(sortFields(unwrappedPayload)));
96
+ }
97
+ return this;
98
+ }
99
+ payloads(payloads) {
100
+ payloads?.forEach((payload) => {
101
+ if (payload !== null) {
102
+ this.payload(payload);
103
+ }
104
+ });
105
+ return this;
106
+ }
107
+ witness(account) {
108
+ this._accounts?.push(account);
109
+ return this;
110
+ }
111
+ witnesses(accounts) {
112
+ this._accounts?.push(...accounts);
113
+ return this;
114
+ }
115
+ async signatures(_hash, previousHashes) {
116
+ const hash = Buffer.from(_hash, "hex");
117
+ return await Promise.all(
118
+ this._accounts.map(async (account, index) => Buffer.from(await account.sign(hash, previousHashes[index])).toString("hex"))
119
+ );
120
+ }
121
+ async getPayloadHashes() {
122
+ return this._payloadHashes ?? await Promise.all(this._payloads.map((payload) => PayloadHasher.hashAsync(payload)));
123
+ }
124
+ inlinePayloads() {
125
+ return this._payloads.map((payload, index) => {
126
+ return {
127
+ ...payload,
128
+ schema: this._payload_schemas[index]
129
+ };
130
+ });
131
+ }
132
+ missingSchemaMessage(payload) {
133
+ return `Builder: Missing Schema
134
+ ${JSON.stringify(payload, null, 2)}`;
135
+ }
136
+ };
137
+
138
+ // src/Query/QueryBoundWitness.ts
139
+ import { BoundWitnessSchema as BoundWitnessSchema2, isBoundWitness } from "@xyo-network/boundwitness-model";
140
+ var QueryBoundWitnessSchema = BoundWitnessSchema2;
141
+ var isQueryBoundWitness = (x) => isBoundWitness(x) && x?.query !== void 0;
142
+
143
+ // src/Query/QueryBoundWitnessBuilder.ts
144
+ import { assertEx as assertEx2 } from "@xylabs/assert";
145
+ import { PayloadWrapper as PayloadWrapper2 } from "@xyo-network/payload-wrapper";
146
+ var QueryBoundWitnessBuilder = class extends BoundWitnessBuilder {
147
+ _query;
148
+ _resultSet;
149
+ async hashableFields() {
150
+ return {
151
+ ...await super.hashableFields(),
152
+ query: assertEx2(await this._query?.hashAsync(), "No Query Specified"),
153
+ schema: QueryBoundWitnessSchema
154
+ };
155
+ }
156
+ query(query) {
157
+ this._query = PayloadWrapper2.wrap(query);
158
+ this.payload(this._query.payload());
159
+ return this;
160
+ }
161
+ resultSet(payloadSet) {
162
+ this._resultSet = PayloadWrapper2.wrap(payloadSet);
163
+ this.payload(this._resultSet.payload());
164
+ return this;
165
+ }
166
+ };
167
+
168
+ // src/Query/QueryBoundWitnessValidator.ts
169
+ import { assertEx as assertEx3 } from "@xylabs/assert";
170
+ import { BoundWitnessValidator } from "@xyo-network/boundwitness-validator";
171
+ import { BoundWitnessWrapper as BoundWitnessWrapper2 } from "@xyo-network/boundwitness-wrapper";
172
+ import { handleError } from "@xyo-network/error";
173
+ import { PayloadWrapper as PayloadWrapper3 } from "@xyo-network/payload-wrapper";
174
+ var QueryBoundWitnessValidator = class _QueryBoundWitnessValidator extends BoundWitnessValidator {
175
+ _query;
176
+ get expectedSchema() {
177
+ return QueryBoundWitnessSchema;
178
+ }
179
+ static isQueryBoundWitnessValidator(obj) {
180
+ return obj?.constructor === _QueryBoundWitnessValidator;
181
+ }
182
+ async validate() {
183
+ return [
184
+ ...await super.validate()
185
+ // ...this.validateResultSet()
186
+ ];
187
+ }
188
+ async validateResultSet() {
189
+ const errors = [];
190
+ try {
191
+ const resultSetHash = assertEx3(this.obj.resultSet, "Missing ResultSet");
192
+ const wrapper = BoundWitnessWrapper2.parse(this.obj);
193
+ const resultSet = PayloadWrapper3.wrap((await wrapper.payloadMap())[resultSetHash]);
194
+ const required = resultSet?.payload().required;
195
+ if (required) {
196
+ Object.entries(required).forEach(([key, value]) => {
197
+ const found = wrapper.payloadSchemas.reduce((count, schema) => {
198
+ return count + (schema === key ? 1 : 0);
199
+ }, 0);
200
+ if (found !== value) {
201
+ errors.push(Error(`validateResultSet: Missing Schema [${key}:${found}:${value}]`));
202
+ }
203
+ });
204
+ }
205
+ } catch (ex) {
206
+ handleError(ex, (error) => {
207
+ errors.push(error);
208
+ });
209
+ }
210
+ return errors;
211
+ }
212
+ };
213
+
214
+ // src/Query/QueryBoundWitnessWrapper.ts
215
+ import { assertEx as assertEx4 } from "@xylabs/assert";
216
+ import { compact } from "@xylabs/lodash";
217
+ import { BoundWitnessWrapper as BoundWitnessWrapper3 } from "@xyo-network/boundwitness-wrapper";
218
+ import { PayloadHasher as PayloadHasher2 } from "@xyo-network/core";
219
+ import { PayloadWrapper as PayloadWrapper4 } from "@xyo-network/payload-wrapper";
220
+ var QueryBoundWitnessWrapper = class _QueryBoundWitnessWrapper extends BoundWitnessWrapper3 {
221
+ _payloadsWithoutQuery;
222
+ _query;
223
+ _resultSet;
224
+ isQueryBoundWitnessWrapper = true;
225
+ static parseQuery(obj, payloads) {
226
+ assertEx4(!Array.isArray(obj), "Array can not be converted to QueryBoundWitnessWrapper");
227
+ switch (typeof obj) {
228
+ case "object": {
229
+ const castWrapper = obj;
230
+ const wrapper = castWrapper?.isQueryBoundWitnessWrapper ? castWrapper : new _QueryBoundWitnessWrapper(obj, payloads);
231
+ return wrapper;
232
+ }
233
+ }
234
+ throw Error(`Unable to parse [${typeof obj}]`);
235
+ }
236
+ getErrors() {
237
+ return new QueryBoundWitnessValidator(this.boundwitness).validate();
238
+ }
239
+ async getQuery() {
240
+ const payloadMap = await this.allPayloadMap();
241
+ this._query = this._query ?? payloadMap[this.boundwitness.query];
242
+ return assertEx4(this._query, `Missing Query [${this.boundwitness}]`);
243
+ }
244
+ async getResultSet() {
245
+ const resultSetHash = this.boundwitness.resultSet;
246
+ const payloadMap = await this.payloadMap();
247
+ return assertEx4(
248
+ this._resultSet = this._resultSet ?? (resultSetHash ? payloadMap[resultSetHash] : void 0),
249
+ `Missing resultSet [${resultSetHash}]`
250
+ );
251
+ }
252
+ async getWrappedPayloads() {
253
+ this._payloadsWithoutQuery = this._payloadsWithoutQuery ?? compact(
254
+ (await PayloadHasher2.filterExclude(
255
+ (await super.getWrappedPayloads()).map((wrapper) => wrapper.payload()),
256
+ this.payload().query
257
+ )).map((payload) => PayloadWrapper4.wrap(payload))
258
+ );
259
+ return this._payloadsWithoutQuery;
260
+ }
261
+ };
262
+ export {
263
+ BoundWitnessBuilder,
264
+ QueryBoundWitnessBuilder,
265
+ QueryBoundWitnessSchema,
266
+ QueryBoundWitnessValidator,
267
+ QueryBoundWitnessWrapper,
268
+ isQueryBoundWitness
269
+ };
3
270
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["export * from './Builder'\nexport * from './Query'\n"],"mappings":"AAAA,cAAc;AACd,cAAc;","names":[]}
1
+ {"version":3,"sources":["../../src/Builder.ts","../../src/Query/QueryBoundWitness.ts","../../src/Query/QueryBoundWitnessBuilder.ts","../../src/Query/QueryBoundWitnessValidator.ts","../../src/Query/QueryBoundWitnessWrapper.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Buffer } from '@xylabs/buffer'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Data, PayloadHasher, sortFields } from '@xyo-network/core'\nimport { PayloadWrapper } from '@xyo-network/payload'\nimport { ModuleError, Payload } from '@xyo-network/payload-model'\nimport { Logger } from '@xyo-network/shared'\nimport { Mutex } from 'async-mutex'\n\nexport interface BoundWitnessBuilderConfig {\n /** Whether or not the payloads should be included in the metadata sent to and recorded by the ArchivistApi */\n readonly inlinePayloads?: boolean\n readonly meta?: boolean\n readonly timestamp?: boolean\n}\n\nexport class BoundWitnessBuilder<TBoundWitness extends BoundWitness<{ schema: string }> = BoundWitness, TPayload extends Payload = Payload> {\n private static readonly _buildMutex = new Mutex()\n private _accounts: AccountInstance[] = []\n private _errorHashes: string[] | undefined\n private _errors: ModuleError[] = []\n private _payloadHashes: string[] | undefined\n private _payloadSchemas: string[] | undefined\n private _payloads: TPayload[] = []\n private _timestamp = Date.now()\n\n constructor(\n readonly config: BoundWitnessBuilderConfig = { inlinePayloads: false },\n protected readonly logger?: Logger,\n ) {}\n\n private get _payload_schemas(): string[] {\n return (\n this._payloadSchemas ??\n this._payloads.map((payload) => {\n return assertEx(payload.schema, () => this.missingSchemaMessage(payload))\n })\n )\n }\n\n async build(meta = false): Promise<[TBoundWitness, TPayload[], ModuleError[]]> {\n return await BoundWitnessBuilder._buildMutex.runExclusive(async () => {\n const hashableFields = await this.hashableFields()\n const _hash = await BoundWitnessWrapper.hashAsync(hashableFields)\n\n /* get all the previousHashes to verify atomic signing */\n const previousHashes = this._accounts.map((account) => account.previousHash)\n\n const ret: TBoundWitness = {\n ...hashableFields,\n _signatures: await this.signatures(_hash, previousHashes),\n }\n if (meta ?? this.config?.meta) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const bwWithMeta = ret as any\n bwWithMeta._client = 'js'\n bwWithMeta._hash = _hash\n bwWithMeta._timestamp = this._timestamp\n }\n if (this.config.inlinePayloads) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const anyRet = ret as any\n //leaving this in here to prevent breaking code (for now)\n anyRet._payloads = this.inlinePayloads()\n }\n return [ret, this._payloads, this._errors]\n })\n }\n\n error(payload?: ModuleError) {\n const unwrappedPayload = PayloadWrapper.unwrap(payload)\n assertEx(this._errorHashes === undefined, 'Can not set errors when hashes already set')\n if (unwrappedPayload) {\n this._errors.push(assertEx(sortFields(unwrappedPayload)))\n }\n return this\n }\n\n errors(errors?: (ModuleError | null)[]) {\n errors?.forEach((error) => {\n if (error !== null) {\n this.error(error)\n }\n })\n return this\n }\n\n async hashableFields(): Promise<TBoundWitness> {\n const addresses = this._accounts.map((account) => account.address)\n const previous_hashes = this._accounts.map((account) => account.previousHash ?? null)\n const payload_hashes = assertEx(await this.getPayloadHashes(), 'Missing payload_hashes')\n const payload_schemas = assertEx(this._payload_schemas, 'Missing payload_schemas')\n const result: TBoundWitness = {\n addresses: assertEx(addresses, 'Missing addresses'),\n payload_hashes,\n payload_schemas,\n previous_hashes,\n schema: BoundWitnessSchema,\n } as TBoundWitness\n\n assertEx(result.payload_hashes?.length === result.payload_schemas?.length, 'Payload hash/schema mismatch')\n\n assertEx(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), 'nulls found in hashes')\n\n assertEx(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), 'nulls found in schemas')\n\n if (this.config.timestamp ?? true) {\n result.timestamp = this._timestamp\n }\n\n return result\n }\n\n hashes(hashes: string[], schema: string[]) {\n assertEx(this.payloads.length === 0, 'Can not set hashes when payloads already set')\n this._payloadHashes = hashes\n this._payloadSchemas = schema\n return this\n }\n\n payload(payload?: TPayload) {\n const unwrappedPayload = PayloadWrapper.unwrap<TPayload>(payload)\n assertEx(this._payloadHashes === undefined, 'Can not set payloads when hashes already set')\n if (unwrappedPayload) {\n this._payloads.push(assertEx(sortFields<TPayload>(unwrappedPayload)))\n }\n return this\n }\n\n payloads(payloads?: (TPayload | null)[]) {\n payloads?.forEach((payload) => {\n if (payload !== null) {\n this.payload(payload)\n }\n })\n return this\n }\n\n witness(account: AccountInstance) {\n this._accounts?.push(account)\n return this\n }\n\n witnesses(accounts: AccountInstance[]) {\n this._accounts?.push(...accounts)\n return this\n }\n\n protected async signatures(_hash: string, previousHashes: (string | Data | undefined)[]) {\n const hash = Buffer.from(_hash, 'hex')\n return await Promise.all(\n this._accounts.map(async (account, index) => Buffer.from(await account.sign(hash, previousHashes[index])).toString('hex')),\n )\n }\n\n private async getPayloadHashes(): Promise<string[]> {\n return this._payloadHashes ?? (await Promise.all(this._payloads.map((payload) => PayloadHasher.hashAsync(payload))))\n }\n\n private inlinePayloads() {\n return this._payloads.map<TPayload>((payload, index) => {\n return {\n ...payload,\n schema: this._payload_schemas[index],\n }\n })\n }\n\n private missingSchemaMessage(payload: Payload) {\n return `Builder: Missing Schema\\n${JSON.stringify(payload, null, 2)}`\n }\n}\n","import { BoundWitness, BoundWitnessSchema, isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type QueryBoundWitnessSchema = BoundWitnessSchema\nexport const QueryBoundWitnessSchema: QueryBoundWitnessSchema = BoundWitnessSchema\n\nexport type QueryBoundWitness = BoundWitness<{\n query: string\n resultSet?: string\n schema: BoundWitnessSchema\n}>\n\nexport const isQueryBoundWitness = (x?: Payload | null): x is QueryBoundWitness => isBoundWitness(x) && (x as QueryBoundWitness)?.query !== undefined\n","import { assertEx } from '@xylabs/assert'\nimport { PayloadSetPayload, Query } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { BoundWitnessBuilder } from '../Builder'\nimport { QueryBoundWitness, QueryBoundWitnessSchema } from './QueryBoundWitness'\n\nexport class QueryBoundWitnessBuilder<\n TBoundWitness extends QueryBoundWitness = QueryBoundWitness,\n TQuery extends Query = Query,\n> extends BoundWitnessBuilder<TBoundWitness> {\n private _query: PayloadWrapper<TQuery> | undefined\n private _resultSet: PayloadWrapper<PayloadSetPayload> | undefined\n\n override async hashableFields(): Promise<TBoundWitness> {\n return {\n ...(await super.hashableFields()),\n query: assertEx(await this._query?.hashAsync(), 'No Query Specified'),\n schema: QueryBoundWitnessSchema,\n }\n }\n\n query<T extends TQuery>(query: T) {\n this._query = PayloadWrapper.wrap(query)\n this.payload(this._query.payload())\n return this\n }\n\n resultSet<T extends PayloadSetPayload>(payloadSet: T) {\n this._resultSet = PayloadWrapper.wrap(payloadSet)\n this.payload(this._resultSet.payload())\n return this\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { BoundWitnessValidator } from '@xyo-network/boundwitness-validator'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { handleError } from '@xyo-network/error'\nimport { PayloadSetPayload, Query } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { QueryBoundWitness, QueryBoundWitnessSchema } from './QueryBoundWitness'\nexport class QueryBoundWitnessValidator<T extends Query = Query> extends BoundWitnessValidator<QueryBoundWitness> {\n private _query: PayloadWrapper<T> | undefined\n\n protected override get expectedSchema(): string {\n return QueryBoundWitnessSchema\n }\n\n static isQueryBoundWitnessValidator(obj: unknown) {\n return (obj as QueryBoundWitnessValidator)?.constructor === QueryBoundWitnessValidator\n }\n\n override async validate() {\n return [\n ...(await super.validate()),\n // ...this.validateResultSet()\n ]\n }\n\n async validateResultSet() {\n const errors: Error[] = []\n try {\n const resultSetHash = assertEx(this.obj.resultSet, 'Missing ResultSet')\n const wrapper = BoundWitnessWrapper.parse(this.obj)\n const resultSet = PayloadWrapper.wrap<PayloadSetPayload>((await wrapper.payloadMap())[resultSetHash] as PayloadSetPayload)\n const required = resultSet?.payload().required\n if (required) {\n Object.entries(required).forEach(([key, value]) => {\n const found = wrapper.payloadSchemas.reduce((count, schema) => {\n return count + (schema === key ? 1 : 0)\n }, 0)\n if (found !== value) {\n errors.push(Error(`validateResultSet: Missing Schema [${key}:${found}:${value}]`))\n }\n })\n }\n } catch (ex) {\n handleError(ex, (error) => {\n errors.push(error)\n })\n }\n return errors\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { Payload, PayloadSetPayload, Query } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { QueryBoundWitness } from './QueryBoundWitness'\nimport { QueryBoundWitnessValidator } from './QueryBoundWitnessValidator'\n\nexport class QueryBoundWitnessWrapper<T extends Query = Query> extends BoundWitnessWrapper<QueryBoundWitness> {\n private _payloadsWithoutQuery: PayloadWrapper<Payload>[] | undefined\n private _query: T | undefined\n private _resultSet: PayloadSetPayload | undefined\n\n private isQueryBoundWitnessWrapper = true\n\n static parseQuery<T extends Query = Query>(obj: unknown, payloads?: Payload[]): QueryBoundWitnessWrapper<T> {\n assertEx(!Array.isArray(obj), 'Array can not be converted to QueryBoundWitnessWrapper')\n switch (typeof obj) {\n case 'object': {\n const castWrapper = obj as QueryBoundWitnessWrapper<T>\n const wrapper = castWrapper?.isQueryBoundWitnessWrapper ? castWrapper : new QueryBoundWitnessWrapper<T>(obj as QueryBoundWitness, payloads)\n /*if (!wrapper.valid) {\n console.warn(`Parsed invalid QueryBoundWitness ${JSON.stringify(wrapper.errors.map((error) => error.message))}`)\n }*/\n return wrapper\n }\n }\n throw Error(`Unable to parse [${typeof obj}]`)\n }\n\n override getErrors() {\n return new QueryBoundWitnessValidator(this.boundwitness).validate()\n }\n\n async getQuery(): Promise<T> {\n const payloadMap = await this.allPayloadMap()\n this._query = this._query ?? (payloadMap[this.boundwitness.query] as T | undefined)\n return assertEx(this._query, `Missing Query [${this.boundwitness}]`)\n }\n\n async getResultSet() {\n const resultSetHash = this.boundwitness.resultSet\n const payloadMap = await this.payloadMap()\n return assertEx(\n (this._resultSet = this._resultSet ?? (resultSetHash ? (payloadMap[resultSetHash] as PayloadSetPayload | undefined) : undefined)),\n `Missing resultSet [${resultSetHash}]`,\n )\n }\n\n override async getWrappedPayloads(): Promise<PayloadWrapper<Payload>[]> {\n this._payloadsWithoutQuery =\n this._payloadsWithoutQuery ??\n compact(\n (\n await PayloadHasher.filterExclude(\n (await super.getWrappedPayloads()).map((wrapper) => wrapper.payload()),\n this.payload().query,\n )\n ).map((payload) => PayloadWrapper.wrap(payload)),\n )\n return this._payloadsWithoutQuery\n }\n}\n"],"mappings":"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","names":["BoundWitnessSchema","assertEx","PayloadWrapper","assertEx","PayloadWrapper","assertEx","BoundWitnessWrapper","PayloadWrapper","assertEx","BoundWitnessWrapper","PayloadWrapper","assertEx","BoundWitnessWrapper","PayloadHasher","PayloadWrapper","BoundWitnessWrapper","assertEx","PayloadHasher","PayloadWrapper"]}