@xyo-network/payload-plugin 2.53.1 → 2.53.2
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/cjs/Resolver.js +6 -6
- package/dist/cjs/Resolver.js.map +1 -1
- package/dist/cjs/createPlugin.js +7 -7
- package/dist/cjs/createPlugin.js.map +1 -1
- package/dist/docs.json +131 -131
- package/dist/esm/Resolver.js +6 -6
- package/dist/esm/Resolver.js.map +1 -1
- package/dist/esm/createPlugin.js +5 -5
- package/dist/esm/createPlugin.js.map +1 -1
- package/dist/types/Plugin.d.ts +7 -7
- package/dist/types/Plugin.d.ts.map +1 -1
- package/dist/types/Resolver.d.ts +13 -13
- package/dist/types/Resolver.d.ts.map +1 -1
- package/dist/types/createPlugin.d.ts +5 -5
- package/dist/types/createPlugin.d.ts.map +1 -1
- package/package.json +6 -6
- package/src/Plugin.ts +7 -7
- package/src/Resolver.ts +17 -17
- package/src/createPlugin.ts +10 -10
package/dist/esm/Resolver.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
export class
|
|
4
|
-
schema =
|
|
1
|
+
import { PayloadSchema } from '@xyo-network/payload-model';
|
|
2
|
+
import { createPayloadPlugin } from './createPlugin';
|
|
3
|
+
export class PayloadPluginResolver {
|
|
4
|
+
schema = PayloadSchema;
|
|
5
5
|
_plugins = {};
|
|
6
6
|
defaultPlugin;
|
|
7
7
|
constructor(
|
|
8
8
|
/** @param plugins The initial set of plugins */
|
|
9
9
|
plugins,
|
|
10
10
|
/** @param defaultPlugin Specifies the plugin to be used if no plugins resolve */
|
|
11
|
-
defaultPlugin =
|
|
12
|
-
schema:
|
|
11
|
+
defaultPlugin = createPayloadPlugin({
|
|
12
|
+
schema: PayloadSchema,
|
|
13
13
|
})) {
|
|
14
14
|
plugins?.forEach((plugin) => this.register(plugin));
|
|
15
15
|
this.defaultPlugin = defaultPlugin;
|
package/dist/esm/Resolver.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Resolver.js","sourceRoot":"","sources":["../../src/Resolver.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"Resolver.js","sourceRoot":"","sources":["../../src/Resolver.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAGnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAA;AAGpD,MAAM,OAAO,qBAAqB;IAChC,MAAM,GAAG,aAAa,CAAA;IAEZ,QAAQ,GAAkC,EAAE,CAAA;IAC5C,aAAa,CAAe;IAEtC;IACE,gDAAgD;IAChD,OAAkC;IAClC,iFAAiF;IACjF,gBAAgB,mBAAmB,CAAU;QAC3C,MAAM,EAAE,aAAa;KACtB,CAAC;QAEF,OAAO,EAAE,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAA;QACnD,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;IACpC,CAAC;IAED,4FAA4F;IAC5F,OAAO;QACL,MAAM,MAAM,GAAoB,EAAE,CAAA;QAClC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAC7C,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACpB,CAAC,CAAC,CAAA;QACF,OAAO,MAAM,CAAA;IACf,CAAC;IAED,QAAQ,CAAgD,MAAe;QACrE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,CAAA;QAErC,OAAO,IAAI,CAAA;IACb,CAAC;IAID,OAAO,CAAC,KAAmC;QACzC,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAA;IAC3H,CAAC;IAED,2FAA2F;IAC3F,OAAO;QACL,MAAM,MAAM,GAAa,EAAE,CAAA;QAC3B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAC7C,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAC3B,CAAC,CAAC,CAAA;QACF,OAAO,MAAM,CAAA;IACf,CAAC;IAED,QAAQ,CAAC,OAAgB;QACvB,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAA;IAClD,CAAC;IAED,IAAI,CAAC,OAAgB;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,CAAA;IAC9C,CAAC;CACF"}
|
package/dist/esm/createPlugin.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { assertEx } from '@xylabs/assert';
|
|
2
|
-
import {
|
|
2
|
+
import { PayloadBuilder } from '@xyo-network/payload-builder';
|
|
3
3
|
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
4
4
|
import { PayloadWrapper } from '@xyo-network/payload-wrapper';
|
|
5
|
-
export const
|
|
5
|
+
export const defaultPayloadPluginFunctions = (schema) => {
|
|
6
6
|
return {
|
|
7
7
|
build: () => {
|
|
8
|
-
return new
|
|
8
|
+
return new PayloadBuilder({ schema });
|
|
9
9
|
},
|
|
10
10
|
schema,
|
|
11
11
|
validate: (payload) => {
|
|
@@ -16,9 +16,9 @@ export const defaultXyoPayloadPluginFunctions = (schema) => {
|
|
|
16
16
|
},
|
|
17
17
|
};
|
|
18
18
|
};
|
|
19
|
-
export const
|
|
19
|
+
export const createPayloadPlugin = (plugin) => {
|
|
20
20
|
return {
|
|
21
|
-
...
|
|
21
|
+
...defaultPayloadPluginFunctions(assertEx(plugin.schema, 'schema field required to create plugin')),
|
|
22
22
|
...plugin,
|
|
23
23
|
};
|
|
24
24
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createPlugin.js","sourceRoot":"","sources":["../../src/createPlugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"createPlugin.js","sourceRoot":"","sources":["../../src/createPlugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAE7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAI7D,MAAM,CAAC,MAAM,6BAA6B,GAAG,CAAoB,MAAc,EAAoB,EAAE;IACnG,OAAO;QACL,KAAK,EAAE,GAAsB,EAAE;YAC7B,OAAO,IAAI,cAAc,CAAI,EAAE,MAAM,EAAE,CAAC,CAAA;QAC1C,CAAC;QACD,MAAM;QACN,QAAQ,EAAE,CAAC,OAAgB,EAAuB,EAAE;YAClD,OAAO,IAAI,gBAAgB,CAAI,OAAY,CAAC,CAAA;QAC9C,CAAC;QACD,IAAI,EAAE,CAAC,OAAgB,EAAqB,EAAE;YAC5C,OAAO,IAAI,cAAc,CAAI,OAAY,CAAC,CAAA;QAC5C,CAAC;KACF,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAqC,MAA+B,EAA2B,EAAE;IAClI,OAAO;QACL,GAAG,6BAA6B,CAAW,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,wCAAwC,CAAC,CAAC;QAC7G,GAAG,MAAM;KACV,CAAA;AACH,CAAC,CAAA"}
|
package/dist/types/Plugin.d.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { Validator } from '@xyo-network/core';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { PayloadBuilder } from '@xyo-network/payload-builder';
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
4
4
|
import { PayloadWrapper } from '@xyo-network/payload-wrapper';
|
|
5
|
-
export type
|
|
6
|
-
export type
|
|
7
|
-
build?: () =>
|
|
5
|
+
export type PayloadPluginFunc<TPayload extends Payload = Payload> = () => PayloadPlugin<TPayload>;
|
|
6
|
+
export type PayloadPlugin<TPayload extends Payload = Payload> = {
|
|
7
|
+
build?: () => PayloadBuilder;
|
|
8
8
|
jsonSchema?: object;
|
|
9
9
|
schema: TPayload['schema'];
|
|
10
10
|
template?: () => Partial<TPayload>;
|
|
11
|
-
validate?: (payload:
|
|
12
|
-
wrap?: (payload:
|
|
11
|
+
validate?: (payload: Payload) => Validator;
|
|
12
|
+
wrap?: (payload: Payload) => PayloadWrapper;
|
|
13
13
|
};
|
|
14
14
|
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAC7D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAE7D,MAAM,MAAM,iBAAiB,CAAC,QAAQ,SAAS,OAAO,GAAG,OAAO,IAAI,MAAM,aAAa,CAAC,QAAQ,CAAC,CAAA;AAEjG,MAAM,MAAM,aAAa,CAAC,QAAQ,SAAS,OAAO,GAAG,OAAO,IAAI;IAC9D,KAAK,CAAC,EAAE,MAAM,cAAc,CAAA;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,MAAM,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAA;IAC1B,QAAQ,CAAC,EAAE,MAAM,OAAO,CAAC,QAAQ,CAAC,CAAA;IAClC,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,SAAS,CAAA;IAC1C,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,cAAc,CAAA;CAC5C,CAAA"}
|
package/dist/types/Resolver.d.ts
CHANGED
|
@@ -1,28 +1,28 @@
|
|
|
1
1
|
import { Validator } from '@xyo-network/core';
|
|
2
|
-
import {
|
|
2
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
3
3
|
import { PayloadWrapper } from '@xyo-network/payload-wrapper';
|
|
4
|
-
import {
|
|
5
|
-
export declare class
|
|
4
|
+
import { PayloadPlugin } from './Plugin';
|
|
5
|
+
export declare class PayloadPluginResolver {
|
|
6
6
|
schema: "network.xyo.payload";
|
|
7
|
-
protected _plugins: Record<string,
|
|
8
|
-
protected defaultPlugin:
|
|
7
|
+
protected _plugins: Record<string, PayloadPlugin>;
|
|
8
|
+
protected defaultPlugin: PayloadPlugin;
|
|
9
9
|
constructor(
|
|
10
10
|
/** @param plugins The initial set of plugins */
|
|
11
|
-
plugins?:
|
|
11
|
+
plugins?: PayloadPlugin<Payload>[],
|
|
12
12
|
/** @param defaultPlugin Specifies the plugin to be used if no plugins resolve */
|
|
13
|
-
defaultPlugin?:
|
|
13
|
+
defaultPlugin?: PayloadPlugin<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
14
14
|
schema: string;
|
|
15
15
|
}>);
|
|
16
16
|
/** @description Create list of plugins, optionally filtered by ability to witness/divine */
|
|
17
|
-
plugins():
|
|
17
|
+
plugins(): PayloadPlugin<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
18
18
|
schema: string;
|
|
19
19
|
}>[];
|
|
20
|
-
register<TPlugin extends
|
|
21
|
-
resolve(schema?: string):
|
|
22
|
-
resolve(payload:
|
|
20
|
+
register<TPlugin extends PayloadPlugin = PayloadPlugin>(plugin: TPlugin): this;
|
|
21
|
+
resolve(schema?: string): PayloadPlugin;
|
|
22
|
+
resolve(payload: Payload): PayloadPlugin;
|
|
23
23
|
/** @description Create list of schema, optionally filtered by ability to witness/divine */
|
|
24
24
|
schemas(): string[];
|
|
25
|
-
validate(payload:
|
|
26
|
-
wrap(payload:
|
|
25
|
+
validate(payload: Payload): Validator<Payload> | undefined;
|
|
26
|
+
wrap(payload: Payload): PayloadWrapper<Payload> | undefined;
|
|
27
27
|
}
|
|
28
28
|
//# sourceMappingURL=Resolver.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Resolver.d.ts","sourceRoot":"","sources":["../../src/Resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"Resolver.d.ts","sourceRoot":"","sources":["../../src/Resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,EAAE,OAAO,EAAiB,MAAM,4BAA4B,CAAA;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAG7D,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAExC,qBAAa,qBAAqB;IAChC,MAAM,wBAAgB;IAEtB,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAK;IACtD,SAAS,CAAC,aAAa,EAAE,aAAa,CAAA;;IAGpC,gDAAgD;IAChD,OAAO,CAAC,EAAE,aAAa,CAAC,OAAO,CAAC,EAAE;IAClC,iFAAiF;IACjF,aAAa;;MAEX;IAMJ,4FAA4F;IAC5F,OAAO;;;IAQP,QAAQ,CAAC,OAAO,SAAS,aAAa,GAAG,aAAa,EAAE,MAAM,EAAE,OAAO;IAMvE,OAAO,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,aAAa;IACvC,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,aAAa;IAKxC,2FAA2F;IAC3F,OAAO;IAQP,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC,GAAG,SAAS;IAI1D,IAAI,CAAC,OAAO,EAAE,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,GAAG,SAAS;CAG5D"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export declare const
|
|
1
|
+
import { PayloadPlugin } from './Plugin';
|
|
2
|
+
export declare const defaultPayloadPluginFunctions: <T extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
3
3
|
schema: string;
|
|
4
|
-
}>(schema: string) =>
|
|
5
|
-
export declare const
|
|
4
|
+
}>(schema: string) => PayloadPlugin<T>;
|
|
5
|
+
export declare const createPayloadPlugin: <TPayload extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
6
6
|
schema: string;
|
|
7
7
|
} = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
8
8
|
schema: string;
|
|
9
|
-
}>(plugin:
|
|
9
|
+
}>(plugin: PayloadPlugin<TPayload>) => PayloadPlugin<TPayload>;
|
|
10
10
|
//# sourceMappingURL=createPlugin.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createPlugin.d.ts","sourceRoot":"","sources":["../../src/createPlugin.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"createPlugin.d.ts","sourceRoot":"","sources":["../../src/createPlugin.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAExC,eAAO,MAAM,6BAA6B;;WAA+B,MAAM,qBAa9E,CAAA;AAED,eAAO,MAAM,mBAAmB;;;;8DAK/B,CAAA"}
|
package/package.json
CHANGED
|
@@ -11,11 +11,11 @@
|
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"@xylabs/assert": "^2.7.4",
|
|
14
|
-
"@xyo-network/core": "^2.53.
|
|
15
|
-
"@xyo-network/payload-builder": "^2.53.
|
|
16
|
-
"@xyo-network/payload-model": "^2.53.
|
|
17
|
-
"@xyo-network/payload-validator": "^2.53.
|
|
18
|
-
"@xyo-network/payload-wrapper": "^2.53.
|
|
14
|
+
"@xyo-network/core": "^2.53.2",
|
|
15
|
+
"@xyo-network/payload-builder": "^2.53.2",
|
|
16
|
+
"@xyo-network/payload-model": "^2.53.2",
|
|
17
|
+
"@xyo-network/payload-validator": "^2.53.2",
|
|
18
|
+
"@xyo-network/payload-wrapper": "^2.53.2"
|
|
19
19
|
},
|
|
20
20
|
"devDependencies": {
|
|
21
21
|
"@xylabs/ts-scripts-yarn3": "^2.16.1",
|
|
@@ -55,5 +55,5 @@
|
|
|
55
55
|
},
|
|
56
56
|
"sideEffects": false,
|
|
57
57
|
"types": "dist/types/index.d.ts",
|
|
58
|
-
"version": "2.53.
|
|
58
|
+
"version": "2.53.2"
|
|
59
59
|
}
|
package/src/Plugin.ts
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { Validator } from '@xyo-network/core'
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { PayloadBuilder } from '@xyo-network/payload-builder'
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model'
|
|
4
4
|
import { PayloadWrapper } from '@xyo-network/payload-wrapper'
|
|
5
5
|
|
|
6
|
-
export type
|
|
6
|
+
export type PayloadPluginFunc<TPayload extends Payload = Payload> = () => PayloadPlugin<TPayload>
|
|
7
7
|
|
|
8
|
-
export type
|
|
9
|
-
build?: () =>
|
|
8
|
+
export type PayloadPlugin<TPayload extends Payload = Payload> = {
|
|
9
|
+
build?: () => PayloadBuilder
|
|
10
10
|
jsonSchema?: object
|
|
11
11
|
schema: TPayload['schema']
|
|
12
12
|
template?: () => Partial<TPayload>
|
|
13
|
-
validate?: (payload:
|
|
14
|
-
wrap?: (payload:
|
|
13
|
+
validate?: (payload: Payload) => Validator
|
|
14
|
+
wrap?: (payload: Payload) => PayloadWrapper
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
/* Note: We use PartialWitnessConfig to allow people to config witnesses without having to pass in all the schema info*/
|
package/src/Resolver.ts
CHANGED
|
@@ -1,22 +1,22 @@
|
|
|
1
1
|
import { Validator } from '@xyo-network/core'
|
|
2
|
-
import {
|
|
2
|
+
import { Payload, PayloadSchema } from '@xyo-network/payload-model'
|
|
3
3
|
import { PayloadWrapper } from '@xyo-network/payload-wrapper'
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
5
|
+
import { createPayloadPlugin } from './createPlugin'
|
|
6
|
+
import { PayloadPlugin } from './Plugin'
|
|
7
7
|
|
|
8
|
-
export class
|
|
9
|
-
schema =
|
|
8
|
+
export class PayloadPluginResolver {
|
|
9
|
+
schema = PayloadSchema
|
|
10
10
|
|
|
11
|
-
protected _plugins: Record<string,
|
|
12
|
-
protected defaultPlugin:
|
|
11
|
+
protected _plugins: Record<string, PayloadPlugin> = {}
|
|
12
|
+
protected defaultPlugin: PayloadPlugin
|
|
13
13
|
|
|
14
14
|
constructor(
|
|
15
15
|
/** @param plugins The initial set of plugins */
|
|
16
|
-
plugins?:
|
|
16
|
+
plugins?: PayloadPlugin<Payload>[],
|
|
17
17
|
/** @param defaultPlugin Specifies the plugin to be used if no plugins resolve */
|
|
18
|
-
defaultPlugin =
|
|
19
|
-
schema:
|
|
18
|
+
defaultPlugin = createPayloadPlugin<Payload>({
|
|
19
|
+
schema: PayloadSchema,
|
|
20
20
|
}),
|
|
21
21
|
) {
|
|
22
22
|
plugins?.forEach((plugin) => this.register(plugin))
|
|
@@ -25,22 +25,22 @@ export class XyoPayloadPluginResolver {
|
|
|
25
25
|
|
|
26
26
|
/** @description Create list of plugins, optionally filtered by ability to witness/divine */
|
|
27
27
|
plugins() {
|
|
28
|
-
const result:
|
|
28
|
+
const result: PayloadPlugin[] = []
|
|
29
29
|
Object.values(this._plugins).forEach((value) => {
|
|
30
30
|
result.push(value)
|
|
31
31
|
})
|
|
32
32
|
return result
|
|
33
33
|
}
|
|
34
34
|
|
|
35
|
-
register<TPlugin extends
|
|
35
|
+
register<TPlugin extends PayloadPlugin = PayloadPlugin>(plugin: TPlugin) {
|
|
36
36
|
this._plugins[plugin.schema] = plugin
|
|
37
37
|
|
|
38
38
|
return this
|
|
39
39
|
}
|
|
40
40
|
|
|
41
|
-
resolve(schema?: string):
|
|
42
|
-
resolve(payload:
|
|
43
|
-
resolve(value:
|
|
41
|
+
resolve(schema?: string): PayloadPlugin
|
|
42
|
+
resolve(payload: Payload): PayloadPlugin
|
|
43
|
+
resolve(value: Payload | string | undefined): PayloadPlugin {
|
|
44
44
|
return value ? this._plugins[typeof value === 'string' ? value : value.schema] ?? this.defaultPlugin : this.defaultPlugin
|
|
45
45
|
}
|
|
46
46
|
|
|
@@ -53,11 +53,11 @@ export class XyoPayloadPluginResolver {
|
|
|
53
53
|
return result
|
|
54
54
|
}
|
|
55
55
|
|
|
56
|
-
validate(payload:
|
|
56
|
+
validate(payload: Payload): Validator<Payload> | undefined {
|
|
57
57
|
return this.resolve(payload).validate?.(payload)
|
|
58
58
|
}
|
|
59
59
|
|
|
60
|
-
wrap(payload:
|
|
60
|
+
wrap(payload: Payload): PayloadWrapper<Payload> | undefined {
|
|
61
61
|
return this.resolve(payload).wrap?.(payload)
|
|
62
62
|
}
|
|
63
63
|
}
|
package/src/createPlugin.ts
CHANGED
|
@@ -1,29 +1,29 @@
|
|
|
1
1
|
import { assertEx } from '@xylabs/assert'
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { PayloadBuilder } from '@xyo-network/payload-builder'
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model'
|
|
4
4
|
import { PayloadValidator } from '@xyo-network/payload-validator'
|
|
5
5
|
import { PayloadWrapper } from '@xyo-network/payload-wrapper'
|
|
6
6
|
|
|
7
|
-
import {
|
|
7
|
+
import { PayloadPlugin } from './Plugin'
|
|
8
8
|
|
|
9
|
-
export const
|
|
9
|
+
export const defaultPayloadPluginFunctions = <T extends Payload>(schema: string): PayloadPlugin<T> => {
|
|
10
10
|
return {
|
|
11
|
-
build: ():
|
|
12
|
-
return new
|
|
11
|
+
build: (): PayloadBuilder<T> => {
|
|
12
|
+
return new PayloadBuilder<T>({ schema })
|
|
13
13
|
},
|
|
14
14
|
schema,
|
|
15
|
-
validate: (payload:
|
|
15
|
+
validate: (payload: Payload): PayloadValidator<T> => {
|
|
16
16
|
return new PayloadValidator<T>(payload as T)
|
|
17
17
|
},
|
|
18
|
-
wrap: (payload:
|
|
18
|
+
wrap: (payload: Payload): PayloadWrapper<T> => {
|
|
19
19
|
return new PayloadWrapper<T>(payload as T)
|
|
20
20
|
},
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
|
|
24
|
-
export const
|
|
24
|
+
export const createPayloadPlugin = <TPayload extends Payload = Payload>(plugin: PayloadPlugin<TPayload>): PayloadPlugin<TPayload> => {
|
|
25
25
|
return {
|
|
26
|
-
...
|
|
26
|
+
...defaultPayloadPluginFunctions<TPayload>(assertEx(plugin.schema, 'schema field required to create plugin')),
|
|
27
27
|
...plugin,
|
|
28
28
|
}
|
|
29
29
|
}
|