@temporalio/common 0.21.0 → 1.0.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -3
- package/lib/converter/data-converter.d.ts +8 -4
- package/lib/converter/data-converter.js +3 -4
- package/lib/converter/data-converter.js.map +1 -1
- package/lib/converter/json-payload-converter.d.ts +10 -0
- package/lib/converter/json-payload-converter.js +39 -0
- package/lib/converter/json-payload-converter.js.map +1 -0
- package/lib/converter/patch-protobuf-root.d.ts +1 -8
- package/lib/converter/patch-protobuf-root.js +2 -39
- package/lib/converter/patch-protobuf-root.js.map +1 -1
- package/lib/converter/payload-codec.d.ts +0 -7
- package/lib/converter/payload-codec.js +0 -8
- package/lib/converter/payload-codec.js.map +1 -1
- package/lib/converter/payload-converter.d.ts +13 -44
- package/lib/converter/payload-converter.js +8 -85
- package/lib/converter/payload-converter.js.map +1 -1
- package/lib/converter/payload-converters.d.ts +48 -13
- package/lib/converter/payload-converters.js +74 -36
- package/lib/converter/payload-converters.js.map +1 -1
- package/lib/converter/protobuf-payload-converters.d.ts +1 -2
- package/lib/converter/protobuf-payload-converters.js +7 -5
- package/lib/converter/protobuf-payload-converters.js.map +1 -1
- package/lib/converter/search-attribute-payload-converter.d.ts +12 -0
- package/lib/converter/search-attribute-payload-converter.js +64 -0
- package/lib/converter/search-attribute-payload-converter.js.map +1 -0
- package/lib/converter/types.d.ts +1 -2
- package/lib/converter/types.js.map +1 -1
- package/lib/failure.d.ts +1 -1
- package/lib/failure.js +16 -5
- package/lib/failure.js.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.js +1 -0
- package/lib/index.js.map +1 -1
- package/lib/protobufs.d.ts +1 -1
- package/lib/protobufs.js +1 -1
- package/package.json +4 -4
- package/src/converter/data-converter.ts +12 -7
- package/src/converter/json-payload-converter.ts +37 -0
- package/src/converter/patch-protobuf-root.ts +1 -49
- package/src/converter/payload-codec.ts +0 -8
- package/src/converter/payload-converter.ts +17 -99
- package/src/converter/payload-converters.ts +99 -41
- package/src/converter/protobuf-payload-converters.ts +8 -4
- package/src/converter/search-attribute-payload-converter.ts +71 -0
- package/src/converter/types.ts +1 -2
- package/src/failure.ts +17 -7
- package/src/index.ts +1 -0
- package/src/protobufs.ts +1 -1
- package/tsconfig.tsbuildinfo +1 -1
package/README.md
CHANGED
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
[](https://www.npmjs.com/package/@temporalio/common)
|
|
4
4
|
|
|
5
|
-
Part of [Temporal](https://temporal.io)'s TypeScript SDK (see [docs](https://docs.temporal.io/
|
|
5
|
+
Part of [Temporal](https://temporal.io)'s TypeScript SDK (see [docs](https://docs.temporal.io/typescript/introduction/) and [samples](https://github.com/temporalio/samples-typescript)).
|
|
6
6
|
|
|
7
7
|
Common library for code that's used across the Client, Worker, and/or Workflow:
|
|
8
8
|
|
|
9
|
-
- [DataConverter docs](https://docs.temporal.io/
|
|
10
|
-
- [Failure docs](https://docs.temporal.io/
|
|
9
|
+
- [DataConverter docs](https://docs.temporal.io/typescript/data-converters)
|
|
10
|
+
- [Failure docs](https://docs.temporal.io/typescript/handling-failure)
|
|
11
11
|
- [API reference](https://typescript.temporal.io/api/namespaces/common)
|
|
@@ -7,7 +7,7 @@ import { PayloadConverter } from './payload-converter';
|
|
|
7
7
|
* The default `DataConverter` supports `undefined`, `Uint8Array`, and JSON serializables (so if
|
|
8
8
|
* [`JSON.stringify(yourArgOrRetval)`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description)
|
|
9
9
|
* works, the default data converter will work). Protobufs are supported via [this
|
|
10
|
-
* API](https://docs.temporal.io/
|
|
10
|
+
* API](https://docs.temporal.io/typescript/data-converters#protobufs).
|
|
11
11
|
*
|
|
12
12
|
* Use a custom `DataConverter` to control the contents of your {@link Payload}s. Common reasons for using a custom
|
|
13
13
|
* `DataConverter` are:
|
|
@@ -32,15 +32,19 @@ export interface DataConverter {
|
|
|
32
32
|
*/
|
|
33
33
|
payloadConverterPath?: string;
|
|
34
34
|
/**
|
|
35
|
-
*
|
|
35
|
+
* An array of {@link PayloadCodec} instances.
|
|
36
|
+
*
|
|
37
|
+
* Payloads are encoded in the order of the array and decoded in the opposite order. For example, if you have a
|
|
38
|
+
* compression codec and an encryption codec, then you want data to be encoded with the compression codec first, so
|
|
39
|
+
* you'd do `payloadCodecs: [compressionCodec, encryptionCodec]`.
|
|
36
40
|
*/
|
|
37
|
-
|
|
41
|
+
payloadCodecs?: PayloadCodec[];
|
|
38
42
|
}
|
|
39
43
|
/**
|
|
40
44
|
* A {@link DataConverter} that has been loaded via {@link loadDataConverter}.
|
|
41
45
|
*/
|
|
42
46
|
export interface LoadedDataConverter {
|
|
43
47
|
payloadConverter: PayloadConverter;
|
|
44
|
-
|
|
48
|
+
payloadCodecs: PayloadCodec[];
|
|
45
49
|
}
|
|
46
50
|
export declare const defaultDataConverter: LoadedDataConverter;
|
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.defaultDataConverter = void 0;
|
|
4
|
-
const
|
|
5
|
-
const payload_converter_1 = require("./payload-converter");
|
|
4
|
+
const payload_converters_1 = require("./payload-converters");
|
|
6
5
|
exports.defaultDataConverter = {
|
|
7
|
-
payloadConverter:
|
|
8
|
-
|
|
6
|
+
payloadConverter: payload_converters_1.defaultPayloadConverter,
|
|
7
|
+
payloadCodecs: [],
|
|
9
8
|
};
|
|
10
9
|
//# sourceMappingURL=data-converter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data-converter.js","sourceRoot":"","sources":["../../src/converter/data-converter.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"data-converter.js","sourceRoot":"","sources":["../../src/converter/data-converter.ts"],"names":[],"mappings":";;;AAEA,6DAA+D;AAoDlD,QAAA,oBAAoB,GAAwB;IACvD,gBAAgB,EAAE,4CAAuB;IACzC,aAAa,EAAE,EAAE;CAClB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { PayloadConverterWithEncoding } from './payload-converters';
|
|
2
|
+
import { Payload } from './types';
|
|
3
|
+
/**
|
|
4
|
+
* Converts between non-undefined values and serialized JSON Payload
|
|
5
|
+
*/
|
|
6
|
+
export declare class JsonPayloadConverter implements PayloadConverterWithEncoding {
|
|
7
|
+
encodingType: "json/plain";
|
|
8
|
+
toPayload(value: unknown): Payload | undefined;
|
|
9
|
+
fromPayload<T>(content: Payload): T;
|
|
10
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JsonPayloadConverter = void 0;
|
|
4
|
+
const internal_workflow_common_1 = require("@temporalio/internal-workflow-common");
|
|
5
|
+
const types_1 = require("./types");
|
|
6
|
+
/**
|
|
7
|
+
* Converts between non-undefined values and serialized JSON Payload
|
|
8
|
+
*/
|
|
9
|
+
class JsonPayloadConverter {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.encodingType = types_1.encodingTypes.METADATA_ENCODING_JSON;
|
|
12
|
+
}
|
|
13
|
+
toPayload(value) {
|
|
14
|
+
if (value === undefined) {
|
|
15
|
+
return undefined;
|
|
16
|
+
}
|
|
17
|
+
let json;
|
|
18
|
+
try {
|
|
19
|
+
json = JSON.stringify(value);
|
|
20
|
+
}
|
|
21
|
+
catch (e) {
|
|
22
|
+
return undefined;
|
|
23
|
+
}
|
|
24
|
+
return {
|
|
25
|
+
metadata: {
|
|
26
|
+
[types_1.METADATA_ENCODING_KEY]: types_1.encodingKeys.METADATA_ENCODING_JSON,
|
|
27
|
+
},
|
|
28
|
+
data: (0, types_1.u8)(json),
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
fromPayload(content) {
|
|
32
|
+
if (content.data === undefined || content.data === null) {
|
|
33
|
+
throw new internal_workflow_common_1.ValueError('Got payload with no data');
|
|
34
|
+
}
|
|
35
|
+
return JSON.parse((0, types_1.str)(content.data));
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
exports.JsonPayloadConverter = JsonPayloadConverter;
|
|
39
|
+
//# sourceMappingURL=json-payload-converter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"json-payload-converter.js","sourceRoot":"","sources":["../../src/converter/json-payload-converter.ts"],"names":[],"mappings":";;;AAAA,mFAAkE;AAElE,mCAA+F;AAE/F;;GAEG;AACH,MAAa,oBAAoB;IAAjC;QACS,iBAAY,GAAG,qBAAa,CAAC,sBAAsB,CAAC;IA4B7D,CAAC;IA1BQ,SAAS,CAAC,KAAc;QAC7B,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,IAAI,CAAC;QACT,IAAI;YACF,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAC9B;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,SAAS,CAAC;SAClB;QAED,OAAO;YACL,QAAQ,EAAE;gBACR,CAAC,6BAAqB,CAAC,EAAE,oBAAY,CAAC,sBAAsB;aAC7D;YACD,IAAI,EAAE,IAAA,UAAE,EAAC,IAAI,CAAC;SACf,CAAC;IACJ,CAAC;IAEM,WAAW,CAAI,OAAgB;QACpC,IAAI,OAAO,CAAC,IAAI,KAAK,SAAS,IAAI,OAAO,CAAC,IAAI,KAAK,IAAI,EAAE;YACvD,MAAM,IAAI,qCAAU,CAAC,0BAA0B,CAAC,CAAC;SAClD;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,IAAA,WAAG,EAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IACvC,CAAC;CACF;AA7BD,oDA6BC"}
|
|
@@ -1,8 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* Create a version of `root` with non-nested namespaces to match the generated types.
|
|
3
|
-
* For more information, see:
|
|
4
|
-
* https://github.com/temporalio/sdk-typescript/blob/main/docs/protobuf-libraries.md#current-solution
|
|
5
|
-
* @param root Generated by `pbjs -t json-module -w commonjs -o json-module.js *.proto`
|
|
6
|
-
* @returns A new patched `root`
|
|
7
|
-
*/
|
|
8
|
-
export declare function patchProtobufRoot<T extends Record<string, unknown>>(root: T): T;
|
|
1
|
+
export { patchProtobufRoot } from '@temporalio/proto/lib/patch-protobuf-root';
|
|
@@ -1,43 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.patchProtobufRoot = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
* Create a version of `root` with non-nested namespaces to match the generated types.
|
|
7
|
-
* For more information, see:
|
|
8
|
-
* https://github.com/temporalio/sdk-typescript/blob/main/docs/protobuf-libraries.md#current-solution
|
|
9
|
-
* @param root Generated by `pbjs -t json-module -w commonjs -o json-module.js *.proto`
|
|
10
|
-
* @returns A new patched `root`
|
|
11
|
-
*/
|
|
12
|
-
function patchProtobufRoot(root) {
|
|
13
|
-
return _patchProtobufRoot(root);
|
|
14
|
-
}
|
|
15
|
-
exports.patchProtobufRoot = patchProtobufRoot;
|
|
16
|
-
function _patchProtobufRoot(root, name) {
|
|
17
|
-
const newRoot = new root.constructor(isNamespace(root) ? name : {});
|
|
18
|
-
for (const key in root) {
|
|
19
|
-
newRoot[key] = root[key];
|
|
20
|
-
}
|
|
21
|
-
if ((0, internal_workflow_common_1.isRecord)(root.nested)) {
|
|
22
|
-
for (const typeOrNamespace in root.nested) {
|
|
23
|
-
const value = root.nested[typeOrNamespace];
|
|
24
|
-
if (typeOrNamespace in root && !(isType(root[typeOrNamespace]) || isNamespace(root[typeOrNamespace]))) {
|
|
25
|
-
console.log(`patchRoot warning: overriding property '${typeOrNamespace}' that is used by protobufjs with the '${typeOrNamespace}' protobuf namespace. This may result in protobufjs not working property.`);
|
|
26
|
-
}
|
|
27
|
-
if (isNamespace(value)) {
|
|
28
|
-
newRoot[typeOrNamespace] = _patchProtobufRoot(value, typeOrNamespace);
|
|
29
|
-
}
|
|
30
|
-
else if (isType(value)) {
|
|
31
|
-
newRoot[typeOrNamespace] = value;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
return newRoot;
|
|
36
|
-
}
|
|
37
|
-
function isType(value) {
|
|
38
|
-
return (0, internal_workflow_common_1.isRecord)(value) && value.constructor.name === 'Type';
|
|
39
|
-
}
|
|
40
|
-
function isNamespace(value) {
|
|
41
|
-
return (0, internal_workflow_common_1.isRecord)(value) && value.constructor.name === 'Namespace';
|
|
42
|
-
}
|
|
4
|
+
var patch_protobuf_root_1 = require("@temporalio/proto/lib/patch-protobuf-root");
|
|
5
|
+
Object.defineProperty(exports, "patchProtobufRoot", { enumerable: true, get: function () { return patch_protobuf_root_1.patchProtobufRoot; } });
|
|
43
6
|
//# sourceMappingURL=patch-protobuf-root.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"patch-protobuf-root.js","sourceRoot":"","sources":["../../src/converter/patch-protobuf-root.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"patch-protobuf-root.js","sourceRoot":"","sources":["../../src/converter/patch-protobuf-root.ts"],"names":[],"mappings":";;;AAAA,iFAA8E;AAArE,wHAAA,iBAAiB,OAAA"}
|
|
@@ -18,10 +18,3 @@ export interface PayloadCodec {
|
|
|
18
18
|
*/
|
|
19
19
|
decode(payloads: Payload[]): Promise<Payload[]>;
|
|
20
20
|
}
|
|
21
|
-
/**
|
|
22
|
-
* No-op implementation of {@link PayloadCodec}.
|
|
23
|
-
*/
|
|
24
|
-
export declare const defaultPayloadCodec: {
|
|
25
|
-
encode: (payloads: Payload[]) => Promise<Payload[]>;
|
|
26
|
-
decode: (payloads: Payload[]) => Promise<Payload[]>;
|
|
27
|
-
};
|
|
@@ -1,11 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.defaultPayloadCodec = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* No-op implementation of {@link PayloadCodec}.
|
|
6
|
-
*/
|
|
7
|
-
exports.defaultPayloadCodec = {
|
|
8
|
-
encode: async (payloads) => payloads,
|
|
9
|
-
decode: async (payloads) => payloads,
|
|
10
|
-
};
|
|
11
3
|
//# sourceMappingURL=payload-codec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"payload-codec.js","sourceRoot":"","sources":["../../src/converter/payload-codec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"payload-codec.js","sourceRoot":"","sources":["../../src/converter/payload-codec.ts"],"names":[],"mappings":""}
|
|
@@ -1,58 +1,40 @@
|
|
|
1
|
-
import { JsonPayloadConverter, PayloadConverterWithEncoding } from './payload-converters';
|
|
2
1
|
import { Payload } from './types';
|
|
3
2
|
/**
|
|
4
|
-
* Used by the framework to serialize/deserialize parameters and return values.
|
|
3
|
+
* Used by the framework to serialize/deserialize data like parameters and return values.
|
|
5
4
|
*
|
|
6
|
-
* This is called inside the [Workflow isolate](https://docs.temporal.io/
|
|
5
|
+
* This is called inside the [Workflow isolate](https://docs.temporal.io/typescript/determinism).
|
|
7
6
|
* To write async code or use Node APIs (or use packages that use Node APIs), use a {@link PayloadCodec}.
|
|
8
7
|
*/
|
|
9
8
|
export interface PayloadConverter {
|
|
10
9
|
/**
|
|
11
10
|
* Converts a value to a {@link Payload}.
|
|
12
|
-
* @param value The value to convert. Example values include the Workflow args sent by the client and the values returned by a Workflow or Activity.
|
|
13
|
-
*/
|
|
14
|
-
toPayload<T>(value: T): Payload | undefined;
|
|
15
|
-
/**
|
|
16
|
-
* Converts a {@link Payload} back to a value.
|
|
17
|
-
*/
|
|
18
|
-
fromPayload<T>(payload: Payload): T;
|
|
19
|
-
}
|
|
20
|
-
export declare class CompositePayloadConverter implements PayloadConverter {
|
|
21
|
-
readonly converters: PayloadConverterWithEncoding[];
|
|
22
|
-
readonly converterByEncoding: Map<string, PayloadConverterWithEncoding>;
|
|
23
|
-
constructor(...converters: PayloadConverterWithEncoding[]);
|
|
24
|
-
/**
|
|
25
|
-
* Tries to run `.toPayload(value)` on each converter in the order provided at construction.
|
|
26
|
-
* Returns the first successful result, or `undefined` if there is no converter that can handle the value.
|
|
27
11
|
*
|
|
28
|
-
* @
|
|
12
|
+
* @param value The value to convert. Example values include the Workflow args sent from the Client and the values returned by a Workflow or Activity.
|
|
13
|
+
*
|
|
14
|
+
* @returns The {@link Payload}.
|
|
15
|
+
*
|
|
16
|
+
* Should throw {@link ValueError} if unable to convert.
|
|
29
17
|
*/
|
|
30
|
-
toPayload<T>(value: T): Payload
|
|
18
|
+
toPayload<T>(value: T): Payload;
|
|
31
19
|
/**
|
|
32
|
-
*
|
|
20
|
+
* Converts a {@link Payload} back to a value.
|
|
33
21
|
*/
|
|
34
22
|
fromPayload<T>(payload: Payload): T;
|
|
35
23
|
}
|
|
36
|
-
/**
|
|
37
|
-
* Tries to convert `value` to a {@link Payload}. Throws if conversion fails.
|
|
38
|
-
*
|
|
39
|
-
* @throws {@link PayloadConverterError}
|
|
40
|
-
*/
|
|
41
|
-
export declare function toPayload(converter: PayloadConverter, value: unknown): Payload;
|
|
42
24
|
/**
|
|
43
25
|
* Implements conversion of a list of values.
|
|
44
26
|
*
|
|
45
27
|
* @param converter
|
|
46
28
|
* @param values JS values to convert to Payloads
|
|
47
|
-
* @return
|
|
48
|
-
* @throws
|
|
29
|
+
* @return list of {@link Payload}s
|
|
30
|
+
* @throws {@link ValueError} if conversion of the value passed as parameter failed for any
|
|
49
31
|
* reason.
|
|
50
32
|
*/
|
|
51
33
|
export declare function toPayloads(converter: PayloadConverter, ...values: unknown[]): Payload[] | undefined;
|
|
52
34
|
/**
|
|
53
35
|
* Run {@link PayloadConverter.toPayload} on each value in the map.
|
|
54
36
|
*
|
|
55
|
-
* @throws {@link
|
|
37
|
+
* @throws {@link ValueError} if conversion of any value in the map fails
|
|
56
38
|
*/
|
|
57
39
|
export declare function mapToPayloads<K extends string>(converter: PayloadConverter, map: Record<K, any>): Record<K, Payload>;
|
|
58
40
|
/**
|
|
@@ -71,17 +53,4 @@ export declare function fromPayloadsAtIndex<T>(converter: PayloadConverter, inde
|
|
|
71
53
|
* Run {@link PayloadConverter.fromPayload} on each value in the array.
|
|
72
54
|
*/
|
|
73
55
|
export declare function arrayFromPayloads(converter: PayloadConverter, payloads?: Payload[] | null): unknown[];
|
|
74
|
-
export declare function mapFromPayloads<K extends string>(converter: PayloadConverter, map?: Record<K, Payload> | null | undefined): Record<K, unknown> | undefined;
|
|
75
|
-
export declare const searchAttributePayloadConverter: JsonPayloadConverter;
|
|
76
|
-
export declare class DefaultPayloadConverter extends CompositePayloadConverter {
|
|
77
|
-
constructor();
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* The default {@link PayloadConverter} used by the SDK.
|
|
81
|
-
* Supports `Uint8Array` and JSON serializables (so if [`JSON.stringify(yourArgOrRetval)`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) works, the default payload converter will work).
|
|
82
|
-
*
|
|
83
|
-
* To also support Protobufs, create a custom payload converter with {@link DefaultPayloadConverter}:
|
|
84
|
-
*
|
|
85
|
-
* `const myConverter = new DefaultPayloadConverter({ protobufRoot })`
|
|
86
|
-
*/
|
|
87
|
-
export declare const defaultPayloadConverter: DefaultPayloadConverter;
|
|
56
|
+
export declare function mapFromPayloads<K extends string>(converter: PayloadConverter, map?: Record<K, Payload> | null | undefined): Record<K, unknown> | undefined | null;
|
|
@@ -1,84 +1,29 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
const internal_workflow_common_1 = require("@temporalio/internal-workflow-common");
|
|
5
|
-
const payload_converters_1 = require("./payload-converters");
|
|
6
|
-
const types_1 = require("./types");
|
|
7
|
-
class CompositePayloadConverter {
|
|
8
|
-
constructor(...converters) {
|
|
9
|
-
this.converterByEncoding = new Map();
|
|
10
|
-
this.converters = converters;
|
|
11
|
-
for (const converter of converters) {
|
|
12
|
-
this.converterByEncoding.set(converter.encodingType, converter);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* Tries to run `.toPayload(value)` on each converter in the order provided at construction.
|
|
17
|
-
* Returns the first successful result, or `undefined` if there is no converter that can handle the value.
|
|
18
|
-
*
|
|
19
|
-
* @throws UnsupportedJsonTypeError
|
|
20
|
-
*/
|
|
21
|
-
toPayload(value) {
|
|
22
|
-
for (const converter of this.converters) {
|
|
23
|
-
const result = converter.toPayload(value);
|
|
24
|
-
if (result !== undefined) {
|
|
25
|
-
return result;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
return undefined;
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Run {@link PayloadConverterWithEncoding.fromPayload} based on the {@link encodingTypes | encoding type} of the {@link Payload}.
|
|
32
|
-
*/
|
|
33
|
-
fromPayload(payload) {
|
|
34
|
-
if (payload.metadata === undefined || payload.metadata === null) {
|
|
35
|
-
throw new internal_workflow_common_1.ValueError('Missing payload metadata');
|
|
36
|
-
}
|
|
37
|
-
const encoding = (0, types_1.str)(payload.metadata[types_1.METADATA_ENCODING_KEY]);
|
|
38
|
-
const converter = this.converterByEncoding.get(encoding);
|
|
39
|
-
if (converter === undefined) {
|
|
40
|
-
throw new internal_workflow_common_1.ValueError(`Unknown encoding: ${encoding}`);
|
|
41
|
-
}
|
|
42
|
-
return converter.fromPayload(payload);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
exports.CompositePayloadConverter = CompositePayloadConverter;
|
|
46
|
-
/**
|
|
47
|
-
* Tries to convert `value` to a {@link Payload}. Throws if conversion fails.
|
|
48
|
-
*
|
|
49
|
-
* @throws {@link PayloadConverterError}
|
|
50
|
-
*/
|
|
51
|
-
function toPayload(converter, value) {
|
|
52
|
-
const payload = converter.toPayload(value);
|
|
53
|
-
if (payload === undefined) {
|
|
54
|
-
throw new internal_workflow_common_1.PayloadConverterError(`Failed to convert value: ${value}`);
|
|
55
|
-
}
|
|
56
|
-
return payload;
|
|
57
|
-
}
|
|
58
|
-
exports.toPayload = toPayload;
|
|
3
|
+
exports.mapFromPayloads = exports.arrayFromPayloads = exports.fromPayloadsAtIndex = exports.mapToPayloads = exports.toPayloads = void 0;
|
|
59
4
|
/**
|
|
60
5
|
* Implements conversion of a list of values.
|
|
61
6
|
*
|
|
62
7
|
* @param converter
|
|
63
8
|
* @param values JS values to convert to Payloads
|
|
64
|
-
* @return
|
|
65
|
-
* @throws
|
|
9
|
+
* @return list of {@link Payload}s
|
|
10
|
+
* @throws {@link ValueError} if conversion of the value passed as parameter failed for any
|
|
66
11
|
* reason.
|
|
67
12
|
*/
|
|
68
13
|
function toPayloads(converter, ...values) {
|
|
69
14
|
if (values.length === 0) {
|
|
70
15
|
return undefined;
|
|
71
16
|
}
|
|
72
|
-
return values.map((value) => toPayload(
|
|
17
|
+
return values.map((value) => converter.toPayload(value));
|
|
73
18
|
}
|
|
74
19
|
exports.toPayloads = toPayloads;
|
|
75
20
|
/**
|
|
76
21
|
* Run {@link PayloadConverter.toPayload} on each value in the map.
|
|
77
22
|
*
|
|
78
|
-
* @throws {@link
|
|
23
|
+
* @throws {@link ValueError} if conversion of any value in the map fails
|
|
79
24
|
*/
|
|
80
25
|
function mapToPayloads(converter, map) {
|
|
81
|
-
return Object.fromEntries(Object.entries(map).map(([k, v]) => [k, toPayload(
|
|
26
|
+
return Object.fromEntries(Object.entries(map).map(([k, v]) => [k, converter.toPayload(v)]));
|
|
82
27
|
}
|
|
83
28
|
exports.mapToPayloads = mapToPayloads;
|
|
84
29
|
/**
|
|
@@ -111,34 +56,12 @@ function arrayFromPayloads(converter, payloads) {
|
|
|
111
56
|
}
|
|
112
57
|
exports.arrayFromPayloads = arrayFromPayloads;
|
|
113
58
|
function mapFromPayloads(converter, map) {
|
|
114
|
-
if (map
|
|
115
|
-
return
|
|
59
|
+
if (map == null)
|
|
60
|
+
return map;
|
|
116
61
|
return Object.fromEntries(Object.entries(map).map(([k, payload]) => {
|
|
117
62
|
const value = converter.fromPayload(payload);
|
|
118
63
|
return [k, value];
|
|
119
64
|
}));
|
|
120
65
|
}
|
|
121
66
|
exports.mapFromPayloads = mapFromPayloads;
|
|
122
|
-
exports.searchAttributePayloadConverter = new payload_converters_1.JsonPayloadConverter();
|
|
123
|
-
class DefaultPayloadConverter extends CompositePayloadConverter {
|
|
124
|
-
// Match the order used in other SDKs, but exclude Protobuf converters so that the code, including
|
|
125
|
-
// `proto3-json-serializer`, doesn't take space in Workflow bundles that don't use Protobufs. To use Protobufs, use
|
|
126
|
-
// {@link DefaultPayloadConverterWithProtobufs}.
|
|
127
|
-
//
|
|
128
|
-
// Go SDK:
|
|
129
|
-
// https://github.com/temporalio/sdk-go/blob/5e5645f0c550dcf717c095ae32c76a7087d2e985/converter/default_data_converter.go#L28
|
|
130
|
-
constructor() {
|
|
131
|
-
super(new payload_converters_1.UndefinedPayloadConverter(), new payload_converters_1.BinaryPayloadConverter(), new payload_converters_1.JsonPayloadConverter());
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
exports.DefaultPayloadConverter = DefaultPayloadConverter;
|
|
135
|
-
/**
|
|
136
|
-
* The default {@link PayloadConverter} used by the SDK.
|
|
137
|
-
* Supports `Uint8Array` and JSON serializables (so if [`JSON.stringify(yourArgOrRetval)`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) works, the default payload converter will work).
|
|
138
|
-
*
|
|
139
|
-
* To also support Protobufs, create a custom payload converter with {@link DefaultPayloadConverter}:
|
|
140
|
-
*
|
|
141
|
-
* `const myConverter = new DefaultPayloadConverter({ protobufRoot })`
|
|
142
|
-
*/
|
|
143
|
-
exports.defaultPayloadConverter = new DefaultPayloadConverter();
|
|
144
67
|
//# sourceMappingURL=payload-converter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"payload-converter.js","sourceRoot":"","sources":["../../src/converter/payload-converter.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"payload-converter.js","sourceRoot":"","sources":["../../src/converter/payload-converter.ts"],"names":[],"mappings":";;;AA0BA;;;;;;;;GAQG;AACH,SAAgB,UAAU,CAAC,SAA2B,EAAE,GAAG,MAAiB;IAC1E,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QACvB,OAAO,SAAS,CAAC;KAClB;IAED,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;AAC3D,CAAC;AAND,gCAMC;AAED;;;;GAIG;AACH,SAAgB,aAAa,CAAmB,SAA2B,EAAE,GAAmB;IAC9F,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAgB,EAAE,CAAC,CAAC,CAAM,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAC9D,CAAC;AAC1B,CAAC;AAJD,sCAIC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,mBAAmB,CAAI,SAA2B,EAAE,KAAa,EAAE,QAA2B;IAC5G,yDAAyD;IACzD,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,KAAK,IAAI,IAAI,KAAK,IAAI,QAAQ,CAAC,MAAM,EAAE;QAC3E,OAAO,SAAgB,CAAC;KACzB;IACD,OAAO,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;AAChD,CAAC;AAND,kDAMC;AAED;;GAEG;AACH,SAAgB,iBAAiB,CAAC,SAA2B,EAAE,QAA2B;IACxF,IAAI,CAAC,QAAQ,EAAE;QACb,OAAO,EAAE,CAAC;KACX;IACD,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;AAC5E,CAAC;AALD,8CAKC;AAED,SAAgB,eAAe,CAC7B,SAA2B,EAC3B,GAA2C;IAE3C,IAAI,GAAG,IAAI,IAAI;QAAE,OAAO,GAAG,CAAC;IAC5B,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,EAAgB,EAAE;QACrD,MAAM,KAAK,GAAG,SAAS,CAAC,WAAW,CAAC,OAAkB,CAAC,CAAC;QACxD,OAAO,CAAC,CAAM,EAAE,KAAK,CAAC,CAAC;IACzB,CAAC,CAAC,CACmB,CAAC;AAC1B,CAAC;AAXD,0CAWC"}
|
|
@@ -1,7 +1,39 @@
|
|
|
1
1
|
import { PayloadConverter } from './payload-converter';
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
import { SearchAttributePayloadConverter } from './search-attribute-payload-converter';
|
|
3
|
+
import { Payload } from './types';
|
|
4
|
+
export interface PayloadConverterWithEncoding {
|
|
5
|
+
/**
|
|
6
|
+
* Converts a value to a {@link Payload}.
|
|
7
|
+
*
|
|
8
|
+
* @param value The value to convert. Example values include the Workflow args sent from the Client and the values returned by a Workflow or Activity.
|
|
9
|
+
* @returns The {@link Payload}, or `undefined` if unable to convert.
|
|
10
|
+
*/
|
|
11
|
+
toPayload<T>(value: T): Payload | undefined;
|
|
12
|
+
/**
|
|
13
|
+
* Converts a {@link Payload} back to a value.
|
|
14
|
+
*/
|
|
15
|
+
fromPayload<T>(payload: Payload): T;
|
|
16
|
+
readonly encodingType: string;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Tries to convert values to {@link Payload}s using the {@link PayloadConverterWithEncoding}s provided to the constructor, in the order provided.
|
|
20
|
+
*
|
|
21
|
+
* Converts Payloads to values based on the `Payload.metadata.encoding` field, which matches the {@link PayloadConverterWithEncoding.encodingType}
|
|
22
|
+
* of the converter that created the Payload.
|
|
23
|
+
*/
|
|
24
|
+
export declare class CompositePayloadConverter implements PayloadConverter {
|
|
25
|
+
readonly converters: PayloadConverterWithEncoding[];
|
|
26
|
+
readonly converterByEncoding: Map<string, PayloadConverterWithEncoding>;
|
|
27
|
+
constructor(...converters: PayloadConverterWithEncoding[]);
|
|
28
|
+
/**
|
|
29
|
+
* Tries to run `.toPayload(value)` on each converter in the order provided at construction.
|
|
30
|
+
* Returns the first successful result, throws {@link ValueError} if there is no converter that can handle the value.
|
|
31
|
+
*/
|
|
32
|
+
toPayload<T>(value: T): Payload;
|
|
33
|
+
/**
|
|
34
|
+
* Run {@link PayloadConverterWithEncoding.fromPayload} based on the {@link encodingTypes | encoding type} of the {@link Payload}.
|
|
35
|
+
*/
|
|
36
|
+
fromPayload<T>(payload: Payload): T;
|
|
5
37
|
}
|
|
6
38
|
/**
|
|
7
39
|
* Converts between JS undefined and NULL Payload
|
|
@@ -11,16 +43,6 @@ export declare class UndefinedPayloadConverter implements PayloadConverterWithEn
|
|
|
11
43
|
toPayload(value: unknown): Payload | undefined;
|
|
12
44
|
fromPayload<T>(_content: Payload): T;
|
|
13
45
|
}
|
|
14
|
-
/**
|
|
15
|
-
* Converts between non-undefined values and serialized JSON Payload
|
|
16
|
-
*
|
|
17
|
-
* @throws UnsupportedJsonTypeError
|
|
18
|
-
*/
|
|
19
|
-
export declare class JsonPayloadConverter implements PayloadConverterWithEncoding {
|
|
20
|
-
encodingType: "json/plain";
|
|
21
|
-
toPayload(value: unknown): Payload | undefined;
|
|
22
|
-
fromPayload<T>(content: Payload): T;
|
|
23
|
-
}
|
|
24
46
|
/**
|
|
25
47
|
* Converts between binary data types and RAW Payload
|
|
26
48
|
*/
|
|
@@ -29,3 +51,16 @@ export declare class BinaryPayloadConverter implements PayloadConverterWithEncod
|
|
|
29
51
|
toPayload(value: unknown): Payload | undefined;
|
|
30
52
|
fromPayload<T>(content: Payload): T;
|
|
31
53
|
}
|
|
54
|
+
export declare const searchAttributePayloadConverter: SearchAttributePayloadConverter;
|
|
55
|
+
export declare class DefaultPayloadConverter extends CompositePayloadConverter {
|
|
56
|
+
constructor();
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* The default {@link PayloadConverter} used by the SDK.
|
|
60
|
+
* Supports `Uint8Array` and JSON serializables (so if [`JSON.stringify(yourArgOrRetval)`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) works, the default payload converter will work).
|
|
61
|
+
*
|
|
62
|
+
* To also support Protobufs, create a custom payload converter with {@link DefaultPayloadConverter}:
|
|
63
|
+
*
|
|
64
|
+
* `const myConverter = new DefaultPayloadConverter({ protobufRoot })`
|
|
65
|
+
*/
|
|
66
|
+
export declare const defaultPayloadConverter: DefaultPayloadConverter;
|