@xyo-network/payload-builder 2.89.0-rc.8 → 2.89.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/Builder.d.cts +5 -15
- package/dist/browser/Builder.d.cts.map +1 -1
- package/dist/browser/Builder.d.mts +5 -15
- package/dist/browser/Builder.d.mts.map +1 -1
- package/dist/browser/Builder.d.ts +5 -15
- package/dist/browser/Builder.d.ts.map +1 -1
- package/dist/browser/BuilderBase.d.cts +17 -0
- package/dist/browser/BuilderBase.d.cts.map +1 -0
- package/dist/browser/BuilderBase.d.mts +17 -0
- package/dist/browser/BuilderBase.d.mts.map +1 -0
- package/dist/browser/BuilderBase.d.ts +17 -0
- package/dist/browser/BuilderBase.d.ts.map +1 -0
- package/dist/browser/Options.d.cts +10 -0
- package/dist/browser/Options.d.cts.map +1 -0
- package/dist/browser/Options.d.mts +10 -0
- package/dist/browser/Options.d.mts.map +1 -0
- package/dist/browser/Options.d.ts +10 -0
- package/dist/browser/Options.d.ts.map +1 -0
- package/dist/browser/index.cjs +65 -32
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.d.cts +2 -0
- package/dist/browser/index.d.cts.map +1 -1
- package/dist/browser/index.d.mts +2 -0
- package/dist/browser/index.d.mts.map +1 -1
- package/dist/browser/index.d.ts +2 -0
- package/dist/browser/index.d.ts.map +1 -1
- package/dist/browser/index.js +63 -30
- package/dist/browser/index.js.map +1 -1
- package/dist/node/Builder.d.cts +5 -15
- package/dist/node/Builder.d.cts.map +1 -1
- package/dist/node/Builder.d.mts +5 -15
- package/dist/node/Builder.d.mts.map +1 -1
- package/dist/node/Builder.d.ts +5 -15
- package/dist/node/Builder.d.ts.map +1 -1
- package/dist/node/BuilderBase.d.cts +17 -0
- package/dist/node/BuilderBase.d.cts.map +1 -0
- package/dist/node/BuilderBase.d.mts +17 -0
- package/dist/node/BuilderBase.d.mts.map +1 -0
- package/dist/node/BuilderBase.d.ts +17 -0
- package/dist/node/BuilderBase.d.ts.map +1 -0
- package/dist/node/Options.d.cts +10 -0
- package/dist/node/Options.d.cts.map +1 -0
- package/dist/node/Options.d.mts +10 -0
- package/dist/node/Options.d.mts.map +1 -0
- package/dist/node/Options.d.ts +10 -0
- package/dist/node/Options.d.ts.map +1 -0
- package/dist/node/index.cjs +65 -32
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.d.cts +2 -0
- package/dist/node/index.d.cts.map +1 -1
- package/dist/node/index.d.mts +2 -0
- package/dist/node/index.d.mts.map +1 -1
- package/dist/node/index.d.ts +2 -0
- package/dist/node/index.d.ts.map +1 -1
- package/dist/node/index.js +61 -29
- package/dist/node/index.js.map +1 -1
- package/package.json +6 -5
- package/src/Builder.ts +18 -44
- package/src/BuilderBase.ts +57 -0
- package/src/Options.ts +10 -0
- package/src/index.ts +2 -0
package/dist/browser/index.js
CHANGED
|
@@ -2,23 +2,66 @@ var __defProp = Object.defineProperty;
|
|
|
2
2
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
3
|
|
|
4
4
|
// src/Builder.ts
|
|
5
|
+
import { PayloadHasher } from "@xyo-network/hash";
|
|
6
|
+
|
|
7
|
+
// src/BuilderBase.ts
|
|
5
8
|
import { assertEx } from "@xylabs/assert";
|
|
6
|
-
import { deepOmitPrefixedFields,
|
|
7
|
-
var
|
|
9
|
+
import { deepOmitPrefixedFields, removeEmptyFields } from "@xyo-network/hash";
|
|
10
|
+
var PayloadBuilderBase = class {
|
|
8
11
|
static {
|
|
9
|
-
__name(this, "
|
|
12
|
+
__name(this, "PayloadBuilderBase");
|
|
10
13
|
}
|
|
14
|
+
options;
|
|
11
15
|
_$meta;
|
|
12
|
-
_fields
|
|
16
|
+
_fields;
|
|
13
17
|
_schema;
|
|
14
|
-
constructor(
|
|
18
|
+
constructor(options) {
|
|
19
|
+
this.options = options;
|
|
20
|
+
const { schema, fields, meta } = options;
|
|
15
21
|
this._schema = schema;
|
|
16
|
-
this._fields = fields
|
|
22
|
+
this._fields = fields;
|
|
17
23
|
this._$meta = meta;
|
|
18
24
|
}
|
|
19
|
-
|
|
20
|
-
this.
|
|
21
|
-
return this
|
|
25
|
+
$meta(meta) {
|
|
26
|
+
this._$meta = meta ?? this._fields.$meta;
|
|
27
|
+
return this;
|
|
28
|
+
}
|
|
29
|
+
async dataHashableFields() {
|
|
30
|
+
return deepOmitPrefixedFields(await this.hashableFields(), "$");
|
|
31
|
+
}
|
|
32
|
+
//we do not require sending in $hash since it will be generated anyway
|
|
33
|
+
fields(fields) {
|
|
34
|
+
if (fields) {
|
|
35
|
+
const { $meta, $hash, schema, ...fieldsOnly } = fields;
|
|
36
|
+
if ($meta) {
|
|
37
|
+
this.$meta($meta);
|
|
38
|
+
}
|
|
39
|
+
if (schema) {
|
|
40
|
+
this.schema(schema);
|
|
41
|
+
}
|
|
42
|
+
this._fields = {
|
|
43
|
+
...this._fields,
|
|
44
|
+
...removeEmptyFields(fieldsOnly)
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
return this;
|
|
48
|
+
}
|
|
49
|
+
hashableFields() {
|
|
50
|
+
const schema = assertEx(this._schema, "Payload: Missing Schema");
|
|
51
|
+
return {
|
|
52
|
+
...removeEmptyFields(deepOmitPrefixedFields(this._fields ?? {}, "_")),
|
|
53
|
+
schema
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
schema(value) {
|
|
57
|
+
this._schema = value;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
// src/Builder.ts
|
|
62
|
+
var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
63
|
+
static {
|
|
64
|
+
__name(this, "PayloadBuilder");
|
|
22
65
|
}
|
|
23
66
|
static async build(payload) {
|
|
24
67
|
const { schema, $hash, $meta, ...fields } = payload;
|
|
@@ -85,6 +128,14 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
85
128
|
static async hashes(payloads) {
|
|
86
129
|
return await PayloadHasher.hashes(payloads);
|
|
87
130
|
}
|
|
131
|
+
static async toAllHashMap(objs) {
|
|
132
|
+
const result = {};
|
|
133
|
+
for (const pair of await this.hashPairs(objs)) {
|
|
134
|
+
result[pair[1]] = pair[0];
|
|
135
|
+
result[pair[0].$hash] = pair[0];
|
|
136
|
+
}
|
|
137
|
+
return result;
|
|
138
|
+
}
|
|
88
139
|
static async toDataHashMap(objs) {
|
|
89
140
|
const result = {};
|
|
90
141
|
for (const pair of await this.dataHashPairs(objs)) {
|
|
@@ -104,12 +155,8 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
104
155
|
}
|
|
105
156
|
return result;
|
|
106
157
|
}
|
|
107
|
-
$meta(meta) {
|
|
108
|
-
this._$meta = meta;
|
|
109
|
-
return this;
|
|
110
|
-
}
|
|
111
158
|
async build() {
|
|
112
|
-
const dataHashableFields = this.dataHashableFields();
|
|
159
|
+
const dataHashableFields = await this.dataHashableFields();
|
|
113
160
|
const $hash = await _PayloadBuilder.hash(dataHashableFields);
|
|
114
161
|
const hashableFields = {
|
|
115
162
|
...dataHashableFields,
|
|
@@ -120,23 +167,9 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
120
167
|
}
|
|
121
168
|
return hashableFields;
|
|
122
169
|
}
|
|
123
|
-
dataHashableFields() {
|
|
124
|
-
return {
|
|
125
|
-
...removeEmptyFields(deepOmitPrefixedFields(deepOmitPrefixedFields(this._fields, "$"), "_")),
|
|
126
|
-
schema: assertEx(this.schema, "Payload: Missing Schema")
|
|
127
|
-
};
|
|
128
|
-
}
|
|
129
|
-
fields(fields) {
|
|
130
|
-
if (fields) {
|
|
131
|
-
this._fields = {
|
|
132
|
-
...this._fields,
|
|
133
|
-
...removeEmptyFields(fields)
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
return this;
|
|
137
|
-
}
|
|
138
170
|
};
|
|
139
171
|
export {
|
|
140
|
-
PayloadBuilder
|
|
172
|
+
PayloadBuilder,
|
|
173
|
+
PayloadBuilderBase
|
|
141
174
|
};
|
|
142
175
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Builder.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { AnyObject, JsonObject } from '@xylabs/object'\nimport { deepOmitPrefixedFields, PayloadHasher, removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nexport interface PayloadBuilderOptions<T> {\n fields?: Partial<T>\n meta?: JsonObject\n schema: string\n}\n\nexport class PayloadBuilder<T extends Payload = Payload<AnyObject>> {\n private _$meta?: JsonObject\n private _fields: Partial<T> = {}\n private _schema: string\n\n constructor({ schema, fields, meta }: PayloadBuilderOptions<T>) {\n this._schema = schema\n this._fields = fields ?? {}\n this._$meta = meta\n }\n\n get schema() {\n this._schema = this._schema ?? this._fields['schema']\n return this._schema\n }\n\n static async build<T extends Payload>(payload: T) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schema, $hash, $meta, ...fields } = payload as WithMeta<T>\n const builder = new PayloadBuilder<T>({ fields: fields as T, meta: $meta, schema: payload.schema })\n return await builder.build()\n }\n\n static async dataHash<T extends Payload>(payload: T): Promise<Hash> {\n return (await this.build(payload)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return payloads\n ? await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload)\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): Promise<Hash> {\n return await PayloadHasher.hash(payload)\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[]): 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)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\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 toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>> {\n const result: Record<Hash, 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, T>> {\n const result: Record<Hash, T> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n $meta(meta?: JsonObject) {\n this._$meta = meta\n return this\n }\n\n async build(): Promise<WithMeta<T>> {\n const dataHashableFields = this.dataHashableFields()\n const $hash = await PayloadBuilder.hash(dataHashableFields)\n const hashableFields: PayloadWithMeta = { ...dataHashableFields, $hash }\n\n //only add $meta if it exists and has at least one field\n if (this._$meta && Object.keys(this._$meta).length > 0) {\n hashableFields['$meta'] = this._$meta\n }\n return hashableFields as WithMeta<T>\n }\n\n dataHashableFields() {\n return {\n ...removeEmptyFields(deepOmitPrefixedFields(deepOmitPrefixedFields(this._fields, '$'), '_')),\n schema: assertEx(this.schema, 'Payload: Missing Schema'),\n } as T\n }\n\n fields(fields?: Partial<T>) {\n if (fields) {\n this._fields = { ...this._fields, ...removeEmptyFields(fields) }\n }\n return this\n }\n}\n"],"mappings":"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","names":["assertEx","deepOmitPrefixedFields","PayloadHasher","removeEmptyFields","PayloadBuilder","_$meta","_fields","_schema","constructor","schema","fields","meta","build","payload","$hash","$meta","builder","dataHash","dataHashPairs","payloads","Promise","all","map","built","dataHashes","undefined","filterExclude","hash","PayloadHasher","filterExcludeByHash","filterExcludeByDataHash","hashes","Array","isArray","filter","_","objHash","includes","pair","filterIncludeByDataHash","findByDataHash","find","hashPairs","toDataHashMap","objs","result","toHashMap","dataHashableFields","hashableFields","Object","keys","length","removeEmptyFields","deepOmitPrefixedFields","assertEx"]}
|
|
1
|
+
{"version":3,"sources":["../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["import { Hash } from '@xylabs/hex'\nimport { AnyObject } from '@xylabs/object'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderBase } from './BuilderBase'\nimport { PayloadBuilderOptions } from './Options'\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: T) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schema, $hash, $meta, ...fields } = payload as WithMeta<T>\n const builder = new PayloadBuilder<T>({ fields: fields as T, meta: $meta, schema: payload.schema })\n return await builder.build()\n }\n\n static async dataHash<T extends Payload>(payload: T): Promise<Hash> {\n return (await this.build(payload)).$hash\n }\n\n static async dataHashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]> {\n return await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload)\n return [built, built.$hash]\n }),\n )\n }\n\n static async dataHashes(payloads: undefined): Promise<undefined>\n static async dataHashes<T extends Payload>(payloads: T[]): Promise<Hash[]>\n static async dataHashes<T extends Payload>(payloads?: T[]): Promise<Hash[] | undefined> {\n return payloads\n ? await Promise.all(\n payloads.map(async (payload) => {\n const built = await PayloadBuilder.build(payload)\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): Promise<Hash> {\n return await PayloadHasher.hash(payload)\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[]): 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)\n return [built, await PayloadBuilder.hash(built)]\n }),\n )\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, T>> {\n const result: Record<Hash, 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, T>> {\n const result: Record<Hash, 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, T>> {\n const result: Record<Hash, T> = {}\n for (const pair of await this.hashPairs(objs)) {\n result[pair[1]] = pair[0]\n }\n return result\n }\n\n async build(): Promise<WithMeta<T>> {\n const dataHashableFields = await this.dataHashableFields()\n const $hash = await PayloadBuilder.hash(dataHashableFields)\n const hashableFields: PayloadWithMeta = { ...dataHashableFields, $hash }\n\n //only add $meta if it exists and has at least one field\n if (this._$meta && Object.keys(this._$meta).length > 0) {\n hashableFields['$meta'] = this._$meta\n }\n return hashableFields as WithMeta<T>\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { AnyObject, JsonObject } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { deepOmitPrefixedFields, removeEmptyFields } from '@xyo-network/hash'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { PayloadBuilderOptions } from './Options'\n\nexport class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {\n protected _$meta?: JsonObject\n protected _fields?: Omit<T, 'schema' | '$hash' | '$meta'>\n protected _schema: Schema\n\n constructor(readonly options: O) {\n const { schema, fields, meta } = options\n this._schema = schema\n this._fields = fields\n this._$meta = 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(): Promise<T> {\n return deepOmitPrefixedFields(await this.hashableFields(), '$')\n }\n\n //we do not require sending in $hash since it will be generated anyway\n fields(fields: Omit<WithMeta<T>, '$hash' | 'schema' | '$meta'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema' | '$meta'>>) {\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 = { ...this._fields, ...removeEmptyFields(fieldsOnly) } as T\n }\n return this\n }\n\n hashableFields(): Promisable<T> {\n const schema = assertEx(this._schema, 'Payload: Missing Schema')\n return {\n ...removeEmptyFields(deepOmitPrefixedFields(this._fields ?? {}, '_')),\n schema,\n } as T\n }\n\n schema(value: Schema) {\n this._schema = value\n }\n}\n"],"mappings":"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","names":["PayloadHasher","assertEx","deepOmitPrefixedFields","removeEmptyFields","PayloadBuilderBase","_$meta","_fields","_schema","constructor","options","schema","fields","meta","$meta","dataHashableFields","deepOmitPrefixedFields","hashableFields","$hash","fieldsOnly","removeEmptyFields","assertEx","value","PayloadBuilder","PayloadBuilderBase","build","payload","schema","$hash","$meta","fields","builder","meta","dataHash","dataHashPairs","payloads","Promise","all","map","built","dataHashes","undefined","filterExclude","hash","PayloadHasher","filterExcludeByHash","filterExcludeByDataHash","hashes","Array","isArray","filter","_","objHash","includes","pair","filterIncludeByDataHash","findByDataHash","find","hashPairs","toAllHashMap","objs","result","toDataHashMap","toHashMap","dataHashableFields","hashableFields","_$meta","Object","keys","length"]}
|
package/dist/node/Builder.d.cts
CHANGED
|
@@ -1,17 +1,9 @@
|
|
|
1
1
|
import { Hash } from '@xylabs/hex';
|
|
2
|
-
import { AnyObject
|
|
2
|
+
import { AnyObject } from '@xylabs/object';
|
|
3
3
|
import { Payload, WithMeta } from '@xyo-network/payload-model';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
schema: string;
|
|
8
|
-
}
|
|
9
|
-
export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
10
|
-
private _$meta?;
|
|
11
|
-
private _fields;
|
|
12
|
-
private _schema;
|
|
13
|
-
constructor({ schema, fields, meta }: PayloadBuilderOptions<T>);
|
|
14
|
-
get schema(): string;
|
|
4
|
+
import { PayloadBuilderBase } from './BuilderBase';
|
|
5
|
+
import { PayloadBuilderOptions } from './Options';
|
|
6
|
+
export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> extends PayloadBuilderBase<T, O> {
|
|
15
7
|
static build<T extends Payload>(payload: T): Promise<WithMeta<T>>;
|
|
16
8
|
static dataHash<T extends Payload>(payload: T): Promise<Hash>;
|
|
17
9
|
static dataHashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]>;
|
|
@@ -30,6 +22,7 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
30
22
|
static hashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]>;
|
|
31
23
|
static hashes(payloads: undefined): Promise<undefined>;
|
|
32
24
|
static hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>;
|
|
25
|
+
static toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
33
26
|
static toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
34
27
|
/**
|
|
35
28
|
* Creates an object map of payload hashes to payloads based on the payloads passed in
|
|
@@ -37,9 +30,6 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
37
30
|
* @returns A map of hashes to payloads
|
|
38
31
|
*/
|
|
39
32
|
static toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
40
|
-
$meta(meta?: JsonObject): this;
|
|
41
33
|
build(): Promise<WithMeta<T>>;
|
|
42
|
-
dataHashableFields(): T;
|
|
43
|
-
fields(fields?: Partial<T>): this;
|
|
44
34
|
}
|
|
45
35
|
//# sourceMappingURL=Builder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,EAAE,OAAO,EAAmB,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAE/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,qBAAa,cAAc,CACzB,CAAC,SAAS,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,EACtC,CAAC,SAAS,qBAAqB,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAC7D,SAAQ,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC;WACnB,KAAK,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC;WAOnC,QAAQ,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;WAItD,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC;WAS/E,UAAU,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;WACnD,UAAU,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;WAY7D,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAIvF,uBAAuB,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAKjG,uBAAuB,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAKjG,cAAc,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;WAIzF,IAAI,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAI/D;;;;OAIG;WACU,SAAS,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC;WAS3E,MAAM,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;WAC/C,MAAM,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;WAKzD,YAAY,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;WASpE,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAQlF;;;;OAIG;WACU,SAAS,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAQxE,KAAK,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;CAWpC"}
|
package/dist/node/Builder.d.mts
CHANGED
|
@@ -1,17 +1,9 @@
|
|
|
1
1
|
import { Hash } from '@xylabs/hex';
|
|
2
|
-
import { AnyObject
|
|
2
|
+
import { AnyObject } from '@xylabs/object';
|
|
3
3
|
import { Payload, WithMeta } from '@xyo-network/payload-model';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
schema: string;
|
|
8
|
-
}
|
|
9
|
-
export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
10
|
-
private _$meta?;
|
|
11
|
-
private _fields;
|
|
12
|
-
private _schema;
|
|
13
|
-
constructor({ schema, fields, meta }: PayloadBuilderOptions<T>);
|
|
14
|
-
get schema(): string;
|
|
4
|
+
import { PayloadBuilderBase } from './BuilderBase';
|
|
5
|
+
import { PayloadBuilderOptions } from './Options';
|
|
6
|
+
export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> extends PayloadBuilderBase<T, O> {
|
|
15
7
|
static build<T extends Payload>(payload: T): Promise<WithMeta<T>>;
|
|
16
8
|
static dataHash<T extends Payload>(payload: T): Promise<Hash>;
|
|
17
9
|
static dataHashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]>;
|
|
@@ -30,6 +22,7 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
30
22
|
static hashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]>;
|
|
31
23
|
static hashes(payloads: undefined): Promise<undefined>;
|
|
32
24
|
static hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>;
|
|
25
|
+
static toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
33
26
|
static toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
34
27
|
/**
|
|
35
28
|
* Creates an object map of payload hashes to payloads based on the payloads passed in
|
|
@@ -37,9 +30,6 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
37
30
|
* @returns A map of hashes to payloads
|
|
38
31
|
*/
|
|
39
32
|
static toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
40
|
-
$meta(meta?: JsonObject): this;
|
|
41
33
|
build(): Promise<WithMeta<T>>;
|
|
42
|
-
dataHashableFields(): T;
|
|
43
|
-
fields(fields?: Partial<T>): this;
|
|
44
34
|
}
|
|
45
35
|
//# sourceMappingURL=Builder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,EAAE,OAAO,EAAmB,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAE/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,qBAAa,cAAc,CACzB,CAAC,SAAS,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,EACtC,CAAC,SAAS,qBAAqB,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAC7D,SAAQ,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC;WACnB,KAAK,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC;WAOnC,QAAQ,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;WAItD,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC;WAS/E,UAAU,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;WACnD,UAAU,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;WAY7D,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAIvF,uBAAuB,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAKjG,uBAAuB,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAKjG,cAAc,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;WAIzF,IAAI,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAI/D;;;;OAIG;WACU,SAAS,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC;WAS3E,MAAM,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;WAC/C,MAAM,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;WAKzD,YAAY,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;WASpE,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAQlF;;;;OAIG;WACU,SAAS,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAQxE,KAAK,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;CAWpC"}
|
package/dist/node/Builder.d.ts
CHANGED
|
@@ -1,17 +1,9 @@
|
|
|
1
1
|
import { Hash } from '@xylabs/hex';
|
|
2
|
-
import { AnyObject
|
|
2
|
+
import { AnyObject } from '@xylabs/object';
|
|
3
3
|
import { Payload, WithMeta } from '@xyo-network/payload-model';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
schema: string;
|
|
8
|
-
}
|
|
9
|
-
export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
10
|
-
private _$meta?;
|
|
11
|
-
private _fields;
|
|
12
|
-
private _schema;
|
|
13
|
-
constructor({ schema, fields, meta }: PayloadBuilderOptions<T>);
|
|
14
|
-
get schema(): string;
|
|
4
|
+
import { PayloadBuilderBase } from './BuilderBase';
|
|
5
|
+
import { PayloadBuilderOptions } from './Options';
|
|
6
|
+
export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> extends PayloadBuilderBase<T, O> {
|
|
15
7
|
static build<T extends Payload>(payload: T): Promise<WithMeta<T>>;
|
|
16
8
|
static dataHash<T extends Payload>(payload: T): Promise<Hash>;
|
|
17
9
|
static dataHashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]>;
|
|
@@ -30,6 +22,7 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
30
22
|
static hashPairs<T extends Payload>(payloads: T[]): Promise<[WithMeta<T>, Hash][]>;
|
|
31
23
|
static hashes(payloads: undefined): Promise<undefined>;
|
|
32
24
|
static hashes<T extends Payload>(payloads: T[]): Promise<Hash[]>;
|
|
25
|
+
static toAllHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
33
26
|
static toDataHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
34
27
|
/**
|
|
35
28
|
* Creates an object map of payload hashes to payloads based on the payloads passed in
|
|
@@ -37,9 +30,6 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
37
30
|
* @returns A map of hashes to payloads
|
|
38
31
|
*/
|
|
39
32
|
static toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
40
|
-
$meta(meta?: JsonObject): this;
|
|
41
33
|
build(): Promise<WithMeta<T>>;
|
|
42
|
-
dataHashableFields(): T;
|
|
43
|
-
fields(fields?: Partial<T>): this;
|
|
44
34
|
}
|
|
45
35
|
//# sourceMappingURL=Builder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,EAAE,OAAO,EAAmB,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAE/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,qBAAa,cAAc,CACzB,CAAC,SAAS,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,EACtC,CAAC,SAAS,qBAAqB,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAC7D,SAAQ,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC;WACnB,KAAK,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC;WAOnC,QAAQ,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;WAItD,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC;WAS/E,UAAU,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;WACnD,UAAU,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;WAY7D,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAIvF,uBAAuB,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAKjG,uBAAuB,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;WAKjG,cAAc,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,iBAAU,EAAE,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;WAIzF,IAAI,CAAC,CAAC,SAAS,OAAO,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAI/D;;;;OAIG;WACU,SAAS,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC;WAS3E,MAAM,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;WAC/C,MAAM,CAAC,CAAC,SAAS,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;WAKzD,YAAY,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;WASpE,aAAa,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAQlF;;;;OAIG;WACU,SAAS,CAAC,CAAC,SAAS,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAQxE,KAAK,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;CAWpC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AnyObject, JsonObject } from '@xylabs/object';
|
|
2
|
+
import { Promisable } from '@xylabs/promise';
|
|
3
|
+
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
4
|
+
import { PayloadBuilderOptions } from './Options';
|
|
5
|
+
export declare class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {
|
|
6
|
+
readonly options: O;
|
|
7
|
+
protected _$meta?: JsonObject;
|
|
8
|
+
protected _fields?: Omit<T, 'schema' | '$hash' | '$meta'>;
|
|
9
|
+
protected _schema: Schema;
|
|
10
|
+
constructor(options: O);
|
|
11
|
+
$meta(meta?: JsonObject): this;
|
|
12
|
+
dataHashableFields(): Promise<T>;
|
|
13
|
+
fields(fields: Omit<WithMeta<T>, '$hash' | 'schema' | '$meta'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema' | '$meta'>>): this;
|
|
14
|
+
hashableFields(): Promisable<T>;
|
|
15
|
+
schema(value: Schema): void;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=BuilderBase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BuilderBase.d.ts","sourceRoot":"","sources":["../../src/BuilderBase.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,qBAAa,kBAAkB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,qBAAqB,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC;IAKvH,QAAQ,CAAC,OAAO,EAAE,CAAC;IAJ/B,SAAS,CAAC,MAAM,CAAC,EAAE,UAAU,CAAA;IAC7B,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC,CAAA;IACzD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAA;gBAEJ,OAAO,EAAE,CAAC;IAO/B,KAAK,CAAC,IAAI,CAAC,EAAE,UAAU;IAKjB,kBAAkB,IAAI,OAAO,CAAC,CAAC,CAAC;IAKtC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC,CAAC;IAezH,cAAc,IAAI,UAAU,CAAC,CAAC,CAAC;IAQ/B,MAAM,CAAC,KAAK,EAAE,MAAM;CAGrB"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AnyObject, JsonObject } from '@xylabs/object';
|
|
2
|
+
import { Promisable } from '@xylabs/promise';
|
|
3
|
+
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
4
|
+
import { PayloadBuilderOptions } from './Options';
|
|
5
|
+
export declare class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {
|
|
6
|
+
readonly options: O;
|
|
7
|
+
protected _$meta?: JsonObject;
|
|
8
|
+
protected _fields?: Omit<T, 'schema' | '$hash' | '$meta'>;
|
|
9
|
+
protected _schema: Schema;
|
|
10
|
+
constructor(options: O);
|
|
11
|
+
$meta(meta?: JsonObject): this;
|
|
12
|
+
dataHashableFields(): Promise<T>;
|
|
13
|
+
fields(fields: Omit<WithMeta<T>, '$hash' | 'schema' | '$meta'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema' | '$meta'>>): this;
|
|
14
|
+
hashableFields(): Promisable<T>;
|
|
15
|
+
schema(value: Schema): void;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=BuilderBase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BuilderBase.d.ts","sourceRoot":"","sources":["../../src/BuilderBase.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,qBAAa,kBAAkB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,qBAAqB,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC;IAKvH,QAAQ,CAAC,OAAO,EAAE,CAAC;IAJ/B,SAAS,CAAC,MAAM,CAAC,EAAE,UAAU,CAAA;IAC7B,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC,CAAA;IACzD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAA;gBAEJ,OAAO,EAAE,CAAC;IAO/B,KAAK,CAAC,IAAI,CAAC,EAAE,UAAU;IAKjB,kBAAkB,IAAI,OAAO,CAAC,CAAC,CAAC;IAKtC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC,CAAC;IAezH,cAAc,IAAI,UAAU,CAAC,CAAC,CAAC;IAQ/B,MAAM,CAAC,KAAK,EAAE,MAAM;CAGrB"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AnyObject, JsonObject } from '@xylabs/object';
|
|
2
|
+
import { Promisable } from '@xylabs/promise';
|
|
3
|
+
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
4
|
+
import { PayloadBuilderOptions } from './Options';
|
|
5
|
+
export declare class PayloadBuilderBase<T extends Payload = Payload<AnyObject>, O extends PayloadBuilderOptions<T> = PayloadBuilderOptions<T>> {
|
|
6
|
+
readonly options: O;
|
|
7
|
+
protected _$meta?: JsonObject;
|
|
8
|
+
protected _fields?: Omit<T, 'schema' | '$hash' | '$meta'>;
|
|
9
|
+
protected _schema: Schema;
|
|
10
|
+
constructor(options: O);
|
|
11
|
+
$meta(meta?: JsonObject): this;
|
|
12
|
+
dataHashableFields(): Promise<T>;
|
|
13
|
+
fields(fields: Omit<WithMeta<T>, '$hash' | 'schema' | '$meta'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema' | '$meta'>>): this;
|
|
14
|
+
hashableFields(): Promisable<T>;
|
|
15
|
+
schema(value: Schema): void;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=BuilderBase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BuilderBase.d.ts","sourceRoot":"","sources":["../../src/BuilderBase.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,qBAAa,kBAAkB,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,qBAAqB,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC;IAKvH,QAAQ,CAAC,OAAO,EAAE,CAAC;IAJ/B,SAAS,CAAC,MAAM,CAAC,EAAE,UAAU,CAAA;IAC7B,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC,CAAA;IACzD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAA;gBAEJ,OAAO,EAAE,CAAC;IAO/B,KAAK,CAAC,IAAI,CAAC,EAAE,UAAU;IAKjB,kBAAkB,IAAI,OAAO,CAAC,CAAC,CAAC;IAKtC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC,CAAC;IAezH,cAAc,IAAI,UAAU,CAAC,CAAC,CAAC;IAQ/B,MAAM,CAAC,KAAK,EAAE,MAAM;CAGrB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Logger } from '@xylabs/logger';
|
|
2
|
+
import { JsonObject } from '@xylabs/object';
|
|
3
|
+
import { Schema } from '@xyo-network/payload-model';
|
|
4
|
+
export interface PayloadBuilderOptions<T> {
|
|
5
|
+
readonly fields?: Omit<T, 'schema' | '$hash' | '$meta'>;
|
|
6
|
+
readonly logger?: Logger;
|
|
7
|
+
readonly meta?: JsonObject;
|
|
8
|
+
readonly schema: Schema;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=Options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Options.d.ts","sourceRoot":"","sources":["../../src/Options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAEnD,MAAM,WAAW,qBAAqB,CAAC,CAAC;IACtC,QAAQ,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC,CAAA;IACvD,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;IACxB,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU,CAAA;IAC1B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;CACxB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Logger } from '@xylabs/logger';
|
|
2
|
+
import { JsonObject } from '@xylabs/object';
|
|
3
|
+
import { Schema } from '@xyo-network/payload-model';
|
|
4
|
+
export interface PayloadBuilderOptions<T> {
|
|
5
|
+
readonly fields?: Omit<T, 'schema' | '$hash' | '$meta'>;
|
|
6
|
+
readonly logger?: Logger;
|
|
7
|
+
readonly meta?: JsonObject;
|
|
8
|
+
readonly schema: Schema;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=Options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Options.d.ts","sourceRoot":"","sources":["../../src/Options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAEnD,MAAM,WAAW,qBAAqB,CAAC,CAAC;IACtC,QAAQ,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC,CAAA;IACvD,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;IACxB,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU,CAAA;IAC1B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;CACxB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Logger } from '@xylabs/logger';
|
|
2
|
+
import { JsonObject } from '@xylabs/object';
|
|
3
|
+
import { Schema } from '@xyo-network/payload-model';
|
|
4
|
+
export interface PayloadBuilderOptions<T> {
|
|
5
|
+
readonly fields?: Omit<T, 'schema' | '$hash' | '$meta'>;
|
|
6
|
+
readonly logger?: Logger;
|
|
7
|
+
readonly meta?: JsonObject;
|
|
8
|
+
readonly schema: Schema;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=Options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Options.d.ts","sourceRoot":"","sources":["../../src/Options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAEnD,MAAM,WAAW,qBAAqB,CAAC,CAAC;IACtC,QAAQ,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC,CAAA;IACvD,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;IACxB,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU,CAAA;IAC1B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;CACxB"}
|
package/dist/node/index.cjs
CHANGED
|
@@ -21,26 +21,69 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
21
21
|
// src/index.ts
|
|
22
22
|
var src_exports = {};
|
|
23
23
|
__export(src_exports, {
|
|
24
|
-
PayloadBuilder: () => PayloadBuilder
|
|
24
|
+
PayloadBuilder: () => PayloadBuilder,
|
|
25
|
+
PayloadBuilderBase: () => PayloadBuilderBase
|
|
25
26
|
});
|
|
26
27
|
module.exports = __toCommonJS(src_exports);
|
|
27
28
|
|
|
28
29
|
// src/Builder.ts
|
|
30
|
+
var import_hash2 = require("@xyo-network/hash");
|
|
31
|
+
|
|
32
|
+
// src/BuilderBase.ts
|
|
29
33
|
var import_assert = require("@xylabs/assert");
|
|
30
34
|
var import_hash = require("@xyo-network/hash");
|
|
31
|
-
var
|
|
35
|
+
var _PayloadBuilderBase = class _PayloadBuilderBase {
|
|
36
|
+
options;
|
|
32
37
|
_$meta;
|
|
33
|
-
_fields
|
|
38
|
+
_fields;
|
|
34
39
|
_schema;
|
|
35
|
-
constructor(
|
|
40
|
+
constructor(options) {
|
|
41
|
+
this.options = options;
|
|
42
|
+
const { schema, fields, meta } = options;
|
|
36
43
|
this._schema = schema;
|
|
37
|
-
this._fields = fields
|
|
44
|
+
this._fields = fields;
|
|
38
45
|
this._$meta = meta;
|
|
39
46
|
}
|
|
40
|
-
|
|
41
|
-
this.
|
|
42
|
-
return this
|
|
47
|
+
$meta(meta) {
|
|
48
|
+
this._$meta = meta ?? this._fields.$meta;
|
|
49
|
+
return this;
|
|
50
|
+
}
|
|
51
|
+
async dataHashableFields() {
|
|
52
|
+
return (0, import_hash.deepOmitPrefixedFields)(await this.hashableFields(), "$");
|
|
53
|
+
}
|
|
54
|
+
//we do not require sending in $hash since it will be generated anyway
|
|
55
|
+
fields(fields) {
|
|
56
|
+
if (fields) {
|
|
57
|
+
const { $meta, $hash, schema, ...fieldsOnly } = fields;
|
|
58
|
+
if ($meta) {
|
|
59
|
+
this.$meta($meta);
|
|
60
|
+
}
|
|
61
|
+
if (schema) {
|
|
62
|
+
this.schema(schema);
|
|
63
|
+
}
|
|
64
|
+
this._fields = {
|
|
65
|
+
...this._fields,
|
|
66
|
+
...(0, import_hash.removeEmptyFields)(fieldsOnly)
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
return this;
|
|
70
|
+
}
|
|
71
|
+
hashableFields() {
|
|
72
|
+
const schema = (0, import_assert.assertEx)(this._schema, "Payload: Missing Schema");
|
|
73
|
+
return {
|
|
74
|
+
...(0, import_hash.removeEmptyFields)((0, import_hash.deepOmitPrefixedFields)(this._fields ?? {}, "_")),
|
|
75
|
+
schema
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
schema(value) {
|
|
79
|
+
this._schema = value;
|
|
43
80
|
}
|
|
81
|
+
};
|
|
82
|
+
__name(_PayloadBuilderBase, "PayloadBuilderBase");
|
|
83
|
+
var PayloadBuilderBase = _PayloadBuilderBase;
|
|
84
|
+
|
|
85
|
+
// src/Builder.ts
|
|
86
|
+
var _PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
44
87
|
static async build(payload) {
|
|
45
88
|
const { schema, $hash, $meta, ...fields } = payload;
|
|
46
89
|
const builder = new _PayloadBuilder({
|
|
@@ -69,7 +112,7 @@ var _PayloadBuilder = class _PayloadBuilder {
|
|
|
69
112
|
})) : void 0;
|
|
70
113
|
}
|
|
71
114
|
static async filterExclude(payloads = [], hash) {
|
|
72
|
-
return await
|
|
115
|
+
return await import_hash2.PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash);
|
|
73
116
|
}
|
|
74
117
|
static async filterExcludeByDataHash(payloads = [], hash) {
|
|
75
118
|
var _a;
|
|
@@ -90,7 +133,7 @@ var _PayloadBuilder = class _PayloadBuilder {
|
|
|
90
133
|
return (_a = (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)) == null ? void 0 : _a[0];
|
|
91
134
|
}
|
|
92
135
|
static async hash(payload) {
|
|
93
|
-
return await
|
|
136
|
+
return await import_hash2.PayloadHasher.hash(payload);
|
|
94
137
|
}
|
|
95
138
|
/**
|
|
96
139
|
* Creates an array of payload/hash tuples based on the payloads passed in
|
|
@@ -107,7 +150,15 @@ var _PayloadBuilder = class _PayloadBuilder {
|
|
|
107
150
|
}));
|
|
108
151
|
}
|
|
109
152
|
static async hashes(payloads) {
|
|
110
|
-
return await
|
|
153
|
+
return await import_hash2.PayloadHasher.hashes(payloads);
|
|
154
|
+
}
|
|
155
|
+
static async toAllHashMap(objs) {
|
|
156
|
+
const result = {};
|
|
157
|
+
for (const pair of await this.hashPairs(objs)) {
|
|
158
|
+
result[pair[1]] = pair[0];
|
|
159
|
+
result[pair[0].$hash] = pair[0];
|
|
160
|
+
}
|
|
161
|
+
return result;
|
|
111
162
|
}
|
|
112
163
|
static async toDataHashMap(objs) {
|
|
113
164
|
const result = {};
|
|
@@ -128,12 +179,8 @@ var _PayloadBuilder = class _PayloadBuilder {
|
|
|
128
179
|
}
|
|
129
180
|
return result;
|
|
130
181
|
}
|
|
131
|
-
$meta(meta) {
|
|
132
|
-
this._$meta = meta;
|
|
133
|
-
return this;
|
|
134
|
-
}
|
|
135
182
|
async build() {
|
|
136
|
-
const dataHashableFields = this.dataHashableFields();
|
|
183
|
+
const dataHashableFields = await this.dataHashableFields();
|
|
137
184
|
const $hash = await _PayloadBuilder.hash(dataHashableFields);
|
|
138
185
|
const hashableFields = {
|
|
139
186
|
...dataHashableFields,
|
|
@@ -144,26 +191,12 @@ var _PayloadBuilder = class _PayloadBuilder {
|
|
|
144
191
|
}
|
|
145
192
|
return hashableFields;
|
|
146
193
|
}
|
|
147
|
-
dataHashableFields() {
|
|
148
|
-
return {
|
|
149
|
-
...(0, import_hash.removeEmptyFields)((0, import_hash.deepOmitPrefixedFields)((0, import_hash.deepOmitPrefixedFields)(this._fields, "$"), "_")),
|
|
150
|
-
schema: (0, import_assert.assertEx)(this.schema, "Payload: Missing Schema")
|
|
151
|
-
};
|
|
152
|
-
}
|
|
153
|
-
fields(fields) {
|
|
154
|
-
if (fields) {
|
|
155
|
-
this._fields = {
|
|
156
|
-
...this._fields,
|
|
157
|
-
...(0, import_hash.removeEmptyFields)(fields)
|
|
158
|
-
};
|
|
159
|
-
}
|
|
160
|
-
return this;
|
|
161
|
-
}
|
|
162
194
|
};
|
|
163
195
|
__name(_PayloadBuilder, "PayloadBuilder");
|
|
164
196
|
var PayloadBuilder = _PayloadBuilder;
|
|
165
197
|
// Annotate the CommonJS export names for ESM import in node:
|
|
166
198
|
0 && (module.exports = {
|
|
167
|
-
PayloadBuilder
|
|
199
|
+
PayloadBuilder,
|
|
200
|
+
PayloadBuilderBase
|
|
168
201
|
});
|
|
169
202
|
//# sourceMappingURL=index.cjs.map
|