@xyo-network/boundwitness-builder 3.5.2 → 3.6.0-rc.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/Builder.d.ts +18 -45
- package/dist/browser/Builder.d.ts.map +1 -1
- package/dist/browser/Query/QueryBoundWitnessBuilder.d.ts +3 -5
- package/dist/browser/Query/QueryBoundWitnessBuilder.d.ts.map +1 -1
- package/dist/browser/index.mjs +71 -104
- package/dist/browser/index.mjs.map +1 -1
- package/dist/neutral/Builder.d.ts +18 -45
- package/dist/neutral/Builder.d.ts.map +1 -1
- package/dist/neutral/Query/QueryBoundWitnessBuilder.d.ts +3 -5
- package/dist/neutral/Query/QueryBoundWitnessBuilder.d.ts.map +1 -1
- package/dist/neutral/index.mjs +71 -104
- package/dist/neutral/index.mjs.map +1 -1
- package/dist/node/Builder.d.ts +18 -45
- package/dist/node/Builder.d.ts.map +1 -1
- package/dist/node/Query/QueryBoundWitnessBuilder.d.ts +3 -5
- package/dist/node/Query/QueryBoundWitnessBuilder.d.ts.map +1 -1
- package/dist/node/index.mjs +71 -104
- package/dist/node/index.mjs.map +1 -1
- package/package.json +18 -18
- package/src/Builder.ts +83 -131
- package/src/Query/QueryBoundWitnessBuilder.ts +9 -23
|
@@ -1,75 +1,48 @@
|
|
|
1
1
|
import type { Address, Hash } from '@xylabs/hex';
|
|
2
|
-
import type { AnyObject, JsonObject } from '@xylabs/object';
|
|
3
2
|
import type { AccountInstance } from '@xyo-network/account-model';
|
|
4
|
-
import type { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
5
|
-
import {
|
|
6
|
-
import type { PayloadBuilderOptions, WithoutMeta, WithoutSchema } from '@xyo-network/payload-builder';
|
|
3
|
+
import type { BoundWitness, Signed, UnsignedBoundWitness } from '@xyo-network/boundwitness-model';
|
|
4
|
+
import type { PayloadBuilderOptions } from '@xyo-network/payload-builder';
|
|
7
5
|
import { PayloadBuilderBase } from '@xyo-network/payload-builder';
|
|
8
|
-
import type { ModuleError, Payload, Schema,
|
|
9
|
-
export
|
|
10
|
-
export
|
|
11
|
-
|
|
12
|
-
readonly destination?: Hash[];
|
|
13
|
-
readonly payloadHashes?: TBoundWitness['payload_hashes'];
|
|
14
|
-
readonly payloadSchemas?: TBoundWitness['payload_schemas'];
|
|
15
|
-
readonly payloads?: TPayload[];
|
|
16
|
-
readonly sourceQuery?: Hash;
|
|
17
|
-
readonly timestamp?: number;
|
|
18
|
-
}
|
|
19
|
-
export declare class BoundWitnessBuilder<TBoundWitness extends BoundWitness = BoundWitness, TPayload extends Payload = Payload> extends PayloadBuilderBase<Omit<TBoundWitness, GeneratedBoundWitnessFields>, BoundWitnessBuilderOptions<TBoundWitness> & {
|
|
20
|
-
schema: BoundWitnessSchema;
|
|
21
|
-
}> {
|
|
6
|
+
import type { ModuleError, Payload, Schema, WithoutMeta, WithoutSchema } from '@xyo-network/payload-model';
|
|
7
|
+
export declare const GeneratedBoundWitnessFields: readonly ["addresses", "payload_hashes", "payload_schemas", "previous_hashes"];
|
|
8
|
+
export type GeneratedBoundWitnessFields = typeof GeneratedBoundWitnessFields[number];
|
|
9
|
+
export declare class BoundWitnessBuilder<TBoundWitness extends UnsignedBoundWitness = UnsignedBoundWitness, TPayload extends Payload = Payload> extends PayloadBuilderBase<TBoundWitness> {
|
|
22
10
|
private static readonly _buildMutex;
|
|
23
11
|
private _accounts;
|
|
24
|
-
private _destination?;
|
|
25
12
|
private _errorHashes?;
|
|
26
13
|
private _errors;
|
|
27
14
|
private _payloadHashes?;
|
|
28
15
|
private _payloadSchemas?;
|
|
29
16
|
private _payloads;
|
|
30
|
-
|
|
31
|
-
private _timestamp;
|
|
32
|
-
constructor(options?: BoundWitnessBuilderOptions<TBoundWitness, TPayload>);
|
|
17
|
+
constructor(options?: Omit<PayloadBuilderOptions, 'schema'>);
|
|
33
18
|
protected get addresses(): Address[];
|
|
34
19
|
protected get payloadSchemas(): string[];
|
|
35
|
-
protected get
|
|
20
|
+
protected get previousHashBytes(): (ArrayBufferLike | null)[];
|
|
36
21
|
protected get previousHashes(): (Hash | null)[];
|
|
37
|
-
protected get timestamp(): number;
|
|
38
22
|
static addressIndex<T extends BoundWitness>(payload: T, address: Address): number;
|
|
39
|
-
static build<TBoundWitness extends BoundWitness>(options: BoundWitnessBuilderOptions<TBoundWitness>): Promise<[WithMeta<TBoundWitness>, WithMeta<{
|
|
40
|
-
schema: string;
|
|
41
|
-
} & import("@xyo-network/payload-model").PayloadFields>[], WithMeta<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
42
|
-
details?: import("@xylabs/object").JsonValue;
|
|
43
|
-
message?: string;
|
|
44
|
-
name?: string;
|
|
45
|
-
query?: Hash;
|
|
46
|
-
schema: import("@xyo-network/payload-model").ModuleErrorSchema;
|
|
47
|
-
sources?: Hash[];
|
|
48
|
-
}>[]]>;
|
|
49
|
-
static dataHashableFields<T extends Payload = Payload<AnyObject>>(schema: string, fields?: WithoutSchema<WithoutMeta<T>>): Promise<WithoutMeta<T>>;
|
|
50
23
|
static previousHash<T extends BoundWitness>(boundWitness: T, address: Address): string | undefined;
|
|
51
|
-
protected static linkingFields<T extends BoundWitness
|
|
52
|
-
protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp?: boolean, accounts?: AccountInstance[], previousHashes?: (Hash | null)[], destination?: Address[], sourceQuery?: Hash): Promise<JsonObject>;
|
|
24
|
+
protected static linkingFields<T extends BoundWitness>(accounts: AccountInstance[], payloads?: Payload[]): Promise<Pick<T, GeneratedBoundWitnessFields>>;
|
|
53
25
|
protected static signature<T extends BoundWitness>(payload: T, address: Address): Lowercase<string>;
|
|
54
|
-
protected static signatures(accounts: AccountInstance[],
|
|
55
|
-
private static
|
|
56
|
-
build(): Promise<[
|
|
57
|
-
|
|
26
|
+
protected static signatures(accounts: AccountInstance[], dataHash: Hash): Promise<string[]>;
|
|
27
|
+
private static validateGeneratedFields;
|
|
28
|
+
build(): Promise<[Signed<TBoundWitness>, TPayload[], ModuleError[]]>;
|
|
29
|
+
dataHash(): Promise<Lowercase<string>>;
|
|
30
|
+
dataHashableFields(): Promise<import("@xylabs/object").DeepOmitStartsWith<import("@xylabs/object").DeepOmitStartsWith<TBoundWitness, "_">, "$">>;
|
|
58
31
|
error(payload?: ModuleError): this;
|
|
59
32
|
errors(errors?: (ModuleError | null)[]): this;
|
|
33
|
+
fields(fields: WithoutMeta<WithoutSchema<Omit<TBoundWitness, GeneratedBoundWitnessFields>>>): this;
|
|
60
34
|
hashes(hashes: Hash[], schema: Schema[]): this;
|
|
61
35
|
payload(payload?: TPayload): this;
|
|
62
36
|
payloads(payloads?: (TPayload | null)[]): this;
|
|
63
37
|
signer(account: AccountInstance): this;
|
|
64
38
|
signers(accounts: AccountInstance[]): this;
|
|
65
|
-
sourceQuery(
|
|
39
|
+
sourceQuery(sourceQuery: Hash): this;
|
|
66
40
|
/** @deprecated use signer instead */
|
|
67
41
|
witness(account: AccountInstance): this;
|
|
68
42
|
/** @deprecated use signers instead */
|
|
69
43
|
witnesses(accounts: AccountInstance[]): this;
|
|
70
|
-
protected
|
|
71
|
-
|
|
72
|
-
private linkingFields;
|
|
44
|
+
protected sign(): Promise<string[]>;
|
|
45
|
+
private generatedFields;
|
|
73
46
|
private missingSchemaMessage;
|
|
74
47
|
}
|
|
75
48
|
//# sourceMappingURL=Builder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAEhD,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import type { QueryBoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import type {
|
|
2
|
+
import type { Query, WithoutMeta } from '@xyo-network/payload-model';
|
|
3
3
|
import { BoundWitnessBuilder } from '../Builder.ts';
|
|
4
4
|
export declare class QueryBoundWitnessBuilder<TBoundWitness extends QueryBoundWitness = QueryBoundWitness, TQuery extends Query = Query> extends BoundWitnessBuilder<TBoundWitness> {
|
|
5
|
-
private _additional?;
|
|
6
5
|
private _query;
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
query<T extends TQuery>(query: T): Promise<this>;
|
|
6
|
+
dataHashableFields(): Promise<WithoutMeta<TBoundWitness>>;
|
|
7
|
+
query<T extends TQuery>(query: T): this;
|
|
10
8
|
}
|
|
11
9
|
//# sourceMappingURL=QueryBoundWitnessBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QueryBoundWitnessBuilder.d.ts","sourceRoot":"","sources":["../../../src/Query/QueryBoundWitnessBuilder.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"QueryBoundWitnessBuilder.d.ts","sourceRoot":"","sources":["../../../src/Query/QueryBoundWitnessBuilder.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAExE,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAEpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAA;AAEnD,qBAAa,wBAAwB,CACnC,aAAa,SAAS,iBAAiB,GAAG,iBAAiB,EAC3D,MAAM,SAAS,KAAK,GAAG,KAAK,CAC5B,SAAQ,mBAAmB,CAAC,aAAa,CAAC;IAC1C,OAAO,CAAC,MAAM,CAAoB;IAEnB,kBAAkB,IAAI,OAAO,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;IAQxE,KAAK,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,CAAC;CAKjC"}
|
package/dist/browser/index.mjs
CHANGED
|
@@ -3,9 +3,18 @@ import { toArrayBuffer } from "@xylabs/arraybuffer";
|
|
|
3
3
|
import { assertEx } from "@xylabs/assert";
|
|
4
4
|
import { hexFromArrayBuffer } from "@xylabs/hex";
|
|
5
5
|
import { BoundWitnessSchema } from "@xyo-network/boundwitness-model";
|
|
6
|
-
import {
|
|
7
|
-
|
|
6
|
+
import {
|
|
7
|
+
ObjectHasher,
|
|
8
|
+
removeEmptyFields,
|
|
9
|
+
sortFields
|
|
10
|
+
} from "@xyo-network/hash";
|
|
11
|
+
import {
|
|
12
|
+
omitSchema,
|
|
13
|
+
PayloadBuilder,
|
|
14
|
+
PayloadBuilderBase
|
|
15
|
+
} from "@xyo-network/payload-builder";
|
|
8
16
|
import { Mutex } from "async-mutex";
|
|
17
|
+
var GeneratedBoundWitnessFields = ["addresses", "payload_hashes", "payload_schemas", "previous_hashes"];
|
|
9
18
|
var uniqueAccounts = (accounts, throwOnFalse = false) => {
|
|
10
19
|
const addresses = /* @__PURE__ */ new Set();
|
|
11
20
|
for (const account of accounts) {
|
|
@@ -21,33 +30,14 @@ var uniqueAccounts = (accounts, throwOnFalse = false) => {
|
|
|
21
30
|
};
|
|
22
31
|
var BoundWitnessBuilder = class _BoundWitnessBuilder extends PayloadBuilderBase {
|
|
23
32
|
static _buildMutex = new Mutex();
|
|
24
|
-
_accounts;
|
|
25
|
-
_destination;
|
|
33
|
+
_accounts = [];
|
|
26
34
|
_errorHashes;
|
|
27
35
|
_errors = [];
|
|
28
36
|
_payloadHashes;
|
|
29
37
|
_payloadSchemas;
|
|
30
|
-
_payloads;
|
|
31
|
-
_sourceQuery;
|
|
32
|
-
_timestamp;
|
|
38
|
+
_payloads = [];
|
|
33
39
|
constructor(options) {
|
|
34
40
|
super({ ...options, schema: BoundWitnessSchema });
|
|
35
|
-
const {
|
|
36
|
-
accounts,
|
|
37
|
-
payloadHashes,
|
|
38
|
-
payloadSchemas,
|
|
39
|
-
payloads,
|
|
40
|
-
sourceQuery,
|
|
41
|
-
timestamp,
|
|
42
|
-
destination
|
|
43
|
-
} = options ?? {};
|
|
44
|
-
this._accounts = accounts ?? [];
|
|
45
|
-
this._payloadHashes = payloadHashes;
|
|
46
|
-
this._payloadSchemas = payloadSchemas;
|
|
47
|
-
this._payloads = payloads ?? [];
|
|
48
|
-
this._sourceQuery = sourceQuery;
|
|
49
|
-
this._destination = destination;
|
|
50
|
-
this._timestamp = timestamp ?? true;
|
|
51
41
|
}
|
|
52
42
|
get addresses() {
|
|
53
43
|
uniqueAccounts(this._accounts, true);
|
|
@@ -58,15 +48,12 @@ var BoundWitnessBuilder = class _BoundWitnessBuilder extends PayloadBuilderBase
|
|
|
58
48
|
return assertEx(payload.schema, () => this.missingSchemaMessage(payload));
|
|
59
49
|
});
|
|
60
50
|
}
|
|
61
|
-
get
|
|
51
|
+
get previousHashBytes() {
|
|
62
52
|
return this._accounts.map((account) => account.previousHashBytes ?? null);
|
|
63
53
|
}
|
|
64
54
|
get previousHashes() {
|
|
65
55
|
return this._accounts.map((account) => account.previousHash ?? null);
|
|
66
56
|
}
|
|
67
|
-
get timestamp() {
|
|
68
|
-
return this._timestamp = typeof this._timestamp === "number" ? this._timestamp : Date.now();
|
|
69
|
-
}
|
|
70
57
|
static addressIndex(payload, address) {
|
|
71
58
|
const index = payload.addresses.indexOf(address);
|
|
72
59
|
if (index === -1) {
|
|
@@ -74,77 +61,63 @@ var BoundWitnessBuilder = class _BoundWitnessBuilder extends PayloadBuilderBase
|
|
|
74
61
|
}
|
|
75
62
|
return index;
|
|
76
63
|
}
|
|
77
|
-
static async build(options) {
|
|
78
|
-
return await new _BoundWitnessBuilder(options).build();
|
|
79
|
-
}
|
|
80
|
-
static async dataHashableFields(schema, fields) {
|
|
81
|
-
return await PayloadBuilderBase.dataHashableFields(schema, fields ? removeEmptyFields(fields) : void 0);
|
|
82
|
-
}
|
|
83
64
|
static previousHash(boundWitness, address) {
|
|
84
65
|
return boundWitness.previous_hashes[this.addressIndex(boundWitness, address)]?.toLowerCase();
|
|
85
66
|
}
|
|
86
|
-
static async linkingFields(accounts, payloads
|
|
67
|
+
static async linkingFields(accounts, payloads) {
|
|
87
68
|
const addresses = accounts.map((account) => hexFromArrayBuffer(account.addressBytes, { prefix: false }));
|
|
88
69
|
const previous_hashes = accounts.map((account) => account.previousHash ?? null);
|
|
89
70
|
const payload_hashes = payloads ? await PayloadBuilder.dataHashes(payloads) : [];
|
|
90
|
-
const payload_schemas = payloads?.map(({ schema }) => schema);
|
|
71
|
+
const payload_schemas = payloads?.map(({ schema }) => schema) ?? [];
|
|
91
72
|
return {
|
|
92
73
|
addresses,
|
|
93
74
|
payload_hashes,
|
|
94
75
|
payload_schemas,
|
|
95
|
-
previous_hashes
|
|
96
|
-
timestamp
|
|
76
|
+
previous_hashes
|
|
97
77
|
};
|
|
98
78
|
}
|
|
99
|
-
static async metaFields(dataHash, otherMeta, stamp = true, accounts, previousHashes, destination, sourceQuery) {
|
|
100
|
-
const meta = await super.metaFields(dataHash, otherMeta, stamp);
|
|
101
|
-
if (accounts?.length && previousHashes?.length) {
|
|
102
|
-
assertEx(accounts.length === previousHashes.length, () => "accounts and previousHashes must have same length");
|
|
103
|
-
meta.signatures = await this.signatures(accounts, dataHash, previousHashes);
|
|
104
|
-
}
|
|
105
|
-
if (sourceQuery) {
|
|
106
|
-
meta.sourceQuery = sourceQuery;
|
|
107
|
-
}
|
|
108
|
-
if (destination) {
|
|
109
|
-
meta.destination = destination;
|
|
110
|
-
}
|
|
111
|
-
return meta;
|
|
112
|
-
}
|
|
113
79
|
static signature(payload, address) {
|
|
114
|
-
return payload.$
|
|
80
|
+
return payload.$signatures[this.addressIndex(payload, address)];
|
|
115
81
|
}
|
|
116
|
-
static async signatures(accounts,
|
|
117
|
-
const hashBytes = toArrayBuffer(
|
|
118
|
-
const previousHashesBytes =
|
|
119
|
-
return await Promise.all(accounts.map(async (account, index) => hexFromArrayBuffer(await account.sign(hashBytes, previousHashesBytes[index]))));
|
|
82
|
+
static async signatures(accounts, dataHash) {
|
|
83
|
+
const hashBytes = toArrayBuffer(dataHash);
|
|
84
|
+
const previousHashesBytes = accounts?.map((account) => account.previousHashBytes);
|
|
85
|
+
return await Promise.all(accounts.map(async (account, index) => hexFromArrayBuffer((await account.sign(hashBytes, previousHashesBytes[index]))[0])));
|
|
120
86
|
}
|
|
121
|
-
static
|
|
122
|
-
assertEx(
|
|
123
|
-
assertEx(!
|
|
124
|
-
assertEx(!
|
|
87
|
+
static validateGeneratedFields(fields) {
|
|
88
|
+
assertEx(fields.payload_hashes?.length === fields.payload_schemas?.length, () => "Payload hash/schema mismatch");
|
|
89
|
+
assertEx(!fields.payload_hashes.some((hash) => !hash), () => "nulls found in hashes");
|
|
90
|
+
assertEx(!fields.payload_schemas.some((schema) => !schema), () => "nulls found in schemas");
|
|
125
91
|
}
|
|
126
92
|
async build() {
|
|
127
93
|
return await _BoundWitnessBuilder._buildMutex.runExclusive(async () => {
|
|
128
94
|
const dataHashableFields = await this.dataHashableFields();
|
|
129
|
-
const $
|
|
130
|
-
const $meta = await this.metaFields($hash);
|
|
95
|
+
const $signatures = await this.sign();
|
|
131
96
|
const ret = {
|
|
97
|
+
...this._meta,
|
|
132
98
|
...dataHashableFields,
|
|
133
|
-
$
|
|
134
|
-
$meta
|
|
99
|
+
$signatures
|
|
135
100
|
};
|
|
136
101
|
return [
|
|
137
102
|
ret,
|
|
138
|
-
|
|
139
|
-
|
|
103
|
+
this._payloads,
|
|
104
|
+
this._errors
|
|
140
105
|
];
|
|
141
106
|
});
|
|
142
107
|
}
|
|
108
|
+
async dataHash() {
|
|
109
|
+
const dataHashableFields = await this.dataHashableFields();
|
|
110
|
+
const hash = await ObjectHasher.hash(dataHashableFields);
|
|
111
|
+
return hash;
|
|
112
|
+
}
|
|
143
113
|
async dataHashableFields() {
|
|
144
|
-
const
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
114
|
+
const generatedFields = await this.generatedFields();
|
|
115
|
+
_BoundWitnessBuilder.validateGeneratedFields(generatedFields);
|
|
116
|
+
const fields = {
|
|
117
|
+
...this._fields,
|
|
118
|
+
...generatedFields
|
|
119
|
+
};
|
|
120
|
+
return await _BoundWitnessBuilder.dataHashableFields(this._schema, fields);
|
|
148
121
|
}
|
|
149
122
|
error(payload) {
|
|
150
123
|
assertEx(this._errorHashes === void 0, () => "Can not set errors when hashes already set");
|
|
@@ -163,6 +136,18 @@ var BoundWitnessBuilder = class _BoundWitnessBuilder extends PayloadBuilderBase
|
|
|
163
136
|
}
|
|
164
137
|
return this;
|
|
165
138
|
}
|
|
139
|
+
fields(fields) {
|
|
140
|
+
const clone = structuredClone(fields);
|
|
141
|
+
for (const field of GeneratedBoundWitnessFields) {
|
|
142
|
+
delete clone[field];
|
|
143
|
+
}
|
|
144
|
+
this._fields = omitSchema(
|
|
145
|
+
PayloadBuilderBase.omitMeta(
|
|
146
|
+
removeEmptyFields(structuredClone(fields))
|
|
147
|
+
)
|
|
148
|
+
);
|
|
149
|
+
return this;
|
|
150
|
+
}
|
|
166
151
|
hashes(hashes, schema) {
|
|
167
152
|
assertEx(this.payloads.length === 0, () => "Can not set hashes when payloads already set");
|
|
168
153
|
this._payloadHashes = hashes;
|
|
@@ -195,8 +180,11 @@ var BoundWitnessBuilder = class _BoundWitnessBuilder extends PayloadBuilderBase
|
|
|
195
180
|
this._accounts?.push(...accounts);
|
|
196
181
|
return this;
|
|
197
182
|
}
|
|
198
|
-
sourceQuery(
|
|
199
|
-
this.
|
|
183
|
+
sourceQuery(sourceQuery) {
|
|
184
|
+
this._meta = {
|
|
185
|
+
...this._meta,
|
|
186
|
+
$sourceQuery: sourceQuery
|
|
187
|
+
};
|
|
200
188
|
return this;
|
|
201
189
|
}
|
|
202
190
|
/** @deprecated use signer instead */
|
|
@@ -209,25 +197,13 @@ var BoundWitnessBuilder = class _BoundWitnessBuilder extends PayloadBuilderBase
|
|
|
209
197
|
this._accounts?.push(...accounts);
|
|
210
198
|
return this;
|
|
211
199
|
}
|
|
212
|
-
async
|
|
213
|
-
return await _BoundWitnessBuilder.metaFields(
|
|
214
|
-
dataHash,
|
|
215
|
-
this._$meta,
|
|
216
|
-
stamp,
|
|
217
|
-
this._accounts,
|
|
218
|
-
this.previousHashes,
|
|
219
|
-
this._destination,
|
|
220
|
-
this._sourceQuery
|
|
221
|
-
);
|
|
222
|
-
}
|
|
223
|
-
async signatures(_hash, previousHashes) {
|
|
200
|
+
async sign() {
|
|
224
201
|
uniqueAccounts(this._accounts, true);
|
|
225
|
-
const
|
|
226
|
-
|
|
227
|
-
return await Promise.all(this._accounts.map(async (account, index) => hexFromArrayBuffer(await account.sign(hash, previousHashesBytes[index]))));
|
|
202
|
+
const hashBytes = toArrayBuffer(await this.dataHash());
|
|
203
|
+
return await Promise.all(this._accounts.map(async (account) => hexFromArrayBuffer((await account.sign(hashBytes))[0])));
|
|
228
204
|
}
|
|
229
|
-
async
|
|
230
|
-
return await _BoundWitnessBuilder.linkingFields(this._accounts, this._payloads
|
|
205
|
+
async generatedFields() {
|
|
206
|
+
return await _BoundWitnessBuilder.linkingFields(this._accounts, this._payloads);
|
|
231
207
|
}
|
|
232
208
|
missingSchemaMessage(payload) {
|
|
233
209
|
return `Builder: Missing Schema
|
|
@@ -237,34 +213,25 @@ ${JSON.stringify(payload, null, 2)}`;
|
|
|
237
213
|
|
|
238
214
|
// src/Query/QueryBoundWitnessBuilder.ts
|
|
239
215
|
import { assertEx as assertEx2 } from "@xylabs/assert";
|
|
240
|
-
import { QueryBoundWitnessSchema } from "@xyo-network/boundwitness-model";
|
|
241
216
|
import { PayloadBuilder as PayloadBuilder2 } from "@xyo-network/payload";
|
|
242
217
|
var QueryBoundWitnessBuilder = class extends BoundWitnessBuilder {
|
|
243
|
-
_additional;
|
|
244
218
|
_query;
|
|
245
|
-
async additional(additional) {
|
|
246
|
-
this._additional = await PayloadBuilder2.dataHashes(additional);
|
|
247
|
-
return this;
|
|
248
|
-
}
|
|
249
219
|
async dataHashableFields() {
|
|
250
220
|
const fields = {
|
|
251
221
|
...await super.dataHashableFields(),
|
|
252
|
-
query: assertEx2(this._query, () => "No Query Specified")
|
|
253
|
-
schema: QueryBoundWitnessSchema
|
|
222
|
+
query: await PayloadBuilder2.dataHash(assertEx2(this._query, () => "No Query Specified"))
|
|
254
223
|
};
|
|
255
|
-
|
|
256
|
-
fields.additional = this._additional;
|
|
257
|
-
}
|
|
258
|
-
return fields;
|
|
224
|
+
return { ...fields };
|
|
259
225
|
}
|
|
260
|
-
|
|
261
|
-
this.
|
|
262
|
-
this.
|
|
226
|
+
query(query) {
|
|
227
|
+
this.payload(query);
|
|
228
|
+
this._query = query;
|
|
263
229
|
return this;
|
|
264
230
|
}
|
|
265
231
|
};
|
|
266
232
|
export {
|
|
267
233
|
BoundWitnessBuilder,
|
|
234
|
+
GeneratedBoundWitnessFields,
|
|
268
235
|
QueryBoundWitnessBuilder
|
|
269
236
|
};
|
|
270
237
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Builder.ts","../../src/Query/QueryBoundWitnessBuilder.ts"],"sourcesContent":["import { toArrayBuffer } from '@xylabs/arraybuffer'\nimport { assertEx } from '@xylabs/assert'\nimport type { Address, Hash } from '@xylabs/hex'\nimport { hexFromArrayBuffer } from '@xylabs/hex'\nimport type { AnyObject, JsonObject } from '@xylabs/object'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { removeEmptyFields, sortFields } from '@xyo-network/hash'\nimport type {\n PayloadBuilderOptions, WithoutMeta, WithoutSchema,\n} from '@xyo-network/payload-builder'\nimport { PayloadBuilder, PayloadBuilderBase } from '@xyo-network/payload-builder'\nimport type {\n ModuleError, Payload, Schema, WithMeta,\n} from '@xyo-network/payload-model'\nimport { Mutex } from 'async-mutex'\n\nexport type GeneratedBoundWitnessFields = 'addresses' | 'payload_hashes' | 'payload_schemas' | 'previous_hashes'\n\nexport interface BoundWitnessBuilderOptions<TBoundWitness extends BoundWitness = BoundWitness, TPayload extends Payload = Payload>\n extends Omit<PayloadBuilderOptions<Omit<TBoundWitness, GeneratedBoundWitnessFields>>, 'schema'> {\n readonly accounts?: AccountInstance[]\n readonly destination?: Hash[]\n readonly payloadHashes?: TBoundWitness['payload_hashes']\n readonly payloadSchemas?: TBoundWitness['payload_schemas']\n readonly payloads?: TPayload[]\n readonly sourceQuery?: Hash\n readonly timestamp?: number\n}\n\nconst uniqueAccounts = (accounts: AccountInstance[], throwOnFalse = false) => {\n const addresses = new Set<Address>()\n for (const account of accounts) {\n if (addresses.has(account.address)) {\n if (throwOnFalse) {\n throw new Error('Duplicate address')\n }\n return false\n }\n addresses.add(account.address)\n }\n return true\n}\n\nexport class BoundWitnessBuilder<TBoundWitness extends BoundWitness = BoundWitness, TPayload extends Payload = Payload> extends PayloadBuilderBase<\n Omit<TBoundWitness, GeneratedBoundWitnessFields>,\n BoundWitnessBuilderOptions<TBoundWitness> & { schema: BoundWitnessSchema }\n> {\n private static readonly _buildMutex = new Mutex()\n private _accounts: AccountInstance[]\n private _destination?: Hash[]\n private _errorHashes?: Hash[]\n private _errors: ModuleError[] = []\n private _payloadHashes?: Hash[]\n private _payloadSchemas?: Schema[]\n private _payloads: TPayload[]\n private _sourceQuery?: Hash\n private _timestamp: boolean | number\n\n constructor(options?: BoundWitnessBuilderOptions<TBoundWitness, TPayload>) {\n super({ ...options, schema: BoundWitnessSchema })\n const {\n accounts, payloadHashes, payloadSchemas, payloads, sourceQuery, timestamp, destination,\n } = options ?? {}\n this._accounts = accounts ?? []\n this._payloadHashes = payloadHashes\n this._payloadSchemas = payloadSchemas\n this._payloads = payloads ?? []\n this._sourceQuery = sourceQuery\n this._destination = destination\n this._timestamp = timestamp ?? true\n }\n\n protected get addresses(): Address[] {\n uniqueAccounts(this._accounts, true)\n return this._accounts.map(account => account.address.toLowerCase()) as Address[]\n }\n\n protected get payloadSchemas(): string[] {\n return (\n this._payloadSchemas\n ?? this._payloads.map((payload) => {\n return assertEx(payload.schema, () => this.missingSchemaMessage(payload))\n })\n )\n }\n\n protected get previousHashBuffers(): (ArrayBufferLike | null)[] {\n return this._accounts.map(account => account.previousHashBytes ?? null)\n }\n\n protected get previousHashes(): (Hash | null)[] {\n return this._accounts.map(account => account.previousHash ?? null)\n }\n\n protected get timestamp(): number {\n return (this._timestamp = typeof this._timestamp === 'number' ? this._timestamp : Date.now())\n }\n\n static addressIndex<T extends BoundWitness>(payload: T, address: Address) {\n const index = payload.addresses.indexOf(address)\n if (index === -1) {\n throw new Error('Invalid address')\n }\n return index\n }\n\n static async build<TBoundWitness extends BoundWitness>(options: BoundWitnessBuilderOptions<TBoundWitness>) {\n return await new BoundWitnessBuilder(options).build()\n }\n\n static override async dataHashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n ): Promise<WithoutMeta<T>> {\n return await PayloadBuilderBase.dataHashableFields(schema, fields ? removeEmptyFields(fields) : undefined)\n }\n\n static previousHash<T extends BoundWitness>(boundWitness: T, address: Address) {\n return boundWitness.previous_hashes[this.addressIndex(boundWitness, address)]?.toLowerCase()\n }\n\n protected static async linkingFields<T extends BoundWitness = BoundWitness>(\n accounts: AccountInstance[],\n payloads?: Payload[],\n timestamp = Date.now(),\n ) {\n const addresses = accounts.map(account => hexFromArrayBuffer(account.addressBytes, { prefix: false }))\n const previous_hashes = accounts.map(account => account.previousHash ?? null)\n const payload_hashes = payloads ? await PayloadBuilder.dataHashes(payloads) : []\n const payload_schemas = payloads?.map(({ schema }) => schema)\n return {\n addresses, payload_hashes, payload_schemas, previous_hashes, timestamp,\n } as WithoutSchema<WithoutMeta<T>>\n }\n\n protected static override async metaFields(\n dataHash: Hash,\n otherMeta?: JsonObject,\n stamp = true,\n accounts?: AccountInstance[],\n previousHashes?: (Hash | null)[],\n destination?: Address[],\n sourceQuery?: Hash,\n ): Promise<JsonObject> {\n const meta = await super.metaFields(dataHash, otherMeta, stamp)\n\n if (accounts?.length && previousHashes?.length) {\n assertEx(accounts.length === previousHashes.length, () => 'accounts and previousHashes must have same length')\n meta.signatures = await this.signatures(accounts, dataHash, previousHashes)\n }\n\n if (sourceQuery) {\n meta.sourceQuery = sourceQuery\n }\n\n if (destination) {\n meta.destination = destination\n }\n\n return meta\n }\n\n protected static signature<T extends BoundWitness>(payload: T, address: Address) {\n return payload.$meta.signatures[this.addressIndex(payload, address)]\n }\n\n protected static async signatures(accounts: AccountInstance[], hash: Hash, previousHashes: (Hash | ArrayBuffer | null)[]): Promise<string[]> {\n const hashBytes = toArrayBuffer(hash)\n const previousHashesBytes = previousHashes?.map(ph => (ph ? toArrayBuffer(ph) : undefined))\n return await Promise.all(accounts.map(async (account, index) => hexFromArrayBuffer(await account.sign(hashBytes, previousHashesBytes[index]))))\n }\n\n private static validateLinkingFields(bw: Pick<BoundWitness, 'payload_hashes' | 'payload_schemas'>) {\n assertEx(bw.payload_hashes?.length === bw.payload_schemas?.length, () => 'Payload hash/schema mismatch')\n assertEx(!bw.payload_hashes.some(hash => !hash), () => 'nulls found in hashes')\n assertEx(!bw.payload_schemas.some(schema => !schema), () => 'nulls found in schemas')\n }\n\n async build(): Promise<[WithMeta<TBoundWitness>, WithMeta<TPayload>[], WithMeta<ModuleError>[]]> {\n return await BoundWitnessBuilder._buildMutex.runExclusive(async () => {\n const dataHashableFields = (await this.dataHashableFields()) as TBoundWitness\n const $hash = (await PayloadBuilder.build(dataHashableFields)).$hash\n const $meta = await this.metaFields($hash)\n\n const ret = {\n ...dataHashableFields,\n $hash,\n $meta,\n } as WithMeta<TBoundWitness>\n return [\n ret,\n await Promise.all(this._payloads?.map(payload => PayloadBuilder.build(payload))),\n await Promise.all(this._errors?.map(error => PayloadBuilder.build(error))),\n ]\n })\n }\n\n override async dataHashableFields(): Promise<WithoutMeta<TBoundWitness>> {\n const fields = await this.linkingFields()\n const result = await BoundWitnessBuilder.dataHashableFields<TBoundWitness>(this._schema, fields)\n\n BoundWitnessBuilder.validateLinkingFields(result)\n\n return result as Omit<TBoundWitness, '$meta' | '$hash'>\n }\n\n error(payload?: ModuleError) {\n assertEx(this._errorHashes === undefined, () => 'Can not set errors when hashes already set')\n if (payload) {\n this._errors.push(assertEx(sortFields(payload)))\n }\n return this\n }\n\n errors(errors?: (ModuleError | null)[]) {\n if (errors) {\n for (const error of errors) {\n if (error !== null) {\n this.error(error)\n }\n }\n }\n return this\n }\n\n hashes(hashes: Hash[], schema: Schema[]) {\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 assertEx(this._payloadHashes === undefined, () => 'Can not set payloads when hashes already set')\n if (payload) {\n this._payloads.push(assertEx(sortFields<TPayload>(payload)))\n }\n return this\n }\n\n payloads(payloads?: (TPayload | null)[]) {\n if (payloads)\n for (const payload of payloads) {\n if (payload !== null) {\n this.payload(payload)\n }\n }\n return this\n }\n\n signer(account: AccountInstance) {\n uniqueAccounts([...this._accounts, account], true)\n this._accounts?.push(account)\n return this\n }\n\n signers(accounts: AccountInstance[]) {\n uniqueAccounts([...this._accounts, ...accounts], true)\n this._accounts?.push(...accounts)\n return this\n }\n\n sourceQuery(query?: Hash) {\n this._sourceQuery = query?.toLowerCase() as Hash\n return this\n }\n\n /** @deprecated use signer instead */\n witness(account: AccountInstance) {\n this._accounts?.push(account)\n return this\n }\n\n /** @deprecated use signers instead */\n witnesses(accounts: AccountInstance[]) {\n this._accounts?.push(...accounts)\n return this\n }\n\n protected override async metaFields(dataHash: Hash, stamp = true): Promise<JsonObject> {\n return await BoundWitnessBuilder.metaFields(\n dataHash,\n this._$meta,\n stamp,\n this._accounts,\n this.previousHashes,\n this._destination,\n this._sourceQuery,\n )\n }\n\n protected async signatures(_hash: Hash, previousHashes: (Hash | ArrayBuffer | null)[]): Promise<string[]> {\n uniqueAccounts(this._accounts, true)\n const hash = toArrayBuffer(_hash)\n const previousHashesBytes = previousHashes.map(ph => (ph ? toArrayBuffer(ph) : undefined))\n return await Promise.all(this._accounts.map(async (account, index) => hexFromArrayBuffer(await account.sign(hash, previousHashesBytes[index]))))\n }\n\n private async linkingFields() {\n return await BoundWitnessBuilder.linkingFields<TBoundWitness>(this._accounts, this._payloads, this.timestamp)\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 type { Hash } from '@xylabs/hex'\nimport type { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload'\nimport type {\n Payload, Query, WithMeta,\n} from '@xyo-network/payload-model'\n\nimport { BoundWitnessBuilder } from '../Builder.ts'\n\nexport class QueryBoundWitnessBuilder<\n TBoundWitness extends QueryBoundWitness = QueryBoundWitness,\n TQuery extends Query = Query,\n> extends BoundWitnessBuilder<TBoundWitness> {\n private _additional?: Hash[]\n private _query: WithMeta<TQuery> | undefined\n\n async additional(additional: Payload[]) {\n this._additional = await PayloadBuilder.dataHashes(additional)\n return this\n }\n\n override async dataHashableFields(): Promise<Omit<TBoundWitness, '$hash' | '$meta'>> {\n const fields = {\n ...(await super.dataHashableFields()),\n query: assertEx(this._query, () => 'No Query Specified').$hash,\n schema: QueryBoundWitnessSchema,\n } as Omit<TBoundWitness, '$hash' | '$meta'>\n if (this._additional) {\n fields.additional = this._additional\n }\n return fields\n }\n\n async query<T extends TQuery>(query: T) {\n this._query = await PayloadBuilder.build(query)\n this.payload(this._query)\n return this\n }\n}\n"],"mappings":"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","names":["assertEx","PayloadBuilder","PayloadBuilder","assertEx"]}
|
|
1
|
+
{"version":3,"sources":["../../src/Builder.ts","../../src/Query/QueryBoundWitnessBuilder.ts"],"sourcesContent":["import { toArrayBuffer } from '@xylabs/arraybuffer'\nimport { assertEx } from '@xylabs/assert'\nimport type { Address, Hash } from '@xylabs/hex'\nimport { hexFromArrayBuffer } from '@xylabs/hex'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type {\n BoundWitness,\n Signed,\n UnsignedBoundWitness,\n} from '@xyo-network/boundwitness-model'\nimport { BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport {\n ObjectHasher, removeEmptyFields, sortFields,\n} from '@xyo-network/hash'\nimport type { PayloadBuilderOptions } from '@xyo-network/payload-builder'\nimport {\n omitSchema, PayloadBuilder, PayloadBuilderBase,\n} from '@xyo-network/payload-builder'\nimport type {\n ModuleError, Payload, Schema,\n WithoutMeta,\n WithoutSchema,\n} from '@xyo-network/payload-model'\nimport { Mutex } from 'async-mutex'\n\nexport const GeneratedBoundWitnessFields = ['addresses', 'payload_hashes', 'payload_schemas', 'previous_hashes'] as const\nexport type GeneratedBoundWitnessFields = typeof GeneratedBoundWitnessFields[number]\n\nconst uniqueAccounts = (accounts: AccountInstance[], throwOnFalse = false) => {\n const addresses = new Set<Address>()\n for (const account of accounts) {\n if (addresses.has(account.address)) {\n if (throwOnFalse) {\n throw new Error('Duplicate address')\n }\n return false\n }\n addresses.add(account.address)\n }\n return true\n}\n\nexport class BoundWitnessBuilder<\n TBoundWitness extends UnsignedBoundWitness = UnsignedBoundWitness,\n TPayload extends Payload = Payload>\n extends PayloadBuilderBase<\n TBoundWitness\n > {\n private static readonly _buildMutex = new Mutex()\n\n private _accounts: AccountInstance[] = []\n private _errorHashes?: Hash[]\n private _errors: ModuleError[] = []\n private _payloadHashes?: Hash[]\n private _payloadSchemas?: Schema[]\n private _payloads: TPayload[] = []\n\n constructor(options?: Omit<PayloadBuilderOptions, 'schema'>) {\n super({ ...options, schema: BoundWitnessSchema })\n }\n\n protected get addresses(): Address[] {\n uniqueAccounts(this._accounts, true)\n return this._accounts.map(account => account.address.toLowerCase()) as Address[]\n }\n\n protected get payloadSchemas(): string[] {\n return (\n this._payloadSchemas\n ?? this._payloads.map((payload) => {\n return assertEx(payload.schema, () => this.missingSchemaMessage(payload))\n })\n )\n }\n\n protected get previousHashBytes(): (ArrayBufferLike | null)[] {\n return this._accounts.map(account => account.previousHashBytes ?? null)\n }\n\n protected get previousHashes(): (Hash | null)[] {\n return this._accounts.map(account => account.previousHash ?? null)\n }\n\n static addressIndex<T extends BoundWitness>(payload: T, address: Address) {\n const index = payload.addresses.indexOf(address)\n if (index === -1) {\n throw new Error('Invalid address')\n }\n return index\n }\n\n static previousHash<T extends BoundWitness>(boundWitness: T, address: Address) {\n return boundWitness.previous_hashes[this.addressIndex(boundWitness, address)]?.toLowerCase()\n }\n\n protected static async linkingFields<T extends BoundWitness>(\n accounts: AccountInstance[],\n payloads?: Payload[],\n ): Promise<Pick<T, GeneratedBoundWitnessFields>> {\n const addresses = accounts.map(account => hexFromArrayBuffer(account.addressBytes, { prefix: false }))\n const previous_hashes = accounts.map(account => account.previousHash ?? null)\n const payload_hashes = payloads ? await PayloadBuilder.dataHashes(payloads) : []\n const payload_schemas = payloads?.map(({ schema }) => schema) ?? []\n return {\n addresses, payload_hashes, payload_schemas, previous_hashes,\n }\n }\n\n protected static signature<T extends BoundWitness>(payload: T, address: Address) {\n return payload.$signatures[this.addressIndex(payload, address)]\n }\n\n protected static async signatures(accounts: AccountInstance[], dataHash: Hash): Promise<string[]> {\n const hashBytes = toArrayBuffer(dataHash)\n const previousHashesBytes = accounts?.map(account => account.previousHashBytes)\n return await Promise.all(accounts.map(async (account, index) => hexFromArrayBuffer((await account.sign(hashBytes, previousHashesBytes[index]))[0])))\n }\n\n private static validateGeneratedFields(fields: Pick<BoundWitness, GeneratedBoundWitnessFields>) {\n assertEx(fields.payload_hashes?.length === fields.payload_schemas?.length, () => 'Payload hash/schema mismatch')\n assertEx(!fields.payload_hashes.some(hash => !hash), () => 'nulls found in hashes')\n assertEx(!fields.payload_schemas.some(schema => !schema), () => 'nulls found in schemas')\n }\n\n async build(): Promise<[Signed<TBoundWitness>, TPayload[], ModuleError[]]> {\n return await BoundWitnessBuilder._buildMutex.runExclusive(async () => {\n const dataHashableFields = (await this.dataHashableFields()) as TBoundWitness\n const $signatures = await this.sign()\n\n const ret = {\n ...this._meta, ...dataHashableFields, $signatures,\n } as Signed<TBoundWitness>\n return [\n ret,\n this._payloads,\n this._errors,\n ]\n })\n }\n\n async dataHash() {\n const dataHashableFields = await this.dataHashableFields()\n const hash = await ObjectHasher.hash(dataHashableFields)\n return hash\n }\n\n override async dataHashableFields() {\n const generatedFields: Pick<TBoundWitness, GeneratedBoundWitnessFields> = await this.generatedFields()\n BoundWitnessBuilder.validateGeneratedFields(generatedFields)\n const fields: WithoutSchema<TBoundWitness> = {\n ...this._fields,\n ...generatedFields,\n } as WithoutSchema<TBoundWitness>\n return await BoundWitnessBuilder.dataHashableFields<TBoundWitness>(this._schema, fields)\n }\n\n error(payload?: ModuleError) {\n assertEx(this._errorHashes === undefined, () => 'Can not set errors when hashes already set')\n if (payload) {\n this._errors.push(assertEx(sortFields(payload)))\n }\n return this\n }\n\n errors(errors?: (ModuleError | null)[]) {\n if (errors) {\n for (const error of errors) {\n if (error !== null) {\n this.error(error)\n }\n }\n }\n return this\n }\n\n override fields(fields: WithoutMeta<WithoutSchema<Omit<TBoundWitness, GeneratedBoundWitnessFields>>>): this {\n const clone = structuredClone(fields) as unknown as Partial<TBoundWitness>\n for (const field of GeneratedBoundWitnessFields) {\n delete clone[field]\n }\n // we need to do the cast here since ts seems to not like nested, yet same, generics\n this._fields = omitSchema(\n PayloadBuilderBase.omitMeta(\n removeEmptyFields(structuredClone(fields)),\n ),\n ) as unknown as WithoutMeta<WithoutSchema<TBoundWitness>>\n return this\n }\n\n hashes(hashes: Hash[], schema: Schema[]) {\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 assertEx(this._payloadHashes === undefined, () => 'Can not set payloads when hashes already set')\n if (payload) {\n this._payloads.push(assertEx(sortFields<TPayload>(payload)))\n }\n return this\n }\n\n payloads(payloads?: (TPayload | null)[]) {\n if (payloads)\n for (const payload of payloads) {\n if (payload !== null) {\n this.payload(payload)\n }\n }\n return this\n }\n\n signer(account: AccountInstance) {\n uniqueAccounts([...this._accounts, account], true)\n this._accounts?.push(account)\n return this\n }\n\n signers(accounts: AccountInstance[]) {\n uniqueAccounts([...this._accounts, ...accounts], true)\n this._accounts?.push(...accounts)\n return this\n }\n\n sourceQuery(sourceQuery: Hash) {\n this._meta = {\n ...this._meta,\n $sourceQuery: sourceQuery,\n } as typeof this._meta\n return this\n }\n\n /** @deprecated use signer instead */\n witness(account: AccountInstance) {\n this._accounts?.push(account)\n return this\n }\n\n /** @deprecated use signers instead */\n witnesses(accounts: AccountInstance[]) {\n this._accounts?.push(...accounts)\n return this\n }\n\n protected async sign(): Promise<string[]> {\n uniqueAccounts(this._accounts, true)\n const hashBytes = toArrayBuffer(await this.dataHash())\n return await Promise.all(this._accounts.map(async account => hexFromArrayBuffer((await account.sign(hashBytes))[0])))\n }\n\n private async generatedFields(): Promise<Pick<TBoundWitness, GeneratedBoundWitnessFields>> {\n return await BoundWitnessBuilder.linkingFields(this._accounts, this._payloads)\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 type { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload'\nimport type { Query, WithoutMeta } from '@xyo-network/payload-model'\n\nimport { BoundWitnessBuilder } from '../Builder.ts'\n\nexport class QueryBoundWitnessBuilder<\n TBoundWitness extends QueryBoundWitness = QueryBoundWitness,\n TQuery extends Query = Query,\n> extends BoundWitnessBuilder<TBoundWitness> {\n private _query: TQuery | undefined\n\n override async dataHashableFields(): Promise<WithoutMeta<TBoundWitness>> {\n const fields = {\n ...(await super.dataHashableFields()),\n query: await PayloadBuilder.dataHash(assertEx(this._query, () => 'No Query Specified')),\n } as TBoundWitness\n return { ...fields } as WithoutMeta<TBoundWitness>\n }\n\n query<T extends TQuery>(query: T) {\n this.payload(query)\n this._query = query\n return this\n }\n}\n"],"mappings":"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","names":["assertEx","PayloadBuilder","PayloadBuilder","assertEx"]}
|
|
@@ -1,75 +1,48 @@
|
|
|
1
1
|
import type { Address, Hash } from '@xylabs/hex';
|
|
2
|
-
import type { AnyObject, JsonObject } from '@xylabs/object';
|
|
3
2
|
import type { AccountInstance } from '@xyo-network/account-model';
|
|
4
|
-
import type { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
5
|
-
import {
|
|
6
|
-
import type { PayloadBuilderOptions, WithoutMeta, WithoutSchema } from '@xyo-network/payload-builder';
|
|
3
|
+
import type { BoundWitness, Signed, UnsignedBoundWitness } from '@xyo-network/boundwitness-model';
|
|
4
|
+
import type { PayloadBuilderOptions } from '@xyo-network/payload-builder';
|
|
7
5
|
import { PayloadBuilderBase } from '@xyo-network/payload-builder';
|
|
8
|
-
import type { ModuleError, Payload, Schema,
|
|
9
|
-
export
|
|
10
|
-
export
|
|
11
|
-
|
|
12
|
-
readonly destination?: Hash[];
|
|
13
|
-
readonly payloadHashes?: TBoundWitness['payload_hashes'];
|
|
14
|
-
readonly payloadSchemas?: TBoundWitness['payload_schemas'];
|
|
15
|
-
readonly payloads?: TPayload[];
|
|
16
|
-
readonly sourceQuery?: Hash;
|
|
17
|
-
readonly timestamp?: number;
|
|
18
|
-
}
|
|
19
|
-
export declare class BoundWitnessBuilder<TBoundWitness extends BoundWitness = BoundWitness, TPayload extends Payload = Payload> extends PayloadBuilderBase<Omit<TBoundWitness, GeneratedBoundWitnessFields>, BoundWitnessBuilderOptions<TBoundWitness> & {
|
|
20
|
-
schema: BoundWitnessSchema;
|
|
21
|
-
}> {
|
|
6
|
+
import type { ModuleError, Payload, Schema, WithoutMeta, WithoutSchema } from '@xyo-network/payload-model';
|
|
7
|
+
export declare const GeneratedBoundWitnessFields: readonly ["addresses", "payload_hashes", "payload_schemas", "previous_hashes"];
|
|
8
|
+
export type GeneratedBoundWitnessFields = typeof GeneratedBoundWitnessFields[number];
|
|
9
|
+
export declare class BoundWitnessBuilder<TBoundWitness extends UnsignedBoundWitness = UnsignedBoundWitness, TPayload extends Payload = Payload> extends PayloadBuilderBase<TBoundWitness> {
|
|
22
10
|
private static readonly _buildMutex;
|
|
23
11
|
private _accounts;
|
|
24
|
-
private _destination?;
|
|
25
12
|
private _errorHashes?;
|
|
26
13
|
private _errors;
|
|
27
14
|
private _payloadHashes?;
|
|
28
15
|
private _payloadSchemas?;
|
|
29
16
|
private _payloads;
|
|
30
|
-
|
|
31
|
-
private _timestamp;
|
|
32
|
-
constructor(options?: BoundWitnessBuilderOptions<TBoundWitness, TPayload>);
|
|
17
|
+
constructor(options?: Omit<PayloadBuilderOptions, 'schema'>);
|
|
33
18
|
protected get addresses(): Address[];
|
|
34
19
|
protected get payloadSchemas(): string[];
|
|
35
|
-
protected get
|
|
20
|
+
protected get previousHashBytes(): (ArrayBufferLike | null)[];
|
|
36
21
|
protected get previousHashes(): (Hash | null)[];
|
|
37
|
-
protected get timestamp(): number;
|
|
38
22
|
static addressIndex<T extends BoundWitness>(payload: T, address: Address): number;
|
|
39
|
-
static build<TBoundWitness extends BoundWitness>(options: BoundWitnessBuilderOptions<TBoundWitness>): Promise<[WithMeta<TBoundWitness>, WithMeta<{
|
|
40
|
-
schema: string;
|
|
41
|
-
} & import("@xyo-network/payload-model").PayloadFields>[], WithMeta<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
42
|
-
details?: import("@xylabs/object").JsonValue;
|
|
43
|
-
message?: string;
|
|
44
|
-
name?: string;
|
|
45
|
-
query?: Hash;
|
|
46
|
-
schema: import("@xyo-network/payload-model").ModuleErrorSchema;
|
|
47
|
-
sources?: Hash[];
|
|
48
|
-
}>[]]>;
|
|
49
|
-
static dataHashableFields<T extends Payload = Payload<AnyObject>>(schema: string, fields?: WithoutSchema<WithoutMeta<T>>): Promise<WithoutMeta<T>>;
|
|
50
23
|
static previousHash<T extends BoundWitness>(boundWitness: T, address: Address): string | undefined;
|
|
51
|
-
protected static linkingFields<T extends BoundWitness
|
|
52
|
-
protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp?: boolean, accounts?: AccountInstance[], previousHashes?: (Hash | null)[], destination?: Address[], sourceQuery?: Hash): Promise<JsonObject>;
|
|
24
|
+
protected static linkingFields<T extends BoundWitness>(accounts: AccountInstance[], payloads?: Payload[]): Promise<Pick<T, GeneratedBoundWitnessFields>>;
|
|
53
25
|
protected static signature<T extends BoundWitness>(payload: T, address: Address): Lowercase<string>;
|
|
54
|
-
protected static signatures(accounts: AccountInstance[],
|
|
55
|
-
private static
|
|
56
|
-
build(): Promise<[
|
|
57
|
-
|
|
26
|
+
protected static signatures(accounts: AccountInstance[], dataHash: Hash): Promise<string[]>;
|
|
27
|
+
private static validateGeneratedFields;
|
|
28
|
+
build(): Promise<[Signed<TBoundWitness>, TPayload[], ModuleError[]]>;
|
|
29
|
+
dataHash(): Promise<Lowercase<string>>;
|
|
30
|
+
dataHashableFields(): Promise<import("@xylabs/object").DeepOmitStartsWith<import("@xylabs/object").DeepOmitStartsWith<TBoundWitness, "_">, "$">>;
|
|
58
31
|
error(payload?: ModuleError): this;
|
|
59
32
|
errors(errors?: (ModuleError | null)[]): this;
|
|
33
|
+
fields(fields: WithoutMeta<WithoutSchema<Omit<TBoundWitness, GeneratedBoundWitnessFields>>>): this;
|
|
60
34
|
hashes(hashes: Hash[], schema: Schema[]): this;
|
|
61
35
|
payload(payload?: TPayload): this;
|
|
62
36
|
payloads(payloads?: (TPayload | null)[]): this;
|
|
63
37
|
signer(account: AccountInstance): this;
|
|
64
38
|
signers(accounts: AccountInstance[]): this;
|
|
65
|
-
sourceQuery(
|
|
39
|
+
sourceQuery(sourceQuery: Hash): this;
|
|
66
40
|
/** @deprecated use signer instead */
|
|
67
41
|
witness(account: AccountInstance): this;
|
|
68
42
|
/** @deprecated use signers instead */
|
|
69
43
|
witnesses(accounts: AccountInstance[]): this;
|
|
70
|
-
protected
|
|
71
|
-
|
|
72
|
-
private linkingFields;
|
|
44
|
+
protected sign(): Promise<string[]>;
|
|
45
|
+
private generatedFields;
|
|
73
46
|
private missingSchemaMessage;
|
|
74
47
|
}
|
|
75
48
|
//# sourceMappingURL=Builder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAEhD,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"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"}
|