@xyo-network/payload-builder 2.89.0-rc.8 → 2.89.0-rc.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/Builder.d.cts +4 -15
- package/dist/browser/Builder.d.cts.map +1 -1
- package/dist/browser/Builder.d.mts +4 -15
- package/dist/browser/Builder.d.mts.map +1 -1
- package/dist/browser/Builder.d.ts +4 -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 +57 -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 +55 -30
- package/dist/browser/index.js.map +1 -1
- package/dist/node/Builder.d.cts +4 -15
- package/dist/node/Builder.d.cts.map +1 -1
- package/dist/node/Builder.d.mts +4 -15
- package/dist/node/Builder.d.mts.map +1 -1
- package/dist/node/Builder.d.ts +4 -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 +57 -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 +53 -29
- package/dist/node/index.js.map +1 -1
- package/package.json +5 -3
- package/src/Builder.ts +9 -44
- package/src/BuilderBase.ts +57 -0
- package/src/Options.ts +10 -0
- package/src/index.ts +2 -0
|
@@ -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][]>;
|
|
@@ -37,9 +29,6 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
37
29
|
* @returns A map of hashes to payloads
|
|
38
30
|
*/
|
|
39
31
|
static toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
40
|
-
$meta(meta?: JsonObject): this;
|
|
41
32
|
build(): Promise<WithMeta<T>>;
|
|
42
|
-
dataHashableFields(): T;
|
|
43
|
-
fields(fields?: Partial<T>): this;
|
|
44
33
|
}
|
|
45
34
|
//# 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,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"}
|
|
@@ -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][]>;
|
|
@@ -37,9 +29,6 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
37
29
|
* @returns A map of hashes to payloads
|
|
38
30
|
*/
|
|
39
31
|
static toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
40
|
-
$meta(meta?: JsonObject): this;
|
|
41
32
|
build(): Promise<WithMeta<T>>;
|
|
42
|
-
dataHashableFields(): T;
|
|
43
|
-
fields(fields?: Partial<T>): this;
|
|
44
33
|
}
|
|
45
34
|
//# 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,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"}
|
|
@@ -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][]>;
|
|
@@ -37,9 +29,6 @@ export declare class PayloadBuilder<T extends Payload = Payload<AnyObject>> {
|
|
|
37
29
|
* @returns A map of hashes to payloads
|
|
38
30
|
*/
|
|
39
31
|
static toHashMap<T extends Payload>(objs: T[]): Promise<Record<Hash, T>>;
|
|
40
|
-
$meta(meta?: JsonObject): this;
|
|
41
32
|
build(): Promise<WithMeta<T>>;
|
|
42
|
-
dataHashableFields(): T;
|
|
43
|
-
fields(fields?: Partial<T>): this;
|
|
44
33
|
}
|
|
45
34
|
//# 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,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'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema'>>): 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,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC,CAAC;IAerG,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'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema'>>): 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,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC,CAAC;IAerG,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'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema'>>): 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,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC,CAAC;IAerG,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/browser/index.cjs
CHANGED
|
@@ -21,28 +21,72 @@ 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 {
|
|
32
36
|
static {
|
|
33
|
-
__name(this, "
|
|
37
|
+
__name(this, "PayloadBuilderBase");
|
|
34
38
|
}
|
|
39
|
+
options;
|
|
35
40
|
_$meta;
|
|
36
|
-
_fields
|
|
41
|
+
_fields;
|
|
37
42
|
_schema;
|
|
38
|
-
constructor(
|
|
43
|
+
constructor(options) {
|
|
44
|
+
this.options = options;
|
|
45
|
+
const { schema, fields, meta } = options;
|
|
39
46
|
this._schema = schema;
|
|
40
|
-
this._fields = fields
|
|
47
|
+
this._fields = fields;
|
|
41
48
|
this._$meta = meta;
|
|
42
49
|
}
|
|
43
|
-
|
|
44
|
-
this.
|
|
45
|
-
return this
|
|
50
|
+
$meta(meta) {
|
|
51
|
+
this._$meta = meta ?? this._fields.$meta;
|
|
52
|
+
return this;
|
|
53
|
+
}
|
|
54
|
+
async dataHashableFields() {
|
|
55
|
+
return (0, import_hash.deepOmitPrefixedFields)(await this.hashableFields(), "$");
|
|
56
|
+
}
|
|
57
|
+
//we do not require sending in $hash since it will be generated anyway
|
|
58
|
+
fields(fields) {
|
|
59
|
+
if (fields) {
|
|
60
|
+
const { $meta, $hash, schema, ...fieldsOnly } = fields;
|
|
61
|
+
if ($meta) {
|
|
62
|
+
this.$meta($meta);
|
|
63
|
+
}
|
|
64
|
+
if (schema) {
|
|
65
|
+
this.schema(schema);
|
|
66
|
+
}
|
|
67
|
+
this._fields = {
|
|
68
|
+
...this._fields,
|
|
69
|
+
...(0, import_hash.removeEmptyFields)(fieldsOnly)
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
hashableFields() {
|
|
75
|
+
const schema = (0, import_assert.assertEx)(this._schema, "Payload: Missing Schema");
|
|
76
|
+
return {
|
|
77
|
+
...(0, import_hash.removeEmptyFields)((0, import_hash.deepOmitPrefixedFields)(this._fields ?? {}, "_")),
|
|
78
|
+
schema
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
schema(value) {
|
|
82
|
+
this._schema = value;
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
// src/Builder.ts
|
|
87
|
+
var PayloadBuilder = class _PayloadBuilder extends PayloadBuilderBase {
|
|
88
|
+
static {
|
|
89
|
+
__name(this, "PayloadBuilder");
|
|
46
90
|
}
|
|
47
91
|
static async build(payload) {
|
|
48
92
|
const { schema, $hash, $meta, ...fields } = payload;
|
|
@@ -72,7 +116,7 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
72
116
|
})) : void 0;
|
|
73
117
|
}
|
|
74
118
|
static async filterExclude(payloads = [], hash) {
|
|
75
|
-
return await
|
|
119
|
+
return await import_hash2.PayloadHasher.filterExcludeByHash(await this.filterExcludeByDataHash(payloads, hash), hash);
|
|
76
120
|
}
|
|
77
121
|
static async filterExcludeByDataHash(payloads = [], hash) {
|
|
78
122
|
const hashes = Array.isArray(hash) ? hash : [
|
|
@@ -90,7 +134,7 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
90
134
|
return (await this.dataHashPairs(payloads)).find(([_, objHash]) => objHash === hash)?.[0];
|
|
91
135
|
}
|
|
92
136
|
static async hash(payload) {
|
|
93
|
-
return await
|
|
137
|
+
return await import_hash2.PayloadHasher.hash(payload);
|
|
94
138
|
}
|
|
95
139
|
/**
|
|
96
140
|
* Creates an array of payload/hash tuples based on the payloads passed in
|
|
@@ -107,7 +151,7 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
107
151
|
}));
|
|
108
152
|
}
|
|
109
153
|
static async hashes(payloads) {
|
|
110
|
-
return await
|
|
154
|
+
return await import_hash2.PayloadHasher.hashes(payloads);
|
|
111
155
|
}
|
|
112
156
|
static async toDataHashMap(objs) {
|
|
113
157
|
const result = {};
|
|
@@ -128,12 +172,8 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
128
172
|
}
|
|
129
173
|
return result;
|
|
130
174
|
}
|
|
131
|
-
$meta(meta) {
|
|
132
|
-
this._$meta = meta;
|
|
133
|
-
return this;
|
|
134
|
-
}
|
|
135
175
|
async build() {
|
|
136
|
-
const dataHashableFields = this.dataHashableFields();
|
|
176
|
+
const dataHashableFields = await this.dataHashableFields();
|
|
137
177
|
const $hash = await _PayloadBuilder.hash(dataHashableFields);
|
|
138
178
|
const hashableFields = {
|
|
139
179
|
...dataHashableFields,
|
|
@@ -144,20 +184,5 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
144
184
|
}
|
|
145
185
|
return hashableFields;
|
|
146
186
|
}
|
|
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
187
|
};
|
|
163
188
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Builder.ts"],"sourcesContent":["export * from './Builder'\n","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":["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/index.ts","../../src/Builder.ts","../../src/BuilderBase.ts"],"sourcesContent":["export * from './Builder'\nexport * from './BuilderBase'\nexport * from './Options'\n","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 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'> & Partial<Pick<WithMeta<T>, '$hash' | 'schema'>>) {\n if (fields) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { $meta, $hash, schema, ...fieldsOnly } = fields as WithMeta<T>\n if ($meta) {\n this.$meta($meta)\n }\n if (schema) {\n this.schema(schema)\n }\n this._fields = { ...this._fields, ...removeEmptyFields(fieldsOnly) }\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":["import_hash","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","toDataHashMap","objs","result","toHashMap","dataHashableFields","hashableFields","_$meta","Object","keys","length"]}
|
package/dist/browser/index.d.cts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,eAAe,CAAA;AAC7B,cAAc,WAAW,CAAA"}
|
package/dist/browser/index.d.mts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,eAAe,CAAA;AAC7B,cAAc,WAAW,CAAA"}
|
package/dist/browser/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,eAAe,CAAA;AAC7B,cAAc,WAAW,CAAA"}
|
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;
|
|
@@ -104,12 +147,8 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
104
147
|
}
|
|
105
148
|
return result;
|
|
106
149
|
}
|
|
107
|
-
$meta(meta) {
|
|
108
|
-
this._$meta = meta;
|
|
109
|
-
return this;
|
|
110
|
-
}
|
|
111
150
|
async build() {
|
|
112
|
-
const dataHashableFields = this.dataHashableFields();
|
|
151
|
+
const dataHashableFields = await this.dataHashableFields();
|
|
113
152
|
const $hash = await _PayloadBuilder.hash(dataHashableFields);
|
|
114
153
|
const hashableFields = {
|
|
115
154
|
...dataHashableFields,
|
|
@@ -120,23 +159,9 @@ var PayloadBuilder = class _PayloadBuilder {
|
|
|
120
159
|
}
|
|
121
160
|
return hashableFields;
|
|
122
161
|
}
|
|
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
162
|
};
|
|
139
163
|
export {
|
|
140
|
-
PayloadBuilder
|
|
164
|
+
PayloadBuilder,
|
|
165
|
+
PayloadBuilderBase
|
|
141
166
|
};
|
|
142
167
|
//# sourceMappingURL=index.js.map
|