@xyo-network/diviner-jsonpath-memory 2.103.9 → 2.104.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/index.cjs +2 -4
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +2 -4
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/index.cjs +2 -4
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.js +2 -4
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/index.cjs +3 -8
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +3 -8
- package/dist/node/index.js.map +1 -1
- package/package.json +11 -11
package/dist/browser/index.cjs
CHANGED
|
@@ -51,8 +51,7 @@ var toPayloadTransformer = /* @__PURE__ */ __name((transformExpression) => {
|
|
|
51
51
|
const source = import_jsonpath.default.value(x, sourcePathExpression);
|
|
52
52
|
const transformed = {};
|
|
53
53
|
const destinationValue = source === void 0 ? defaultValue : source;
|
|
54
|
-
if (destinationValue !== void 0)
|
|
55
|
-
transformed[destinationField] = destinationValue;
|
|
54
|
+
if (destinationValue !== void 0) transformed[destinationField] = destinationValue;
|
|
56
55
|
return transformed;
|
|
57
56
|
}, "transformer");
|
|
58
57
|
return transformer;
|
|
@@ -87,8 +86,7 @@ var JsonPathDiviner = class extends import_diviner_abstract.AbstractDiviner {
|
|
|
87
86
|
return this._transforms;
|
|
88
87
|
}
|
|
89
88
|
async divineHandler(payloads) {
|
|
90
|
-
if (!payloads)
|
|
91
|
-
return [];
|
|
89
|
+
if (!payloads) return [];
|
|
92
90
|
const results = await Promise.all(payloads.map(async (payload) => {
|
|
93
91
|
const fields = this.transforms.map((transform) => transform(payload));
|
|
94
92
|
const sources = await import_payload_builder.PayloadBuilder.dataHashes([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './jsonpath'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;ACAA,oBAAyB;AACzB,8BAAgC;AAChC,oCAAuF;AAEvF,6BAA8C;AAC9C,2BAA+C;;;ACH/C,sBAAqB;AAOd,IAAMA,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,gBAAAA,QAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './jsonpath'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;ACAA,oBAAyB;AACzB,8BAAgC;AAChC,oCAAuF;AAEvF,6BAA8C;AAC9C,2BAA+C;;;ACH/C,sBAAqB;AAOd,IAAMA,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,gBAAAA,QAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC,OAAWF,aAAYP,gBAAAA,IAAoBQ;AACpE,WAAOD;EACT,GAPwC;AAQxC,SAAOL;AACT,GAXoC;;;ADA7B,IAAMQ,kBAAN,cASGC,wCAAAA;EAlBV,OAkBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAE7CE;;;;EAKV,IAAcC,oBAA4B;AACxC,WAAO,KAAKC,OAAOD,qBAAqBE;EAC1C;;;;;EAKA,IAAcC,aAAmC;AAC/C,QAAI,CAAC,KAAKJ,aAAa;AACrB,YAAMI,iBAAaC,wBAAS,KAAKH,OAAOE,YAAY,MAAM,kCAAA;AAC1D,WAAKJ,cAAcI,WAAWE,IAAIC,oBAAAA;IACpC;AACA,WAAO,KAAKP;EACd;EAEA,MAAyBQ,cAAcC,UAAmC;AACxE,QAAI,CAACA,SAAU,QAAO,CAAA;AAEtB,UAAMC,UAAU,MAAMC,QAAQC,IAC5BH,SAASH,IAAmB,OAAOO,YAAAA;AAEjC,YAAMC,SAAS,KAAKV,WAAWE,IAAI,CAACS,cAAcA,UAAUF,OAAAA,CAAAA;AAE5D,YAAMG,UAAU,MAAMC,sCAAeC,WAAW;QAACL;OAAQ;AAEzD,aAAO,MAAM,IAAII,sCAAqB;QAAEE,QAAQ,KAAKlB;MAAkB,CAAA,EAAGa,OAAOM,OAAOC,OAAO;QAAEL;MAAQ,GAAA,GAAMF,MAAAA,CAAAA,EAASQ,MAAK;IAC/H,CAAA,CAAA;AAEF,WAAOZ;EACT;AACF;","names":["toPayloadTransformer","transformExpression","defaultValue","destinationField","sourcePathExpression","transformer","x","source","jsonpath","value","transformed","destinationValue","undefined","JsonPathDiviner","AbstractDiviner","configSchemas","JsonPathDivinerConfigSchema","defaultConfigSchema","_transforms","destinationSchema","config","PayloadSchema","transforms","assertEx","map","toPayloadTransformer","divineHandler","payloads","results","Promise","all","payload","fields","transform","sources","PayloadBuilder","dataHashes","schema","Object","assign","build"]}
|
package/dist/browser/index.js
CHANGED
|
@@ -16,8 +16,7 @@ var toPayloadTransformer = /* @__PURE__ */ __name((transformExpression) => {
|
|
|
16
16
|
const source = jsonpath.value(x, sourcePathExpression);
|
|
17
17
|
const transformed = {};
|
|
18
18
|
const destinationValue = source === void 0 ? defaultValue : source;
|
|
19
|
-
if (destinationValue !== void 0)
|
|
20
|
-
transformed[destinationField] = destinationValue;
|
|
19
|
+
if (destinationValue !== void 0) transformed[destinationField] = destinationValue;
|
|
21
20
|
return transformed;
|
|
22
21
|
}, "transformer");
|
|
23
22
|
return transformer;
|
|
@@ -52,8 +51,7 @@ var JsonPathDiviner = class extends AbstractDiviner {
|
|
|
52
51
|
return this._transforms;
|
|
53
52
|
}
|
|
54
53
|
async divineHandler(payloads) {
|
|
55
|
-
if (!payloads)
|
|
56
|
-
return [];
|
|
54
|
+
if (!payloads) return [];
|
|
57
55
|
const results = await Promise.all(payloads.map(async (payload) => {
|
|
58
56
|
const fields = this.transforms.map((transform) => transform(payload));
|
|
59
57
|
const sources = await PayloadBuilder.dataHashes([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,uBAAuB;AAChC,SAASC,mCAA8E;AAEvF,SAASC,sBAAqC;AAC9C,SAAkBC,qBAA6B;;;ACH/C,OAAOC,cAAc;AAOd,IAAMC,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,SAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC
|
|
1
|
+
{"version":3,"sources":["../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,uBAAuB;AAChC,SAASC,mCAA8E;AAEvF,SAASC,sBAAqC;AAC9C,SAAkBC,qBAA6B;;;ACH/C,OAAOC,cAAc;AAOd,IAAMC,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,SAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC,OAAWF,aAAYP,gBAAAA,IAAoBQ;AACpE,WAAOD;EACT,GAPwC;AAQxC,SAAOL;AACT,GAXoC;;;ADA7B,IAAMQ,kBAAN,cASGC,gBAAAA;EAlBV,OAkBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAE7CE;;;;EAKV,IAAcC,oBAA4B;AACxC,WAAO,KAAKC,OAAOD,qBAAqBE;EAC1C;;;;;EAKA,IAAcC,aAAmC;AAC/C,QAAI,CAAC,KAAKJ,aAAa;AACrB,YAAMI,aAAaC,SAAS,KAAKH,OAAOE,YAAY,MAAM,kCAAA;AAC1D,WAAKJ,cAAcI,WAAWE,IAAIC,oBAAAA;IACpC;AACA,WAAO,KAAKP;EACd;EAEA,MAAyBQ,cAAcC,UAAmC;AACxE,QAAI,CAACA,SAAU,QAAO,CAAA;AAEtB,UAAMC,UAAU,MAAMC,QAAQC,IAC5BH,SAASH,IAAmB,OAAOO,YAAAA;AAEjC,YAAMC,SAAS,KAAKV,WAAWE,IAAI,CAACS,cAAcA,UAAUF,OAAAA,CAAAA;AAE5D,YAAMG,UAAU,MAAMC,eAAeC,WAAW;QAACL;OAAQ;AAEzD,aAAO,MAAM,IAAII,eAAqB;QAAEE,QAAQ,KAAKlB;MAAkB,CAAA,EAAGa,OAAOM,OAAOC,OAAO;QAAEL;MAAQ,GAAA,GAAMF,MAAAA,CAAAA,EAASQ,MAAK;IAC/H,CAAA,CAAA;AAEF,WAAOZ;EACT;AACF;","names":["assertEx","AbstractDiviner","JsonPathDivinerConfigSchema","PayloadBuilder","PayloadSchema","jsonpath","toPayloadTransformer","transformExpression","defaultValue","destinationField","sourcePathExpression","transformer","x","source","jsonpath","value","transformed","destinationValue","undefined","JsonPathDiviner","AbstractDiviner","configSchemas","JsonPathDivinerConfigSchema","defaultConfigSchema","_transforms","destinationSchema","config","PayloadSchema","transforms","assertEx","map","toPayloadTransformer","divineHandler","payloads","results","Promise","all","payload","fields","transform","sources","PayloadBuilder","dataHashes","schema","Object","assign","build"]}
|
package/dist/neutral/index.cjs
CHANGED
|
@@ -51,8 +51,7 @@ var toPayloadTransformer = /* @__PURE__ */ __name((transformExpression) => {
|
|
|
51
51
|
const source = import_jsonpath.default.value(x, sourcePathExpression);
|
|
52
52
|
const transformed = {};
|
|
53
53
|
const destinationValue = source === void 0 ? defaultValue : source;
|
|
54
|
-
if (destinationValue !== void 0)
|
|
55
|
-
transformed[destinationField] = destinationValue;
|
|
54
|
+
if (destinationValue !== void 0) transformed[destinationField] = destinationValue;
|
|
56
55
|
return transformed;
|
|
57
56
|
}, "transformer");
|
|
58
57
|
return transformer;
|
|
@@ -87,8 +86,7 @@ var JsonPathDiviner = class extends import_diviner_abstract.AbstractDiviner {
|
|
|
87
86
|
return this._transforms;
|
|
88
87
|
}
|
|
89
88
|
async divineHandler(payloads) {
|
|
90
|
-
if (!payloads)
|
|
91
|
-
return [];
|
|
89
|
+
if (!payloads) return [];
|
|
92
90
|
const results = await Promise.all(payloads.map(async (payload) => {
|
|
93
91
|
const fields = this.transforms.map((transform) => transform(payload));
|
|
94
92
|
const sources = await import_payload_builder.PayloadBuilder.dataHashes([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './jsonpath'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;ACAA,oBAAyB;AACzB,8BAAgC;AAChC,oCAAuF;AAEvF,6BAA8C;AAC9C,2BAA+C;;;ACH/C,sBAAqB;AAOd,IAAMA,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,gBAAAA,QAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './jsonpath'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;ACAA,oBAAyB;AACzB,8BAAgC;AAChC,oCAAuF;AAEvF,6BAA8C;AAC9C,2BAA+C;;;ACH/C,sBAAqB;AAOd,IAAMA,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,gBAAAA,QAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC,OAAWF,aAAYP,gBAAAA,IAAoBQ;AACpE,WAAOD;EACT,GAPwC;AAQxC,SAAOL;AACT,GAXoC;;;ADA7B,IAAMQ,kBAAN,cASGC,wCAAAA;EAlBV,OAkBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAE7CE;;;;EAKV,IAAcC,oBAA4B;AACxC,WAAO,KAAKC,OAAOD,qBAAqBE;EAC1C;;;;;EAKA,IAAcC,aAAmC;AAC/C,QAAI,CAAC,KAAKJ,aAAa;AACrB,YAAMI,iBAAaC,wBAAS,KAAKH,OAAOE,YAAY,MAAM,kCAAA;AAC1D,WAAKJ,cAAcI,WAAWE,IAAIC,oBAAAA;IACpC;AACA,WAAO,KAAKP;EACd;EAEA,MAAyBQ,cAAcC,UAAmC;AACxE,QAAI,CAACA,SAAU,QAAO,CAAA;AAEtB,UAAMC,UAAU,MAAMC,QAAQC,IAC5BH,SAASH,IAAmB,OAAOO,YAAAA;AAEjC,YAAMC,SAAS,KAAKV,WAAWE,IAAI,CAACS,cAAcA,UAAUF,OAAAA,CAAAA;AAE5D,YAAMG,UAAU,MAAMC,sCAAeC,WAAW;QAACL;OAAQ;AAEzD,aAAO,MAAM,IAAII,sCAAqB;QAAEE,QAAQ,KAAKlB;MAAkB,CAAA,EAAGa,OAAOM,OAAOC,OAAO;QAAEL;MAAQ,GAAA,GAAMF,MAAAA,CAAAA,EAASQ,MAAK;IAC/H,CAAA,CAAA;AAEF,WAAOZ;EACT;AACF;","names":["toPayloadTransformer","transformExpression","defaultValue","destinationField","sourcePathExpression","transformer","x","source","jsonpath","value","transformed","destinationValue","undefined","JsonPathDiviner","AbstractDiviner","configSchemas","JsonPathDivinerConfigSchema","defaultConfigSchema","_transforms","destinationSchema","config","PayloadSchema","transforms","assertEx","map","toPayloadTransformer","divineHandler","payloads","results","Promise","all","payload","fields","transform","sources","PayloadBuilder","dataHashes","schema","Object","assign","build"]}
|
package/dist/neutral/index.js
CHANGED
|
@@ -16,8 +16,7 @@ var toPayloadTransformer = /* @__PURE__ */ __name((transformExpression) => {
|
|
|
16
16
|
const source = jsonpath.value(x, sourcePathExpression);
|
|
17
17
|
const transformed = {};
|
|
18
18
|
const destinationValue = source === void 0 ? defaultValue : source;
|
|
19
|
-
if (destinationValue !== void 0)
|
|
20
|
-
transformed[destinationField] = destinationValue;
|
|
19
|
+
if (destinationValue !== void 0) transformed[destinationField] = destinationValue;
|
|
21
20
|
return transformed;
|
|
22
21
|
}, "transformer");
|
|
23
22
|
return transformer;
|
|
@@ -52,8 +51,7 @@ var JsonPathDiviner = class extends AbstractDiviner {
|
|
|
52
51
|
return this._transforms;
|
|
53
52
|
}
|
|
54
53
|
async divineHandler(payloads) {
|
|
55
|
-
if (!payloads)
|
|
56
|
-
return [];
|
|
54
|
+
if (!payloads) return [];
|
|
57
55
|
const results = await Promise.all(payloads.map(async (payload) => {
|
|
58
56
|
const fields = this.transforms.map((transform) => transform(payload));
|
|
59
57
|
const sources = await PayloadBuilder.dataHashes([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,uBAAuB;AAChC,SAASC,mCAA8E;AAEvF,SAASC,sBAAqC;AAC9C,SAAkBC,qBAA6B;;;ACH/C,OAAOC,cAAc;AAOd,IAAMC,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,SAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC
|
|
1
|
+
{"version":3,"sources":["../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,uBAAuB;AAChC,SAASC,mCAA8E;AAEvF,SAASC,sBAAqC;AAC9C,SAAkBC,qBAA6B;;;ACH/C,OAAOC,cAAc;AAOd,IAAMC,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,SAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC,OAAWF,aAAYP,gBAAAA,IAAoBQ;AACpE,WAAOD;EACT,GAPwC;AAQxC,SAAOL;AACT,GAXoC;;;ADA7B,IAAMQ,kBAAN,cASGC,gBAAAA;EAlBV,OAkBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAE7CE;;;;EAKV,IAAcC,oBAA4B;AACxC,WAAO,KAAKC,OAAOD,qBAAqBE;EAC1C;;;;;EAKA,IAAcC,aAAmC;AAC/C,QAAI,CAAC,KAAKJ,aAAa;AACrB,YAAMI,aAAaC,SAAS,KAAKH,OAAOE,YAAY,MAAM,kCAAA;AAC1D,WAAKJ,cAAcI,WAAWE,IAAIC,oBAAAA;IACpC;AACA,WAAO,KAAKP;EACd;EAEA,MAAyBQ,cAAcC,UAAmC;AACxE,QAAI,CAACA,SAAU,QAAO,CAAA;AAEtB,UAAMC,UAAU,MAAMC,QAAQC,IAC5BH,SAASH,IAAmB,OAAOO,YAAAA;AAEjC,YAAMC,SAAS,KAAKV,WAAWE,IAAI,CAACS,cAAcA,UAAUF,OAAAA,CAAAA;AAE5D,YAAMG,UAAU,MAAMC,eAAeC,WAAW;QAACL;OAAQ;AAEzD,aAAO,MAAM,IAAII,eAAqB;QAAEE,QAAQ,KAAKlB;MAAkB,CAAA,EAAGa,OAAOM,OAAOC,OAAO;QAAEL;MAAQ,GAAA,GAAMF,MAAAA,CAAAA,EAASQ,MAAK;IAC/H,CAAA,CAAA;AAEF,WAAOZ;EACT;AACF;","names":["assertEx","AbstractDiviner","JsonPathDivinerConfigSchema","PayloadBuilder","PayloadSchema","jsonpath","toPayloadTransformer","transformExpression","defaultValue","destinationField","sourcePathExpression","transformer","x","source","jsonpath","value","transformed","destinationValue","undefined","JsonPathDiviner","AbstractDiviner","configSchemas","JsonPathDivinerConfigSchema","defaultConfigSchema","_transforms","destinationSchema","config","PayloadSchema","transforms","assertEx","map","toPayloadTransformer","divineHandler","payloads","results","Promise","all","payload","fields","transform","sources","PayloadBuilder","dataHashes","schema","Object","assign","build"]}
|
package/dist/node/index.cjs
CHANGED
|
@@ -29,10 +29,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
29
29
|
mod
|
|
30
30
|
));
|
|
31
31
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
32
|
-
var __publicField = (obj, key, value) =>
|
|
33
|
-
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
34
|
-
return value;
|
|
35
|
-
};
|
|
32
|
+
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
36
33
|
var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
37
34
|
|
|
38
35
|
// src/index.ts
|
|
@@ -58,8 +55,7 @@ var toPayloadTransformer = /* @__PURE__ */ __name((transformExpression) => {
|
|
|
58
55
|
const source = import_jsonpath.default.value(x, sourcePathExpression);
|
|
59
56
|
const transformed = {};
|
|
60
57
|
const destinationValue = source === void 0 ? defaultValue : source;
|
|
61
|
-
if (destinationValue !== void 0)
|
|
62
|
-
transformed[destinationField] = destinationValue;
|
|
58
|
+
if (destinationValue !== void 0) transformed[destinationField] = destinationValue;
|
|
63
59
|
return transformed;
|
|
64
60
|
}, "transformer");
|
|
65
61
|
return transformer;
|
|
@@ -86,8 +82,7 @@ var _JsonPathDiviner = class _JsonPathDiviner extends import_diviner_abstract.Ab
|
|
|
86
82
|
return this._transforms;
|
|
87
83
|
}
|
|
88
84
|
async divineHandler(payloads) {
|
|
89
|
-
if (!payloads)
|
|
90
|
-
return [];
|
|
85
|
+
if (!payloads) return [];
|
|
91
86
|
const results = await Promise.all(payloads.map(async (payload) => {
|
|
92
87
|
const fields = this.transforms.map((transform) => transform(payload));
|
|
93
88
|
const sources = await import_payload_builder.PayloadBuilder.dataHashes([
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './jsonpath'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './jsonpath'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;ACAA,oBAAyB;AACzB,8BAAgC;AAChC,oCAAuF;AAEvF,6BAA8C;AAC9C,2BAA+C;;;ACH/C,sBAAqB;AAOd,IAAMA,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,gBAAAA,QAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC,OAAWF,aAAYP,gBAAAA,IAAoBQ;AACpE,WAAOD;EACT,GAPwC;AAQxC,SAAOL;AACT,GAXoC;;;ADA7B,IAAMQ,mBAAN,MAAMA,yBASHC,wCAAAA;EAIEC;;;;EAKV,IAAcC,oBAA4B;AACxC,WAAO,KAAKC,OAAOD,qBAAqBE;EAC1C;;;;;EAKA,IAAcC,aAAmC;AAC/C,QAAI,CAAC,KAAKJ,aAAa;AACrB,YAAMI,iBAAaC,wBAAS,KAAKH,OAAOE,YAAY,MAAM,kCAAA;AAC1D,WAAKJ,cAAcI,WAAWE,IAAIC,oBAAAA;IACpC;AACA,WAAO,KAAKP;EACd;EAEA,MAAyBQ,cAAcC,UAAmC;AACxE,QAAI,CAACA,SAAU,QAAO,CAAA;AAEtB,UAAMC,UAAU,MAAMC,QAAQC,IAC5BH,SAASH,IAAmB,OAAOO,YAAAA;AAEjC,YAAMC,SAAS,KAAKV,WAAWE,IAAI,CAACS,cAAcA,UAAUF,OAAAA,CAAAA;AAE5D,YAAMG,UAAU,MAAMC,sCAAeC,WAAW;QAACL;OAAQ;AAEzD,aAAO,MAAM,IAAII,sCAAqB;QAAEE,QAAQ,KAAKlB;MAAkB,CAAA,EAAGa,OAAOM,OAAOC,OAAO;QAAEL;MAAQ,GAAA,GAAMF,MAAAA,CAAAA,EAASQ,MAAK;IAC/H,CAAA,CAAA;AAEF,WAAOZ;EACT;AACF;AAvCUX;AACR,cAVWD,kBAUcyB,iBAA0B;KAAI,+CAAMA;EAAeC;;AAC5E,cAXW1B,kBAWc2B,uBAA8BD;AAXlD,IAAM1B,kBAAN;","names":["toPayloadTransformer","transformExpression","defaultValue","destinationField","sourcePathExpression","transformer","x","source","jsonpath","value","transformed","destinationValue","undefined","JsonPathDiviner","AbstractDiviner","_transforms","destinationSchema","config","PayloadSchema","transforms","assertEx","map","toPayloadTransformer","divineHandler","payloads","results","Promise","all","payload","fields","transform","sources","PayloadBuilder","dataHashes","schema","Object","assign","build","configSchemas","JsonPathDivinerConfigSchema","defaultConfigSchema"]}
|
package/dist/node/index.js
CHANGED
|
@@ -3,10 +3,7 @@ var __getProtoOf = Object.getPrototypeOf;
|
|
|
3
3
|
var __reflectGet = Reflect.get;
|
|
4
4
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
5
5
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
-
var __publicField = (obj, key, value) =>
|
|
7
|
-
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
8
|
-
return value;
|
|
9
|
-
};
|
|
6
|
+
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
10
7
|
var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
11
8
|
|
|
12
9
|
// src/Diviner.ts
|
|
@@ -24,8 +21,7 @@ var toPayloadTransformer = /* @__PURE__ */ __name((transformExpression) => {
|
|
|
24
21
|
const source = jsonpath.value(x, sourcePathExpression);
|
|
25
22
|
const transformed = {};
|
|
26
23
|
const destinationValue = source === void 0 ? defaultValue : source;
|
|
27
|
-
if (destinationValue !== void 0)
|
|
28
|
-
transformed[destinationField] = destinationValue;
|
|
24
|
+
if (destinationValue !== void 0) transformed[destinationField] = destinationValue;
|
|
29
25
|
return transformed;
|
|
30
26
|
}, "transformer");
|
|
31
27
|
return transformer;
|
|
@@ -52,8 +48,7 @@ var _JsonPathDiviner = class _JsonPathDiviner extends AbstractDiviner {
|
|
|
52
48
|
return this._transforms;
|
|
53
49
|
}
|
|
54
50
|
async divineHandler(payloads) {
|
|
55
|
-
if (!payloads)
|
|
56
|
-
return [];
|
|
51
|
+
if (!payloads) return [];
|
|
57
52
|
const results = await Promise.all(payloads.map(async (payload) => {
|
|
58
53
|
const fields = this.transforms.map((transform) => transform(payload));
|
|
59
54
|
const sources = await PayloadBuilder.dataHashes([
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/Diviner.ts","../../src/jsonpath/toPayloadTransformer.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { JsonPathDivinerConfigSchema, JsonPathDivinerParams, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadBuilder, WithoutSchema } from '@xyo-network/payload-builder'\nimport { Payload, PayloadSchema, Schema } from '@xyo-network/payload-model'\n\nimport { toPayloadTransformer } from './jsonpath'\n\nexport class JsonPathDiviner<\n TParams extends JsonPathDivinerParams = JsonPathDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, JsonPathDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = JsonPathDivinerConfigSchema\n\n protected _transforms: PayloadTransformer[] | undefined\n\n /**\n * The schema to use for the destination payloads\n */\n protected get destinationSchema(): string {\n return this.config.destinationSchema ?? PayloadSchema\n }\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get transforms(): PayloadTransformer[] {\n if (!this._transforms) {\n const transforms = assertEx(this.config.transforms, () => 'config.transforms is not defined')\n this._transforms = transforms.map(toPayloadTransformer)\n }\n return this._transforms\n }\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n if (!payloads) return []\n // Create the indexes from the tuples\n const results = await Promise.all(\n payloads.map<Promise<TOut>>(async (payload) => {\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const fields = this.transforms.map((transform) => transform(payload)) as WithoutSchema<TOut>[]\n // Include all the sources for reference\n const sources = await PayloadBuilder.dataHashes([payload])\n // Build and return the index\n return await new PayloadBuilder<TOut>({ schema: this.destinationSchema }).fields(Object.assign({ sources }, ...fields)).build()\n }),\n )\n return results\n }\n}\n","import { JsonPathTransformExpression, PayloadTransformer } from '@xyo-network/diviner-jsonpath-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport jsonpath from 'jsonpath'\n\n/**\n * Converts a JSON Path transform expression to a payload transformer\n * @param transformExpression The transform expression to convert\n * @returns The payload transformer for the JSON Path transform expression\n */\nexport const toPayloadTransformer = (transformExpression: JsonPathTransformExpression) => {\n const { defaultValue, destinationField, sourcePathExpression } = transformExpression\n const transformer: PayloadTransformer = (x: Payload) => {\n const source = jsonpath.value(x, sourcePathExpression)\n const transformed: Record<string, unknown> = {}\n // Assign the source value to the destination field or the default value if the source is undefined\n const destinationValue = source === undefined ? defaultValue : source\n if (destinationValue !== undefined) transformed[destinationField] = destinationValue\n return transformed\n }\n return transformer\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,uBAAuB;AAChC,SAASC,mCAA8E;AAEvF,SAASC,sBAAqC;AAC9C,SAAkBC,qBAA6B;;;ACH/C,OAAOC,cAAc;AAOd,IAAMC,uBAAuB,wBAACC,wBAAAA;AACnC,QAAM,EAAEC,cAAcC,kBAAkBC,qBAAoB,IAAKH;AACjE,QAAMI,cAAkC,wBAACC,MAAAA;AACvC,UAAMC,SAASC,SAASC,MAAMH,GAAGF,oBAAAA;AACjC,UAAMM,cAAuC,CAAC;AAE9C,UAAMC,mBAAmBJ,WAAWK,SAAYV,eAAeK;AAC/D,QAAII,qBAAqBC,OAAWF,aAAYP,gBAAAA,IAAoBQ;AACpE,WAAOD;EACT,GAPwC;AAQxC,SAAOL;AACT,GAXoC;;;ADA7B,IAAMQ,mBAAN,MAAMA,yBASHC,gBAAAA;EAIEC;;;;EAKV,IAAcC,oBAA4B;AACxC,WAAO,KAAKC,OAAOD,qBAAqBE;EAC1C;;;;;EAKA,IAAcC,aAAmC;AAC/C,QAAI,CAAC,KAAKJ,aAAa;AACrB,YAAMI,aAAaC,SAAS,KAAKH,OAAOE,YAAY,MAAM,kCAAA;AAC1D,WAAKJ,cAAcI,WAAWE,IAAIC,oBAAAA;IACpC;AACA,WAAO,KAAKP;EACd;EAEA,MAAyBQ,cAAcC,UAAmC;AACxE,QAAI,CAACA,SAAU,QAAO,CAAA;AAEtB,UAAMC,UAAU,MAAMC,QAAQC,IAC5BH,SAASH,IAAmB,OAAOO,YAAAA;AAEjC,YAAMC,SAAS,KAAKV,WAAWE,IAAI,CAACS,cAAcA,UAAUF,OAAAA,CAAAA;AAE5D,YAAMG,UAAU,MAAMC,eAAeC,WAAW;QAACL;OAAQ;AAEzD,aAAO,MAAM,IAAII,eAAqB;QAAEE,QAAQ,KAAKlB;MAAkB,CAAA,EAAGa,OAAOM,OAAOC,OAAO;QAAEL;MAAQ,GAAA,GAAMF,MAAAA,CAAAA,EAASQ,MAAK;IAC/H,CAAA,CAAA;AAEF,WAAOZ;EACT;AACF;AAvCUX;AACR,cAVWD,kBAUcyB,iBAA0B;KAAI,+CAAMA;EAAeC;;AAC5E,cAXW1B,kBAWc2B,uBAA8BD;AAXlD,IAAM1B,kBAAN;","names":["assertEx","AbstractDiviner","JsonPathDivinerConfigSchema","PayloadBuilder","PayloadSchema","jsonpath","toPayloadTransformer","transformExpression","defaultValue","destinationField","sourcePathExpression","transformer","x","source","jsonpath","value","transformed","destinationValue","undefined","JsonPathDiviner","AbstractDiviner","_transforms","destinationSchema","config","PayloadSchema","transforms","assertEx","map","toPayloadTransformer","divineHandler","payloads","results","Promise","all","payload","fields","transform","sources","PayloadBuilder","dataHashes","schema","Object","assign","build","configSchemas","JsonPathDivinerConfigSchema","defaultConfigSchema"]}
|
package/package.json
CHANGED
|
@@ -10,19 +10,19 @@
|
|
|
10
10
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@xylabs/assert": "^3.5.
|
|
14
|
-
"@xyo-network/diviner-abstract": "~2.
|
|
15
|
-
"@xyo-network/diviner-jsonpath-model": "~2.
|
|
16
|
-
"@xyo-network/diviner-model": "~2.
|
|
17
|
-
"@xyo-network/payload-builder": "~2.
|
|
18
|
-
"@xyo-network/payload-model": "~2.
|
|
13
|
+
"@xylabs/assert": "^3.5.1",
|
|
14
|
+
"@xyo-network/diviner-abstract": "~2.104.1",
|
|
15
|
+
"@xyo-network/diviner-jsonpath-model": "~2.104.1",
|
|
16
|
+
"@xyo-network/diviner-model": "~2.104.1",
|
|
17
|
+
"@xyo-network/payload-builder": "~2.104.1",
|
|
18
|
+
"@xyo-network/payload-model": "~2.104.1",
|
|
19
19
|
"jsonpath": "^1.1.1"
|
|
20
20
|
},
|
|
21
21
|
"devDependencies": {
|
|
22
|
-
"@xylabs/ts-scripts-yarn3": "^3.
|
|
23
|
-
"@xylabs/tsconfig": "^3.
|
|
24
|
-
"@xyo-network/account": "~2.
|
|
25
|
-
"@xyo-network/wallet-model": "~2.
|
|
22
|
+
"@xylabs/ts-scripts-yarn3": "^3.11.2",
|
|
23
|
+
"@xylabs/tsconfig": "^3.11.2",
|
|
24
|
+
"@xyo-network/account": "~2.104.1",
|
|
25
|
+
"@xyo-network/wallet-model": "~2.104.1",
|
|
26
26
|
"typescript": "^5.4.5"
|
|
27
27
|
},
|
|
28
28
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
@@ -64,6 +64,6 @@
|
|
|
64
64
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
65
65
|
},
|
|
66
66
|
"sideEffects": false,
|
|
67
|
-
"version": "2.
|
|
67
|
+
"version": "2.104.1",
|
|
68
68
|
"type": "module"
|
|
69
69
|
}
|