@xyo-network/payload-plugin 2.75.0 → 2.75.1
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/Plugin.d.cts +14 -0
- package/dist/browser/Plugin.d.cts.map +1 -0
- package/dist/browser/Resolver.d.cts +26 -0
- package/dist/browser/Resolver.d.cts.map +1 -0
- package/dist/browser/Resolver.js +3 -31
- package/dist/browser/Resolver.js.map +1 -1
- package/dist/browser/createPlugin.d.cts +10 -0
- package/dist/browser/createPlugin.d.cts.map +1 -0
- package/dist/browser/createPlugin.js +2 -3
- package/dist/browser/createPlugin.js.map +1 -1
- package/dist/browser/index.d.cts +4 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.js +3 -73
- package/dist/browser/index.js.map +1 -1
- package/dist/docs.json +2186 -0
- package/dist/node/Plugin.d.cts +14 -0
- package/dist/node/Plugin.d.cts.map +1 -0
- package/dist/node/Plugin.js +2 -0
- package/dist/node/Plugin.js.map +1 -1
- package/dist/node/Resolver.d.cts +26 -0
- package/dist/node/Resolver.d.cts.map +1 -0
- package/dist/node/Resolver.js +38 -7
- package/dist/node/Resolver.js.map +1 -1
- package/dist/node/Resolver.mjs +36 -6
- package/dist/node/Resolver.mjs.map +1 -1
- package/dist/node/createPlugin.d.cts +10 -0
- package/dist/node/createPlugin.d.cts.map +1 -0
- package/dist/node/createPlugin.js +4 -2
- package/dist/node/createPlugin.js.map +1 -1
- package/dist/node/createPlugin.mjs +3 -2
- package/dist/node/createPlugin.mjs.map +1 -1
- package/dist/node/index.d.cts +4 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.js +85 -7
- package/dist/node/index.js.map +1 -1
- package/dist/node/index.mjs +75 -3
- package/dist/node/index.mjs.map +1 -1
- package/package.json +10 -10
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Validator } from '@xyo-network/core';
|
|
2
|
+
import { PayloadBuilder } from '@xyo-network/payload-builder';
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
4
|
+
import { PayloadWrapper } from '@xyo-network/payload-wrapper';
|
|
5
|
+
export type PayloadPluginFunc<TPayload extends Payload = Payload> = () => PayloadPlugin<TPayload>;
|
|
6
|
+
export type PayloadPlugin<TPayload extends Payload = Payload> = {
|
|
7
|
+
build?: () => PayloadBuilder;
|
|
8
|
+
jsonSchema?: object;
|
|
9
|
+
schema: TPayload['schema'];
|
|
10
|
+
template?: () => Partial<TPayload>;
|
|
11
|
+
validate?: (payload: Payload) => Validator;
|
|
12
|
+
wrap?: (payload: Payload) => PayloadWrapper;
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -0,0 +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,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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Validator } from '@xyo-network/core';
|
|
2
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
3
|
+
import { PayloadWrapper } from '@xyo-network/payload-wrapper';
|
|
4
|
+
import { PayloadPlugin } from './Plugin';
|
|
5
|
+
export declare class PayloadPluginResolver {
|
|
6
|
+
schema: "network.xyo.payload";
|
|
7
|
+
protected _plugins: Record<string, PayloadPlugin>;
|
|
8
|
+
protected defaultPlugin: PayloadPlugin;
|
|
9
|
+
constructor(
|
|
10
|
+
/** @param plugins The initial set of plugins */
|
|
11
|
+
plugins?: PayloadPlugin<Payload>[],
|
|
12
|
+
/** @param defaultPlugin Specifies the plugin to be used if no plugins resolve */
|
|
13
|
+
defaultPlugin?: PayloadPlugin<{
|
|
14
|
+
schema: string;
|
|
15
|
+
} & import("@xyo-network/payload-model").PayloadFields>);
|
|
16
|
+
/** @description Create list of plugins, optionally filtered by ability to witness/divine */
|
|
17
|
+
plugins(): PayloadPlugin[];
|
|
18
|
+
register<TPlugin extends PayloadPlugin = PayloadPlugin>(plugin: TPlugin): this;
|
|
19
|
+
resolve(schema?: string): PayloadPlugin;
|
|
20
|
+
resolve(payload: Payload): PayloadPlugin;
|
|
21
|
+
/** @description Create list of schema, optionally filtered by ability to witness/divine */
|
|
22
|
+
schemas(): string[];
|
|
23
|
+
validate(payload: Payload): Validator<Payload> | undefined;
|
|
24
|
+
wrap(payload: Payload): PayloadWrapper<Payload> | undefined;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=Resolver.d.ts.map
|
|
@@ -0,0 +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,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;;2DAEX;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"}
|
package/dist/browser/Resolver.js
CHANGED
|
@@ -1,34 +1,6 @@
|
|
|
1
|
-
// src/Resolver.ts
|
|
2
1
|
import { PayloadSchema } from "@xyo-network/payload-model";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
import { assertEx } from "@xylabs/assert";
|
|
6
|
-
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
7
|
-
import { PayloadValidator } from "@xyo-network/payload-validator";
|
|
8
|
-
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
9
|
-
var defaultPayloadPluginFunctions = (schema) => {
|
|
10
|
-
return {
|
|
11
|
-
build: () => {
|
|
12
|
-
return new PayloadBuilder({ schema });
|
|
13
|
-
},
|
|
14
|
-
schema,
|
|
15
|
-
validate: (payload) => {
|
|
16
|
-
return new PayloadValidator(payload);
|
|
17
|
-
},
|
|
18
|
-
wrap: (payload) => {
|
|
19
|
-
return PayloadWrapper.wrap(payload);
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
};
|
|
23
|
-
var createPayloadPlugin = (plugin) => {
|
|
24
|
-
return {
|
|
25
|
-
...defaultPayloadPluginFunctions(assertEx(plugin.schema, "schema field required to create plugin")),
|
|
26
|
-
...plugin
|
|
27
|
-
};
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
// src/Resolver.ts
|
|
31
|
-
var PayloadPluginResolver = class {
|
|
2
|
+
import { createPayloadPlugin } from "./createPlugin";
|
|
3
|
+
class PayloadPluginResolver {
|
|
32
4
|
schema = PayloadSchema;
|
|
33
5
|
_plugins = {};
|
|
34
6
|
defaultPlugin;
|
|
@@ -67,7 +39,7 @@ var PayloadPluginResolver = class {
|
|
|
67
39
|
wrap(payload) {
|
|
68
40
|
return this.resolve(payload).wrap?.(payload);
|
|
69
41
|
}
|
|
70
|
-
}
|
|
42
|
+
}
|
|
71
43
|
export {
|
|
72
44
|
PayloadPluginResolver
|
|
73
45
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Resolver.ts"
|
|
1
|
+
{"version":3,"sources":["../../src/Resolver.ts"],"sourcesContent":["import { Validator } from '@xyo-network/core'\nimport { Payload, PayloadSchema } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { createPayloadPlugin } from './createPlugin'\nimport { PayloadPlugin } from './Plugin'\n\nexport class PayloadPluginResolver {\n schema = PayloadSchema\n\n protected _plugins: Record<string, PayloadPlugin> = {}\n protected defaultPlugin: PayloadPlugin\n\n constructor(\n /** @param plugins The initial set of plugins */\n plugins?: PayloadPlugin<Payload>[],\n /** @param defaultPlugin Specifies the plugin to be used if no plugins resolve */\n defaultPlugin = createPayloadPlugin<Payload>({\n schema: PayloadSchema,\n }),\n ) {\n plugins?.forEach((plugin) => this.register(plugin))\n this.defaultPlugin = defaultPlugin\n }\n\n /** @description Create list of plugins, optionally filtered by ability to witness/divine */\n plugins() {\n const result: PayloadPlugin[] = []\n Object.values(this._plugins).forEach((value) => {\n result.push(value)\n })\n return result\n }\n\n register<TPlugin extends PayloadPlugin = PayloadPlugin>(plugin: TPlugin) {\n this._plugins[plugin.schema] = plugin\n\n return this\n }\n\n resolve(schema?: string): PayloadPlugin\n resolve(payload: Payload): PayloadPlugin\n resolve(value: Payload | string | undefined): PayloadPlugin {\n return value ? this._plugins[typeof value === 'string' ? value : value.schema] ?? this.defaultPlugin : this.defaultPlugin\n }\n\n /** @description Create list of schema, optionally filtered by ability to witness/divine */\n schemas() {\n const result: string[] = []\n Object.values(this._plugins).forEach((value) => {\n result.push(value.schema)\n })\n return result\n }\n\n validate(payload: Payload): Validator<Payload> | undefined {\n return this.resolve(payload).validate?.(payload)\n }\n\n wrap(payload: Payload): PayloadWrapper<Payload> | undefined {\n return this.resolve(payload).wrap?.(payload)\n }\n}\n"],"mappings":"AACA,SAAkB,qBAAqB;AAGvC,SAAS,2BAA2B;AAG7B,MAAM,sBAAsB;AAAA,EACjC,SAAS;AAAA,EAEC,WAA0C,CAAC;AAAA,EAC3C;AAAA,EAEV,YAEE,SAEA,gBAAgB,oBAA6B;AAAA,IAC3C,QAAQ;AAAA,EACV,CAAC,GACD;AACA,aAAS,QAAQ,CAAC,WAAW,KAAK,SAAS,MAAM,CAAC;AAClD,SAAK,gBAAgB;AAAA,EACvB;AAAA;AAAA,EAGA,UAAU;AACR,UAAM,SAA0B,CAAC;AACjC,WAAO,OAAO,KAAK,QAAQ,EAAE,QAAQ,CAAC,UAAU;AAC9C,aAAO,KAAK,KAAK;AAAA,IACnB,CAAC;AACD,WAAO;AAAA,EACT;AAAA,EAEA,SAAwD,QAAiB;AACvE,SAAK,SAAS,OAAO,MAAM,IAAI;AAE/B,WAAO;AAAA,EACT;AAAA,EAIA,QAAQ,OAAoD;AAC1D,WAAO,QAAQ,KAAK,SAAS,OAAO,UAAU,WAAW,QAAQ,MAAM,MAAM,KAAK,KAAK,gBAAgB,KAAK;AAAA,EAC9G;AAAA;AAAA,EAGA,UAAU;AACR,UAAM,SAAmB,CAAC;AAC1B,WAAO,OAAO,KAAK,QAAQ,EAAE,QAAQ,CAAC,UAAU;AAC9C,aAAO,KAAK,MAAM,MAAM;AAAA,IAC1B,CAAC;AACD,WAAO;AAAA,EACT;AAAA,EAEA,SAAS,SAAkD;AACzD,WAAO,KAAK,QAAQ,OAAO,EAAE,WAAW,OAAO;AAAA,EACjD;AAAA,EAEA,KAAK,SAAuD;AAC1D,WAAO,KAAK,QAAQ,OAAO,EAAE,OAAO,OAAO;AAAA,EAC7C;AACF;","names":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { PayloadPlugin } from './Plugin';
|
|
2
|
+
export declare const defaultPayloadPluginFunctions: <T extends {
|
|
3
|
+
schema: string;
|
|
4
|
+
} & import("@xyo-network/payload-model").PayloadFields>(schema: string) => PayloadPlugin<T>;
|
|
5
|
+
export declare const createPayloadPlugin: <TPayload extends {
|
|
6
|
+
schema: string;
|
|
7
|
+
} & import("@xyo-network/payload-model").PayloadFields = {
|
|
8
|
+
schema: string;
|
|
9
|
+
} & import("@xyo-network/payload-model").PayloadFields>(plugin: PayloadPlugin<TPayload>) => PayloadPlugin<TPayload>;
|
|
10
|
+
//# sourceMappingURL=createPlugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
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;;gEAA+B,MAAM,qBAa9E,CAAA;AAED,eAAO,MAAM,mBAAmB;;;;mHAK/B,CAAA"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
// src/createPlugin.ts
|
|
2
1
|
import { assertEx } from "@xylabs/assert";
|
|
3
2
|
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
4
3
|
import { PayloadValidator } from "@xyo-network/payload-validator";
|
|
5
4
|
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
6
|
-
|
|
5
|
+
const defaultPayloadPluginFunctions = (schema) => {
|
|
7
6
|
return {
|
|
8
7
|
build: () => {
|
|
9
8
|
return new PayloadBuilder({ schema });
|
|
@@ -17,7 +16,7 @@ var defaultPayloadPluginFunctions = (schema) => {
|
|
|
17
16
|
}
|
|
18
17
|
};
|
|
19
18
|
};
|
|
20
|
-
|
|
19
|
+
const createPayloadPlugin = (plugin) => {
|
|
21
20
|
return {
|
|
22
21
|
...defaultPayloadPluginFunctions(assertEx(plugin.schema, "schema field required to create plugin")),
|
|
23
22
|
...plugin
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/createPlugin.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { PayloadPlugin } from './Plugin'\n\nexport const defaultPayloadPluginFunctions = <T extends Payload>(schema: string): PayloadPlugin<T> => {\n return {\n build: (): PayloadBuilder<T> => {\n return new PayloadBuilder<T>({ schema })\n },\n schema,\n validate: (payload: Payload): PayloadValidator<T> => {\n return new PayloadValidator<T>(payload as T)\n },\n wrap: (payload: Payload): PayloadWrapper<T> => {\n return PayloadWrapper.wrap<T>(payload as T)\n },\n }\n}\n\nexport const createPayloadPlugin = <TPayload extends Payload = Payload>(plugin: PayloadPlugin<TPayload>): PayloadPlugin<TPayload> => {\n return {\n ...defaultPayloadPluginFunctions<TPayload>(assertEx(plugin.schema, 'schema field required to create plugin')),\n ...plugin,\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/createPlugin.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { PayloadPlugin } from './Plugin'\n\nexport const defaultPayloadPluginFunctions = <T extends Payload>(schema: string): PayloadPlugin<T> => {\n return {\n build: (): PayloadBuilder<T> => {\n return new PayloadBuilder<T>({ schema })\n },\n schema,\n validate: (payload: Payload): PayloadValidator<T> => {\n return new PayloadValidator<T>(payload as T)\n },\n wrap: (payload: Payload): PayloadWrapper<T> => {\n return PayloadWrapper.wrap<T>(payload as T)\n },\n }\n}\n\nexport const createPayloadPlugin = <TPayload extends Payload = Payload>(plugin: PayloadPlugin<TPayload>): PayloadPlugin<TPayload> => {\n return {\n ...defaultPayloadPluginFunctions<TPayload>(assertEx(plugin.schema, 'schema field required to create plugin')),\n ...plugin,\n }\n}\n"],"mappings":"AAAA,SAAS,gBAAgB;AACzB,SAAS,sBAAsB;AAE/B,SAAS,wBAAwB;AACjC,SAAS,sBAAsB;AAIxB,MAAM,gCAAgC,CAAoB,WAAqC;AACpG,SAAO;AAAA,IACL,OAAO,MAAyB;AAC9B,aAAO,IAAI,eAAkB,EAAE,OAAO,CAAC;AAAA,IACzC;AAAA,IACA;AAAA,IACA,UAAU,CAAC,YAA0C;AACnD,aAAO,IAAI,iBAAoB,OAAY;AAAA,IAC7C;AAAA,IACA,MAAM,CAAC,YAAwC;AAC7C,aAAO,eAAe,KAAQ,OAAY;AAAA,IAC5C;AAAA,EACF;AACF;AAEO,MAAM,sBAAsB,CAAqC,WAA6D;AACnI,SAAO;AAAA,IACL,GAAG,8BAAwC,SAAS,OAAO,QAAQ,wCAAwC,CAAC;AAAA,IAC5G,GAAG;AAAA,EACL;AACF;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,UAAU,CAAA;AACxB,cAAc,YAAY,CAAA"}
|
package/dist/browser/index.js
CHANGED
|
@@ -1,74 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
import { PayloadValidator } from "@xyo-network/payload-validator";
|
|
5
|
-
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
6
|
-
var defaultPayloadPluginFunctions = (schema) => {
|
|
7
|
-
return {
|
|
8
|
-
build: () => {
|
|
9
|
-
return new PayloadBuilder({ schema });
|
|
10
|
-
},
|
|
11
|
-
schema,
|
|
12
|
-
validate: (payload) => {
|
|
13
|
-
return new PayloadValidator(payload);
|
|
14
|
-
},
|
|
15
|
-
wrap: (payload) => {
|
|
16
|
-
return PayloadWrapper.wrap(payload);
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
};
|
|
20
|
-
var createPayloadPlugin = (plugin) => {
|
|
21
|
-
return {
|
|
22
|
-
...defaultPayloadPluginFunctions(assertEx(plugin.schema, "schema field required to create plugin")),
|
|
23
|
-
...plugin
|
|
24
|
-
};
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
// src/Resolver.ts
|
|
28
|
-
import { PayloadSchema } from "@xyo-network/payload-model";
|
|
29
|
-
var PayloadPluginResolver = class {
|
|
30
|
-
schema = PayloadSchema;
|
|
31
|
-
_plugins = {};
|
|
32
|
-
defaultPlugin;
|
|
33
|
-
constructor(plugins, defaultPlugin = createPayloadPlugin({
|
|
34
|
-
schema: PayloadSchema
|
|
35
|
-
})) {
|
|
36
|
-
plugins?.forEach((plugin) => this.register(plugin));
|
|
37
|
-
this.defaultPlugin = defaultPlugin;
|
|
38
|
-
}
|
|
39
|
-
/** @description Create list of plugins, optionally filtered by ability to witness/divine */
|
|
40
|
-
plugins() {
|
|
41
|
-
const result = [];
|
|
42
|
-
Object.values(this._plugins).forEach((value) => {
|
|
43
|
-
result.push(value);
|
|
44
|
-
});
|
|
45
|
-
return result;
|
|
46
|
-
}
|
|
47
|
-
register(plugin) {
|
|
48
|
-
this._plugins[plugin.schema] = plugin;
|
|
49
|
-
return this;
|
|
50
|
-
}
|
|
51
|
-
resolve(value) {
|
|
52
|
-
return value ? this._plugins[typeof value === "string" ? value : value.schema] ?? this.defaultPlugin : this.defaultPlugin;
|
|
53
|
-
}
|
|
54
|
-
/** @description Create list of schema, optionally filtered by ability to witness/divine */
|
|
55
|
-
schemas() {
|
|
56
|
-
const result = [];
|
|
57
|
-
Object.values(this._plugins).forEach((value) => {
|
|
58
|
-
result.push(value.schema);
|
|
59
|
-
});
|
|
60
|
-
return result;
|
|
61
|
-
}
|
|
62
|
-
validate(payload) {
|
|
63
|
-
return this.resolve(payload).validate?.(payload);
|
|
64
|
-
}
|
|
65
|
-
wrap(payload) {
|
|
66
|
-
return this.resolve(payload).wrap?.(payload);
|
|
67
|
-
}
|
|
68
|
-
};
|
|
69
|
-
export {
|
|
70
|
-
PayloadPluginResolver,
|
|
71
|
-
createPayloadPlugin,
|
|
72
|
-
defaultPayloadPluginFunctions
|
|
73
|
-
};
|
|
1
|
+
export * from "./createPlugin";
|
|
2
|
+
export * from "./Plugin";
|
|
3
|
+
export * from "./Resolver";
|
|
74
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["export * from './createPlugin'\nexport * from './Plugin'\nexport * from './Resolver'\n"],"mappings":"AAAA,cAAc;AACd,cAAc;AACd,cAAc;","names":[]}
|