@xyo-network/payload-builder 2.110.10 → 2.110.12
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/index.cjs +64 -80
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +64 -82
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/index.cjs +64 -80
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.js +64 -82
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/index.cjs +66 -80
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +66 -82
- package/dist/node/index.js.map +1 -1
- package/package.json +11 -11
package/dist/neutral/index.js
CHANGED
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
-
|
|
4
1
|
// src/Builder.ts
|
|
5
2
|
import { assertEx as assertEx2 } from "@xylabs/assert";
|
|
6
3
|
import { omitBy as omitBy2 } from "@xylabs/lodash";
|
|
@@ -12,25 +9,18 @@ import { assertEx } from "@xylabs/assert";
|
|
|
12
9
|
import { omitBy } from "@xylabs/lodash";
|
|
13
10
|
import { isJsonObject, toJson } from "@xylabs/object";
|
|
14
11
|
import { removeEmptyFields } from "@xyo-network/hash";
|
|
15
|
-
var removeMetaAndSchema =
|
|
12
|
+
var removeMetaAndSchema = (payload) => {
|
|
16
13
|
const { ...result } = payload;
|
|
17
14
|
delete result.$hash;
|
|
18
15
|
delete result.$meta;
|
|
19
16
|
delete result.schema;
|
|
20
17
|
return result;
|
|
21
|
-
}
|
|
22
|
-
var omitByPredicate =
|
|
18
|
+
};
|
|
19
|
+
var omitByPredicate = (prefix) => (_, key) => {
|
|
23
20
|
assertEx(typeof key === "string", () => `Invalid key type [${key}, ${typeof key}]`);
|
|
24
21
|
return key.startsWith(prefix);
|
|
25
|
-
}
|
|
22
|
+
};
|
|
26
23
|
var PayloadBuilderBase = class _PayloadBuilderBase {
|
|
27
|
-
static {
|
|
28
|
-
__name(this, "PayloadBuilderBase");
|
|
29
|
-
}
|
|
30
|
-
options;
|
|
31
|
-
_$meta;
|
|
32
|
-
_fields;
|
|
33
|
-
_schema;
|
|
34
24
|
constructor(options) {
|
|
35
25
|
this.options = options;
|
|
36
26
|
const { schema, fields, meta } = options;
|
|
@@ -38,18 +28,19 @@ var PayloadBuilderBase = class _PayloadBuilderBase {
|
|
|
38
28
|
this._fields = removeEmptyFields(fields ?? {});
|
|
39
29
|
this._$meta = meta;
|
|
40
30
|
}
|
|
31
|
+
_$meta;
|
|
32
|
+
_fields;
|
|
33
|
+
_schema;
|
|
41
34
|
static dataHashableFields(schema, fields) {
|
|
42
35
|
const cleanFields = fields ? removeEmptyFields(fields) : void 0;
|
|
43
|
-
assertEx(
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}, omitByPredicate("$")), omitByPredicate("_"));
|
|
36
|
+
assertEx(
|
|
37
|
+
cleanFields === void 0 || isJsonObject(cleanFields),
|
|
38
|
+
() => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`
|
|
39
|
+
);
|
|
40
|
+
return omitBy(omitBy({ schema, ...cleanFields }, omitByPredicate("$")), omitByPredicate("_"));
|
|
48
41
|
}
|
|
49
42
|
static metaFields(dataHash, otherMeta, stamp = true) {
|
|
50
|
-
const meta = {
|
|
51
|
-
...otherMeta
|
|
52
|
-
};
|
|
43
|
+
const meta = { ...otherMeta };
|
|
53
44
|
if (!meta.timestamp && stamp) {
|
|
54
45
|
meta.timestamp = meta.timestamp ?? Date.now();
|
|
55
46
|
}
|
|
@@ -60,7 +51,10 @@ var PayloadBuilderBase = class _PayloadBuilderBase {
|
|
|
60
51
|
return this;
|
|
61
52
|
}
|
|
62
53
|
async dataHashableFields() {
|
|
63
|
-
return await _PayloadBuilderBase.dataHashableFields(
|
|
54
|
+
return await _PayloadBuilderBase.dataHashableFields(
|
|
55
|
+
assertEx(this._schema, () => "Payload: Missing Schema"),
|
|
56
|
+
this._fields
|
|
57
|
+
);
|
|
64
58
|
}
|
|
65
59
|
//we do not require sending in $hash since it will be generated anyway
|
|
66
60
|
fields(fields) {
|
|
@@ -85,14 +79,11 @@ var PayloadBuilderBase = class _PayloadBuilderBase {
|
|
|
85
79
|
};
|
|
86
80
|
|
|
87
81
|
// src/Builder.ts
|
|
88
|
-
var omitByPredicate2 =
|
|
82
|
+
var omitByPredicate2 = (prefix) => (_, key) => {
|
|
89
83
|
assertEx2(typeof key === "string", () => `Invalid key type [${key}, ${typeof key}]`);
|
|
90
84
|
return key.startsWith(prefix);
|
|
91
|
-
}
|
|
85
|
+
};
|
|
92
86
|
var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
93
|
-
static {
|
|
94
|
-
__name(this, "PayloadBuilder");
|
|
95
|
-
}
|
|
96
87
|
static async build(payload, options = {}) {
|
|
97
88
|
if (Array.isArray(payload)) {
|
|
98
89
|
return await Promise.all(payload.map((payload2) => this.build(payload2, options)));
|
|
@@ -106,17 +97,11 @@ var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
106
97
|
const fields = removeMetaAndSchema(payload);
|
|
107
98
|
const dataHashableFields = await _PayloadBuilder.dataHashableFields(schema, fields);
|
|
108
99
|
const $hash = validate || incomingDataHash === void 0 ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash;
|
|
109
|
-
const $meta = {
|
|
110
|
-
...incomingMeta
|
|
111
|
-
};
|
|
100
|
+
const $meta = { ...incomingMeta };
|
|
112
101
|
if ($meta.timestamp === void 0 && stamp) {
|
|
113
102
|
$meta.timestamp = Date.now();
|
|
114
103
|
}
|
|
115
|
-
const hashableFields = {
|
|
116
|
-
...dataHashableFields,
|
|
117
|
-
$hash,
|
|
118
|
-
schema
|
|
119
|
-
};
|
|
104
|
+
const hashableFields = { ...dataHashableFields, $hash, schema };
|
|
120
105
|
if (Object.keys($meta).length > 0) {
|
|
121
106
|
hashableFields.$meta = $meta;
|
|
122
107
|
}
|
|
@@ -127,33 +112,30 @@ var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
127
112
|
return (await this.build(payload, options)).$hash;
|
|
128
113
|
}
|
|
129
114
|
static async dataHashPairs(payloads, options) {
|
|
130
|
-
return await Promise.all(
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
built,
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
}));
|
|
115
|
+
return await Promise.all(
|
|
116
|
+
payloads.map(async (payload) => {
|
|
117
|
+
const built = await _PayloadBuilder.build(payload, options);
|
|
118
|
+
return [built, built.$hash];
|
|
119
|
+
})
|
|
120
|
+
);
|
|
137
121
|
}
|
|
138
122
|
static async dataHashes(payloads, options) {
|
|
139
|
-
return payloads ? await Promise.all(
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
123
|
+
return payloads ? await Promise.all(
|
|
124
|
+
payloads.map(async (payload) => {
|
|
125
|
+
const built = await _PayloadBuilder.build(payload, options);
|
|
126
|
+
return built.$hash;
|
|
127
|
+
})
|
|
128
|
+
) : void 0;
|
|
143
129
|
}
|
|
144
130
|
static async filterExclude(payloads = [], hash) {
|
|
145
131
|
return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash);
|
|
146
132
|
}
|
|
147
133
|
static async filterExcludeByDataHash(payloads = [], hash) {
|
|
148
|
-
const hashes = Array.isArray(hash) ? hash : [
|
|
149
|
-
hash
|
|
150
|
-
];
|
|
134
|
+
const hashes = Array.isArray(hash) ? hash : [hash];
|
|
151
135
|
return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0]);
|
|
152
136
|
}
|
|
153
137
|
static async filterIncludeByDataHash(payloads = [], hash) {
|
|
154
|
-
const hashes = Array.isArray(hash) ? hash : [
|
|
155
|
-
hash
|
|
156
|
-
];
|
|
138
|
+
const hashes = Array.isArray(hash) ? hash : [hash];
|
|
157
139
|
return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0]);
|
|
158
140
|
}
|
|
159
141
|
static async findByDataHash(payloads = [], hash) {
|
|
@@ -163,30 +145,30 @@ var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
163
145
|
return await PayloadHasher.hash(await _PayloadBuilder.build(payload, options));
|
|
164
146
|
}
|
|
165
147
|
/**
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
148
|
+
* Creates an array of payload/hash tuples based on the payloads passed in
|
|
149
|
+
* @param objs Any array of payloads
|
|
150
|
+
* @returns An array of payload/hash tuples
|
|
151
|
+
*/
|
|
170
152
|
static async hashPairs(payloads, options) {
|
|
171
|
-
return await Promise.all(
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
built,
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
}));
|
|
153
|
+
return await Promise.all(
|
|
154
|
+
payloads.map(async (payload) => {
|
|
155
|
+
const built = await _PayloadBuilder.build(payload, options);
|
|
156
|
+
return [built, await _PayloadBuilder.hash(built)];
|
|
157
|
+
})
|
|
158
|
+
);
|
|
178
159
|
}
|
|
179
160
|
static async hashableFields(schema, fields, $meta, $hash, timestamp, stamp = false) {
|
|
180
161
|
const dataFields = await this.dataHashableFields(schema, fields);
|
|
181
162
|
assertEx2($meta === void 0 || isJsonObject2($meta), () => "$meta must be JsonObject");
|
|
182
|
-
const result = omitBy2(
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
163
|
+
const result = omitBy2(
|
|
164
|
+
{
|
|
165
|
+
...dataFields,
|
|
166
|
+
$hash: $hash ?? await _PayloadBuilder.dataHash(dataFields),
|
|
167
|
+
schema
|
|
168
|
+
},
|
|
169
|
+
omitByPredicate2("_")
|
|
170
|
+
);
|
|
171
|
+
const clonedMeta = { ...$meta };
|
|
190
172
|
if (timestamp) {
|
|
191
173
|
clonedMeta.timestamp = timestamp;
|
|
192
174
|
}
|
|
@@ -217,10 +199,10 @@ var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
217
199
|
return result;
|
|
218
200
|
}
|
|
219
201
|
/**
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
202
|
+
* Creates an object map of payload hashes to payloads based on the payloads passed in
|
|
203
|
+
* @param objs Any array of payloads
|
|
204
|
+
* @returns A map of hashes to payloads
|
|
205
|
+
*/
|
|
224
206
|
static async toHashMap(objs) {
|
|
225
207
|
const result = {};
|
|
226
208
|
for (const pair of await this.hashPairs(objs)) {
|
|
@@ -240,14 +222,14 @@ var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
240
222
|
}
|
|
241
223
|
async build(options) {
|
|
242
224
|
const dataHashableFields = await this.dataHashableFields();
|
|
243
|
-
return await _PayloadBuilder.build({
|
|
244
|
-
...dataHashableFields,
|
|
245
|
-
$meta: this._$meta,
|
|
246
|
-
schema: this._schema
|
|
247
|
-
}, options);
|
|
225
|
+
return await _PayloadBuilder.build({ ...dataHashableFields, $meta: this._$meta, schema: this._schema }, options);
|
|
248
226
|
}
|
|
249
227
|
async hashableFields() {
|
|
250
|
-
return await _PayloadBuilder.hashableFields(
|
|
228
|
+
return await _PayloadBuilder.hashableFields(
|
|
229
|
+
assertEx2(this._schema, () => "Payload: Missing Schema"),
|
|
230
|
+
this._fields,
|
|
231
|
+
this._$meta
|
|
232
|
+
);
|
|
251
233
|
}
|
|
252
234
|
};
|
|
253
235
|
export {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { omitBy } from '@xylabs/lodash'\nimport { AnyObject, isJsonObject, JsonArray, JsonObject } from '@xylabs/object'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderBase, removeMetaAndSchema, WithoutMeta, WithoutSchema } from './BuilderBase.js'\nimport { PayloadBuilderOptions } from './Options.js'\n\nexport interface BuildOptions {\n stamp?: boolean\n validate?: boolean\n}\n\nconst omitByPredicate = (prefix: string) => (_: unknown, key: string) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n}\n\nexport class PayloadBuilder<\n T extends Payload = Payload<AnyObject>,\n O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>,\n> extends PayloadBuilderBase<T, O> {\n static async build<T extends Payload = Payload<AnyObject>>(payload: T, options?: BuildOptions): Promise<WithMeta<T>>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T[], options?: BuildOptions): Promise<WithMeta<T>[]>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T | T[], options: BuildOptions = {}) {\n if (Array.isArray(payload)) {\n return await Promise.all(payload.map((payload) => this.build(payload, options)))\n } else {\n const { stamp = false, validate = true } = options\n const { schema, $hash: incomingDataHash, $meta: incomingMeta = {} } = payload as WithMeta<T>\n\n //check for legacy signatures\n const { _signatures } = payload as { _signatures?: JsonArray }\n if (_signatures && !incomingMeta.signatures) {\n incomingMeta.signatures = _signatures\n }\n\n const fields = removeMetaAndSchema(payload)\n const dataHashableFields = await PayloadBuilder.dataHashableFields(schema, fields)\n const $hash = validate || incomingDataHash === undefined ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash\n const $meta: JsonObject = { ...incomingMeta }\n if ($meta.timestamp === undefined && stamp) {\n $meta.timestamp = Date.now()\n }\n const hashableFields: WithMeta<Payload> = { ...dataHashableFields, $hash, schema }\n\n if (Object.keys($meta).length > 0) {\n hashableFields.$meta = $meta\n }\n\n return hashableFields as WithMeta<T>\n }\n }\n\n static async dataHash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return (await this.build(payload, options)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined, options?: BuildOptions): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[], options?: BuildOptions): Promise<Hash[] | undefined> {\n return payloads ?\n await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return built.$hash\n }),\n )\n : undefined\n }\n\n static async filterExclude<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash)\n }\n\n static async filterExcludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n static async hash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return await PayloadHasher.hash(await PayloadBuilder.build(payload, options))\n }\n\n /**\n * Creates an array of payload/hash tuples based on the payloads passed in\n * @param objs Any array of payloads\n * @returns An array of payload/hash tuples\n */\n static async hashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map<Promise<[WithMeta<T>, Hash]>>(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\n }\n\n static async hashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n $meta?: JsonObject,\n $hash?: Hash,\n timestamp?: number,\n stamp = false,\n ): Promise<WithMeta<T>> {\n const dataFields = await this.dataHashableFields<T>(schema, fields)\n assertEx($meta === undefined || isJsonObject($meta), () => '$meta must be JsonObject')\n const result: WithMeta<T> = omitBy(\n {\n ...dataFields,\n $hash: $hash ?? (await PayloadBuilder.dataHash(dataFields)),\n schema,\n } as WithMeta<T>,\n omitByPredicate('_'),\n ) as WithMeta<T>\n\n const clonedMeta = { ...$meta }\n\n if (timestamp) {\n clonedMeta.timestamp = timestamp\n }\n\n if (clonedMeta.timestamp === undefined && stamp) {\n clonedMeta.timestamp = Date.now()\n }\n\n if (Object.keys(clonedMeta).length > 0) {\n result.$meta = clonedMeta\n }\n\n return result\n }\n\n static async hashes(payloads: undefined): Promise<undefined>\n static async hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async hashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return await PayloadHasher.hashes(payloads)\n }\n\n static async toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n result[pair[0].$hash] = pair[0]\n }\n return result\n }\n\n static async toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.dataHashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n /**\n * Creates an object map of payload hashes to payloads based on the payloads passed in\n * @param objs Any array of payloads\n * @returns A map of hashes to payloads\n */\n static async toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n static withoutMeta(payload: undefined): undefined\n static withoutMeta<T extends PayloadWithMeta>(payload: T): Omit<T, '$meta'>\n static withoutMeta<T extends PayloadWithMeta>(payloads: T[]): Omit<T, '$meta'>[]\n static withoutMeta<T extends PayloadWithMeta>(payloads: T | T[]) {\n if (Array.isArray(payloads)) {\n return payloads.map((payload) => this.withoutMeta(payload))\n } else {\n if (payloads) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, ...result } = payloads\n return result as Omit<T, '$meta'>\n }\n }\n }\n\n async build(options?: BuildOptions): Promise<WithMeta<T>> {\n const dataHashableFields = await this.dataHashableFields()\n return await PayloadBuilder.build<T>({ ...dataHashableFields, $meta: this._$meta, schema: this._schema } as Payload as T, options)\n }\n\n async hashableFields() {\n return await PayloadBuilder.hashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n this._$meta,\n )\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { omitBy } from '@xylabs/lodash'\nimport { AnyObject, isJsonObject, JsonObject, toJson } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, Schema, WithMeta, WithOptionalMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderOptions } from './Options.js'\n\nexport type WithOptionalSchema<T extends Payload> = Omit<T, 'schema'> & Partial<T>\n\nexport type WithoutSchema<T extends WithOptionalSchema<Payload>> = Omit<T, 'schema'>\n\nexport type WithoutMeta<T extends WithOptionalMeta<Payload>> = Omit<T, '$hash' | '$meta'>\n\nexport const removeMetaAndSchema = <T extends Payload>(payload: WithOptionalSchema<WithOptionalMeta<T>>): WithoutSchema<WithoutMeta<T>> => {\n const { ...result } = payload\n delete result.$hash\n delete result.$meta\n delete result.schema\n return result as Omit<T, 'schema'>\n}\n\nconst omitByPredicate = (prefix: string) => (_: unknown, key: string) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n}\n\nexport class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {\n protected _$meta?: JsonObject\n protected _fields?: WithoutSchema<WithoutMeta<T>>\n protected _schema: Schema\n\n constructor(readonly options: O) {\n const { schema, fields, meta } = options\n this._schema = schema\n this._fields = removeEmptyFields(fields ?? {}) as WithoutSchema<WithoutMeta<T>>\n this._$meta = meta\n }\n\n static dataHashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n ): Promisable<Omit<T, '$hash' | '$meta'>> {\n const cleanFields = fields ? removeEmptyFields(fields) : undefined\n assertEx(\n cleanFields === undefined || isJsonObject(cleanFields),\n () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`,\n )\n return omitBy(omitBy({ schema, ...cleanFields }, omitByPredicate('$')), omitByPredicate('_')) as unknown as T\n }\n\n protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp = true): Promisable<JsonObject> {\n const meta: JsonObject = { ...otherMeta }\n\n if (!meta.timestamp && stamp) {\n meta.timestamp = meta.timestamp ?? Date.now()\n }\n\n return meta\n }\n\n $meta(meta?: JsonObject) {\n this._$meta = meta ?? (this._fields as WithMeta<T>).$meta\n return this\n }\n\n async dataHashableFields() {\n return await PayloadBuilderBase.dataHashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n )\n }\n\n //we do not require sending in $hash since it will be generated anyway\n fields(fields: WithOptionalSchema<WithOptionalMeta<T>>) {\n if (fields) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, $hash, schema, ...fieldsOnly } = fields\n if ($meta) {\n this.$meta($meta)\n }\n if (schema) {\n this.schema(schema)\n }\n this._fields = removeMetaAndSchema<T>(fields)\n }\n return this\n }\n\n schema(value: Schema) {\n this._schema = value\n }\n\n protected async metaFields(dataHash: Hash, stamp = true): Promise<JsonObject> {\n return await PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp)\n }\n}\n"],"mappings":"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","names":["assertEx","omitBy","isJsonObject","PayloadHasher","assertEx","omitBy","isJsonObject","toJson","removeEmptyFields","removeMetaAndSchema","payload","result","$hash","$meta","schema","omitByPredicate","prefix","_","key","assertEx","startsWith","PayloadBuilderBase","_$meta","_fields","_schema","constructor","options","fields","meta","removeEmptyFields","dataHashableFields","cleanFields","undefined","isJsonObject","JSON","stringify","toJson","omitBy","metaFields","dataHash","otherMeta","stamp","timestamp","Date","now","fieldsOnly","value","omitByPredicate","prefix","_","key","assertEx","startsWith","PayloadBuilder","PayloadBuilderBase","build","payload","options","Array","isArray","Promise","all","map","stamp","validate","schema","$hash","incomingDataHash","$meta","incomingMeta","_signatures","signatures","fields","removeMetaAndSchema","dataHashableFields","undefined","PayloadHasher","hash","timestamp","Date","now","hashableFields","Object","keys","length","dataHash","dataHashPairs","payloads","built","dataHashes","filterExclude","filterExcludeByHash","filterExcludeByDataHash","hashes","filter","objHash","includes","pair","filterIncludeByDataHash","findByDataHash","find","hashPairs","dataFields","isJsonObject","result","omitBy","clonedMeta","toAllHashMap","objs","toDataHashMap","toHashMap","withoutMeta","_$meta","_schema","_fields"]}
|
|
1
|
+
{"version":3,"sources":["../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { omitBy } from '@xylabs/lodash'\nimport { AnyObject, isJsonObject, JsonArray, JsonObject } from '@xylabs/object'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderBase, removeMetaAndSchema, WithoutMeta, WithoutSchema } from './BuilderBase.js'\nimport { PayloadBuilderOptions } from './Options.js'\n\nexport interface BuildOptions {\n stamp?: boolean\n validate?: boolean\n}\n\nconst omitByPredicate = (prefix: string) => (_: unknown, key: string) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n}\n\nexport class PayloadBuilder<\n T extends Payload = Payload<AnyObject>,\n O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>,\n> extends PayloadBuilderBase<T, O> {\n static async build<T extends Payload = Payload<AnyObject>>(payload: T, options?: BuildOptions): Promise<WithMeta<T>>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T[], options?: BuildOptions): Promise<WithMeta<T>[]>\n static async build<T extends Payload = Payload<AnyObject>>(payload: T | T[], options: BuildOptions = {}) {\n if (Array.isArray(payload)) {\n return await Promise.all(payload.map((payload) => this.build(payload, options)))\n } else {\n const { stamp = false, validate = true } = options\n const { schema, $hash: incomingDataHash, $meta: incomingMeta = {} } = payload as WithMeta<T>\n\n //check for legacy signatures\n const { _signatures } = payload as { _signatures?: JsonArray }\n if (_signatures && !incomingMeta.signatures) {\n incomingMeta.signatures = _signatures\n }\n\n const fields = removeMetaAndSchema(payload)\n const dataHashableFields = await PayloadBuilder.dataHashableFields(schema, fields)\n const $hash = validate || incomingDataHash === undefined ? await PayloadHasher.hash(dataHashableFields) : incomingDataHash\n const $meta: JsonObject = { ...incomingMeta }\n if ($meta.timestamp === undefined && stamp) {\n $meta.timestamp = Date.now()\n }\n const hashableFields: WithMeta<Payload> = { ...dataHashableFields, $hash, schema }\n\n if (Object.keys($meta).length > 0) {\n hashableFields.$meta = $meta\n }\n\n return hashableFields as WithMeta<T>\n }\n }\n\n static async dataHash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return (await this.build(payload, options)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined, options?: BuildOptions): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[], options?: BuildOptions): Promise<Hash[] | undefined> {\n return payloads ?\n await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return built.$hash\n }),\n )\n : undefined\n }\n\n static async filterExclude<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n return await PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash)\n }\n\n static async filterExcludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async filterIncludeByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash[] | Hash): Promise<T[]> {\n const hashes = Array.isArray(hash) ? hash : [hash]\n return (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))?.map((pair) => pair[0])\n }\n\n static async findByDataHash<T extends Payload>(payloads: T[] = [], hash: Hash): Promise<T | undefined> {\n return (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)?.[0]\n }\n\n static async hash<T extends Payload>(payload: T, options?: BuildOptions): Promise<Hash> {\n return await PayloadHasher.hash(await PayloadBuilder.build(payload, options))\n }\n\n /**\n * Creates an array of payload/hash tuples based on the payloads passed in\n * @param objs Any array of payloads\n * @returns An array of payload/hash tuples\n */\n static async hashPairs<T extends Payload>(payloads: T[], options?: BuildOptions): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map<Promise<[WithMeta<T>, Hash]>>(async (payload) => {\n const built = await PayloadBuilder.build(payload, options)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\n }\n\n static async hashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n $meta?: JsonObject,\n $hash?: Hash,\n timestamp?: number,\n stamp = false,\n ): Promise<WithMeta<T>> {\n const dataFields = await this.dataHashableFields<T>(schema, fields)\n assertEx($meta === undefined || isJsonObject($meta), () => '$meta must be JsonObject')\n const result: WithMeta<T> = omitBy(\n {\n ...dataFields,\n $hash: $hash ?? (await PayloadBuilder.dataHash(dataFields)),\n schema,\n } as WithMeta<T>,\n omitByPredicate('_'),\n ) as WithMeta<T>\n\n const clonedMeta = { ...$meta }\n\n if (timestamp) {\n clonedMeta.timestamp = timestamp\n }\n\n if (clonedMeta.timestamp === undefined && stamp) {\n clonedMeta.timestamp = Date.now()\n }\n\n if (Object.keys(clonedMeta).length > 0) {\n result.$meta = clonedMeta\n }\n\n return result\n }\n\n static async hashes(payloads: undefined): Promise<undefined>\n static async hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async hashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return await PayloadHasher.hashes(payloads)\n }\n\n static async toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n result[pair[0].$hash] = pair[0]\n }\n return result\n }\n\n static async toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.dataHashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n /**\n * Creates an object map of payload hashes to payloads based on the payloads passed in\n * @param objs Any array of payloads\n * @returns A map of hashes to payloads\n */\n static async toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, WithMeta<T>>> {\n const result: Record<Hash, WithMeta<T>> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n static withoutMeta(payload: undefined): undefined\n static withoutMeta<T extends PayloadWithMeta>(payload: T): Omit<T, '$meta'>\n static withoutMeta<T extends PayloadWithMeta>(payloads: T[]): Omit<T, '$meta'>[]\n static withoutMeta<T extends PayloadWithMeta>(payloads: T | T[]) {\n if (Array.isArray(payloads)) {\n return payloads.map((payload) => this.withoutMeta(payload))\n } else {\n if (payloads) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, ...result } = payloads\n return result as Omit<T, '$meta'>\n }\n }\n }\n\n async build(options?: BuildOptions): Promise<WithMeta<T>> {\n const dataHashableFields = await this.dataHashableFields()\n return await PayloadBuilder.build<T>({ ...dataHashableFields, $meta: this._$meta, schema: this._schema } as Payload as T, options)\n }\n\n async hashableFields() {\n return await PayloadBuilder.hashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n this._$meta,\n )\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { omitBy } from '@xylabs/lodash'\nimport { AnyObject, isJsonObject, JsonObject, toJson } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, Schema, WithMeta, WithOptionalMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderOptions } from './Options.js'\n\nexport type WithOptionalSchema<T extends Payload> = Omit<T, 'schema'> & Partial<T>\n\nexport type WithoutSchema<T extends WithOptionalSchema<Payload>> = Omit<T, 'schema'>\n\nexport type WithoutMeta<T extends WithOptionalMeta<Payload>> = Omit<T, '$hash' | '$meta'>\n\nexport const removeMetaAndSchema = <T extends Payload>(payload: WithOptionalSchema<WithOptionalMeta<T>>): WithoutSchema<WithoutMeta<T>> => {\n const { ...result } = payload\n delete result.$hash\n delete result.$meta\n delete result.schema\n return result as Omit<T, 'schema'>\n}\n\nconst omitByPredicate = (prefix: string) => (_: unknown, key: string) => {\n assertEx(typeof key === 'string', () => `Invalid key type [${key}, ${typeof key}]`)\n return key.startsWith(prefix)\n}\n\nexport class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {\n protected _$meta?: JsonObject\n protected _fields?: WithoutSchema<WithoutMeta<T>>\n protected _schema: Schema\n\n constructor(readonly options: O) {\n const { schema, fields, meta } = options\n this._schema = schema\n this._fields = removeEmptyFields(fields ?? {}) as WithoutSchema<WithoutMeta<T>>\n this._$meta = meta\n }\n\n static dataHashableFields<T extends Payload = Payload<AnyObject>>(\n schema: string,\n fields?: WithoutSchema<WithoutMeta<T>>,\n ): Promisable<Omit<T, '$hash' | '$meta'>> {\n const cleanFields = fields ? removeEmptyFields(fields) : undefined\n assertEx(\n cleanFields === undefined || isJsonObject(cleanFields),\n () => `Fields must be JsonObject: ${JSON.stringify(toJson(cleanFields), null, 2)}`,\n )\n return omitBy(omitBy({ schema, ...cleanFields }, omitByPredicate('$')), omitByPredicate('_')) as unknown as T\n }\n\n protected static metaFields(dataHash: Hash, otherMeta?: JsonObject, stamp = true): Promisable<JsonObject> {\n const meta: JsonObject = { ...otherMeta }\n\n if (!meta.timestamp && stamp) {\n meta.timestamp = meta.timestamp ?? Date.now()\n }\n\n return meta\n }\n\n $meta(meta?: JsonObject) {\n this._$meta = meta ?? (this._fields as WithMeta<T>).$meta\n return this\n }\n\n async dataHashableFields() {\n return await PayloadBuilderBase.dataHashableFields(\n assertEx(this._schema, () => 'Payload: Missing Schema'),\n this._fields,\n )\n }\n\n //we do not require sending in $hash since it will be generated anyway\n fields(fields: WithOptionalSchema<WithOptionalMeta<T>>) {\n if (fields) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, $hash, schema, ...fieldsOnly } = fields\n if ($meta) {\n this.$meta($meta)\n }\n if (schema) {\n this.schema(schema)\n }\n this._fields = removeMetaAndSchema<T>(fields)\n }\n return this\n }\n\n schema(value: Schema) {\n this._schema = value\n }\n\n protected async metaFields(dataHash: Hash, stamp = true): Promise<JsonObject> {\n return await PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp)\n }\n}\n"],"mappings":"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","names":["assertEx","omitBy","isJsonObject","omitByPredicate","assertEx","payload","isJsonObject","omitBy"]}
|
package/dist/node/index.cjs
CHANGED
|
@@ -3,7 +3,6 @@ var __defProp = Object.defineProperty;
|
|
|
3
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
5
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
6
|
var __export = (target, all) => {
|
|
8
7
|
for (var name in all)
|
|
9
8
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
@@ -38,22 +37,18 @@ var import_assert = require("@xylabs/assert");
|
|
|
38
37
|
var import_lodash = require("@xylabs/lodash");
|
|
39
38
|
var import_object = require("@xylabs/object");
|
|
40
39
|
var import_hash = require("@xyo-network/hash");
|
|
41
|
-
var removeMetaAndSchema =
|
|
40
|
+
var removeMetaAndSchema = (payload) => {
|
|
42
41
|
const { ...result } = payload;
|
|
43
42
|
delete result.$hash;
|
|
44
43
|
delete result.$meta;
|
|
45
44
|
delete result.schema;
|
|
46
45
|
return result;
|
|
47
|
-
}
|
|
48
|
-
var omitByPredicate =
|
|
46
|
+
};
|
|
47
|
+
var omitByPredicate = (prefix) => (_, key) => {
|
|
49
48
|
(0, import_assert.assertEx)(typeof key === "string", () => `Invalid key type [${key}, ${typeof key}]`);
|
|
50
49
|
return key.startsWith(prefix);
|
|
51
|
-
}
|
|
52
|
-
var
|
|
53
|
-
options;
|
|
54
|
-
_$meta;
|
|
55
|
-
_fields;
|
|
56
|
-
_schema;
|
|
50
|
+
};
|
|
51
|
+
var PayloadBuilderBase = class _PayloadBuilderBase {
|
|
57
52
|
constructor(options) {
|
|
58
53
|
this.options = options;
|
|
59
54
|
const { schema, fields, meta } = options;
|
|
@@ -61,18 +56,19 @@ var _PayloadBuilderBase = class _PayloadBuilderBase {
|
|
|
61
56
|
this._fields = (0, import_hash.removeEmptyFields)(fields ?? {});
|
|
62
57
|
this._$meta = meta;
|
|
63
58
|
}
|
|
59
|
+
_$meta;
|
|
60
|
+
_fields;
|
|
61
|
+
_schema;
|
|
64
62
|
static dataHashableFields(schema, fields) {
|
|
65
63
|
const cleanFields = fields ? (0, import_hash.removeEmptyFields)(fields) : void 0;
|
|
66
|
-
(0, import_assert.assertEx)(
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
}, omitByPredicate("$")), omitByPredicate("_"));
|
|
64
|
+
(0, import_assert.assertEx)(
|
|
65
|
+
cleanFields === void 0 || (0, import_object.isJsonObject)(cleanFields),
|
|
66
|
+
() => `Fields must be JsonObject: ${JSON.stringify((0, import_object.toJson)(cleanFields), null, 2)}`
|
|
67
|
+
);
|
|
68
|
+
return (0, import_lodash.omitBy)((0, import_lodash.omitBy)({ schema, ...cleanFields }, omitByPredicate("$")), omitByPredicate("_"));
|
|
71
69
|
}
|
|
72
70
|
static metaFields(dataHash, otherMeta, stamp = true) {
|
|
73
|
-
const meta = {
|
|
74
|
-
...otherMeta
|
|
75
|
-
};
|
|
71
|
+
const meta = { ...otherMeta };
|
|
76
72
|
if (!meta.timestamp && stamp) {
|
|
77
73
|
meta.timestamp = meta.timestamp ?? Date.now();
|
|
78
74
|
}
|
|
@@ -83,7 +79,10 @@ var _PayloadBuilderBase = class _PayloadBuilderBase {
|
|
|
83
79
|
return this;
|
|
84
80
|
}
|
|
85
81
|
async dataHashableFields() {
|
|
86
|
-
return await _PayloadBuilderBase.dataHashableFields(
|
|
82
|
+
return await _PayloadBuilderBase.dataHashableFields(
|
|
83
|
+
(0, import_assert.assertEx)(this._schema, () => "Payload: Missing Schema"),
|
|
84
|
+
this._fields
|
|
85
|
+
);
|
|
87
86
|
}
|
|
88
87
|
//we do not require sending in $hash since it will be generated anyway
|
|
89
88
|
fields(fields) {
|
|
@@ -106,15 +105,13 @@ var _PayloadBuilderBase = class _PayloadBuilderBase {
|
|
|
106
105
|
return await _PayloadBuilderBase.metaFields(dataHash, this._$meta, stamp);
|
|
107
106
|
}
|
|
108
107
|
};
|
|
109
|
-
__name(_PayloadBuilderBase, "PayloadBuilderBase");
|
|
110
|
-
var PayloadBuilderBase = _PayloadBuilderBase;
|
|
111
108
|
|
|
112
109
|
// src/Builder.ts
|
|
113
|
-
var omitByPredicate2 =
|
|
110
|
+
var omitByPredicate2 = (prefix) => (_, key) => {
|
|
114
111
|
(0, import_assert2.assertEx)(typeof key === "string", () => `Invalid key type [${key}, ${typeof key}]`);
|
|
115
112
|
return key.startsWith(prefix);
|
|
116
|
-
}
|
|
117
|
-
var
|
|
113
|
+
};
|
|
114
|
+
var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
118
115
|
static async build(payload, options = {}) {
|
|
119
116
|
if (Array.isArray(payload)) {
|
|
120
117
|
return await Promise.all(payload.map((payload2) => this.build(payload2, options)));
|
|
@@ -128,17 +125,11 @@ var _PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
128
125
|
const fields = removeMetaAndSchema(payload);
|
|
129
126
|
const dataHashableFields = await _PayloadBuilder.dataHashableFields(schema, fields);
|
|
130
127
|
const $hash = validate || incomingDataHash === void 0 ? await import_hash2.PayloadHasher.hash(dataHashableFields) : incomingDataHash;
|
|
131
|
-
const $meta = {
|
|
132
|
-
...incomingMeta
|
|
133
|
-
};
|
|
128
|
+
const $meta = { ...incomingMeta };
|
|
134
129
|
if ($meta.timestamp === void 0 && stamp) {
|
|
135
130
|
$meta.timestamp = Date.now();
|
|
136
131
|
}
|
|
137
|
-
const hashableFields = {
|
|
138
|
-
...dataHashableFields,
|
|
139
|
-
$hash,
|
|
140
|
-
schema
|
|
141
|
-
};
|
|
132
|
+
const hashableFields = { ...dataHashableFields, $hash, schema };
|
|
142
133
|
if (Object.keys($meta).length > 0) {
|
|
143
134
|
hashableFields.$meta = $meta;
|
|
144
135
|
}
|
|
@@ -149,35 +140,32 @@ var _PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
149
140
|
return (await this.build(payload, options)).$hash;
|
|
150
141
|
}
|
|
151
142
|
static async dataHashPairs(payloads, options) {
|
|
152
|
-
return await Promise.all(
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
built,
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
}));
|
|
143
|
+
return await Promise.all(
|
|
144
|
+
payloads.map(async (payload) => {
|
|
145
|
+
const built = await _PayloadBuilder.build(payload, options);
|
|
146
|
+
return [built, built.$hash];
|
|
147
|
+
})
|
|
148
|
+
);
|
|
159
149
|
}
|
|
160
150
|
static async dataHashes(payloads, options) {
|
|
161
|
-
return payloads ? await Promise.all(
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
151
|
+
return payloads ? await Promise.all(
|
|
152
|
+
payloads.map(async (payload) => {
|
|
153
|
+
const built = await _PayloadBuilder.build(payload, options);
|
|
154
|
+
return built.$hash;
|
|
155
|
+
})
|
|
156
|
+
) : void 0;
|
|
165
157
|
}
|
|
166
158
|
static async filterExclude(payloads = [], hash) {
|
|
167
159
|
return await import_hash2.PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash);
|
|
168
160
|
}
|
|
169
161
|
static async filterExcludeByDataHash(payloads = [], hash) {
|
|
170
162
|
var _a;
|
|
171
|
-
const hashes = Array.isArray(hash) ? hash : [
|
|
172
|
-
hash
|
|
173
|
-
];
|
|
163
|
+
const hashes = Array.isArray(hash) ? hash : [hash];
|
|
174
164
|
return (_a = (await this.dataHashPairs(payloads)).filter(([_, objHash]) => !hashes.includes(objHash))) == null ? void 0 : _a.map((pair) => pair[0]);
|
|
175
165
|
}
|
|
176
166
|
static async filterIncludeByDataHash(payloads = [], hash) {
|
|
177
167
|
var _a;
|
|
178
|
-
const hashes = Array.isArray(hash) ? hash : [
|
|
179
|
-
hash
|
|
180
|
-
];
|
|
168
|
+
const hashes = Array.isArray(hash) ? hash : [hash];
|
|
181
169
|
return (_a = (await this.dataHashPairs(payloads)).filter(([_, objHash]) => hashes.includes(objHash))) == null ? void 0 : _a.map((pair) => pair[0]);
|
|
182
170
|
}
|
|
183
171
|
static async findByDataHash(payloads = [], hash) {
|
|
@@ -188,30 +176,30 @@ var _PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
188
176
|
return await import_hash2.PayloadHasher.hash(await _PayloadBuilder.build(payload, options));
|
|
189
177
|
}
|
|
190
178
|
/**
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
179
|
+
* Creates an array of payload/hash tuples based on the payloads passed in
|
|
180
|
+
* @param objs Any array of payloads
|
|
181
|
+
* @returns An array of payload/hash tuples
|
|
182
|
+
*/
|
|
195
183
|
static async hashPairs(payloads, options) {
|
|
196
|
-
return await Promise.all(
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
built,
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
}));
|
|
184
|
+
return await Promise.all(
|
|
185
|
+
payloads.map(async (payload) => {
|
|
186
|
+
const built = await _PayloadBuilder.build(payload, options);
|
|
187
|
+
return [built, await _PayloadBuilder.hash(built)];
|
|
188
|
+
})
|
|
189
|
+
);
|
|
203
190
|
}
|
|
204
191
|
static async hashableFields(schema, fields, $meta, $hash, timestamp, stamp = false) {
|
|
205
192
|
const dataFields = await this.dataHashableFields(schema, fields);
|
|
206
193
|
(0, import_assert2.assertEx)($meta === void 0 || (0, import_object2.isJsonObject)($meta), () => "$meta must be JsonObject");
|
|
207
|
-
const result = (0, import_lodash2.omitBy)(
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
194
|
+
const result = (0, import_lodash2.omitBy)(
|
|
195
|
+
{
|
|
196
|
+
...dataFields,
|
|
197
|
+
$hash: $hash ?? await _PayloadBuilder.dataHash(dataFields),
|
|
198
|
+
schema
|
|
199
|
+
},
|
|
200
|
+
omitByPredicate2("_")
|
|
201
|
+
);
|
|
202
|
+
const clonedMeta = { ...$meta };
|
|
215
203
|
if (timestamp) {
|
|
216
204
|
clonedMeta.timestamp = timestamp;
|
|
217
205
|
}
|
|
@@ -242,10 +230,10 @@ var _PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
242
230
|
return result;
|
|
243
231
|
}
|
|
244
232
|
/**
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
233
|
+
* Creates an object map of payload hashes to payloads based on the payloads passed in
|
|
234
|
+
* @param objs Any array of payloads
|
|
235
|
+
* @returns A map of hashes to payloads
|
|
236
|
+
*/
|
|
249
237
|
static async toHashMap(objs) {
|
|
250
238
|
const result = {};
|
|
251
239
|
for (const pair of await this.hashPairs(objs)) {
|
|
@@ -265,18 +253,16 @@ var _PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
|
265
253
|
}
|
|
266
254
|
async build(options) {
|
|
267
255
|
const dataHashableFields = await this.dataHashableFields();
|
|
268
|
-
return await _PayloadBuilder.build({
|
|
269
|
-
...dataHashableFields,
|
|
270
|
-
$meta: this._$meta,
|
|
271
|
-
schema: this._schema
|
|
272
|
-
}, options);
|
|
256
|
+
return await _PayloadBuilder.build({ ...dataHashableFields, $meta: this._$meta, schema: this._schema }, options);
|
|
273
257
|
}
|
|
274
258
|
async hashableFields() {
|
|
275
|
-
return await _PayloadBuilder.hashableFields(
|
|
259
|
+
return await _PayloadBuilder.hashableFields(
|
|
260
|
+
(0, import_assert2.assertEx)(this._schema, () => "Payload: Missing Schema"),
|
|
261
|
+
this._fields,
|
|
262
|
+
this._$meta
|
|
263
|
+
);
|
|
276
264
|
}
|
|
277
265
|
};
|
|
278
|
-
__name(_PayloadBuilder, "PayloadBuilder");
|
|
279
|
-
var PayloadBuilder = _PayloadBuilder;
|
|
280
266
|
// Annotate the CommonJS export names for ESM import in node:
|
|
281
267
|
0 && (module.exports = {
|
|
282
268
|
PayloadBuilder,
|