@proompteng/temporal-bun-sdk 0.1.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 +387 -0
- package/dist/bin/start-worker.js +3 -0
- package/dist/bin/temporal-bun.js +3 -0
- package/dist/src/activities/index.d.ts +6 -0
- package/dist/src/activities/index.d.ts.map +1 -0
- package/dist/src/activities/index.js +5 -0
- package/dist/src/activities/index.js.map +1 -0
- package/dist/src/activities/lifecycle.d.ts +48 -0
- package/dist/src/activities/lifecycle.d.ts.map +1 -0
- package/dist/src/activities/lifecycle.js +306 -0
- package/dist/src/activities/lifecycle.js.map +1 -0
- package/dist/src/bin/replay-command.d.ts +104 -0
- package/dist/src/bin/replay-command.d.ts.map +1 -0
- package/dist/src/bin/replay-command.js +582 -0
- package/dist/src/bin/replay-command.js.map +1 -0
- package/dist/src/bin/start-worker.d.ts +3 -0
- package/dist/src/bin/start-worker.d.ts.map +1 -0
- package/dist/src/bin/start-worker.js +29 -0
- package/dist/src/bin/start-worker.js.map +1 -0
- package/dist/src/bin/temporal-bun.d.ts +25 -0
- package/dist/src/bin/temporal-bun.d.ts.map +1 -0
- package/dist/src/bin/temporal-bun.js +427 -0
- package/dist/src/bin/temporal-bun.js.map +1 -0
- package/dist/src/build_id_preflight.d.ts +7 -0
- package/dist/src/build_id_preflight.d.ts.map +1 -0
- package/dist/src/build_id_preflight.js +123 -0
- package/dist/src/build_id_preflight.js.map +1 -0
- package/dist/src/client/headers.d.ts +4 -0
- package/dist/src/client/headers.d.ts.map +1 -0
- package/dist/src/client/headers.js +79 -0
- package/dist/src/client/headers.js.map +1 -0
- package/dist/src/client/index.d.ts +2 -0
- package/dist/src/client/index.d.ts.map +1 -0
- package/dist/src/client/index.js +2 -0
- package/dist/src/client/index.js.map +1 -0
- package/dist/src/client/interceptors.d.ts +17 -0
- package/dist/src/client/interceptors.d.ts.map +1 -0
- package/dist/src/client/interceptors.js +71 -0
- package/dist/src/client/interceptors.js.map +1 -0
- package/dist/src/client/layer.d.ts +10 -0
- package/dist/src/client/layer.d.ts.map +1 -0
- package/dist/src/client/layer.js +7 -0
- package/dist/src/client/layer.js.map +1 -0
- package/dist/src/client/retries.d.ts +13 -0
- package/dist/src/client/retries.d.ts.map +1 -0
- package/dist/src/client/retries.js +51 -0
- package/dist/src/client/retries.js.map +1 -0
- package/dist/src/client/serialization.d.ts +48 -0
- package/dist/src/client/serialization.d.ts.map +1 -0
- package/dist/src/client/serialization.js +310 -0
- package/dist/src/client/serialization.js.map +1 -0
- package/dist/src/client/serialization.test.d.ts +2 -0
- package/dist/src/client/serialization.test.d.ts.map +1 -0
- package/dist/src/client/serialization.test.js +251 -0
- package/dist/src/client/serialization.test.js.map +1 -0
- package/dist/src/client/transport.d.ts +12 -0
- package/dist/src/client/transport.d.ts.map +1 -0
- package/dist/src/client/transport.js +36 -0
- package/dist/src/client/transport.js.map +1 -0
- package/dist/src/client/types.d.ts +51 -0
- package/dist/src/client/types.d.ts.map +1 -0
- package/dist/src/client/types.js +7 -0
- package/dist/src/client/types.js.map +1 -0
- package/dist/src/client.d.ts +92 -0
- package/dist/src/client.d.ts.map +1 -0
- package/dist/src/client.js +666 -0
- package/dist/src/client.js.map +1 -0
- package/dist/src/common/duration.d.ts +4 -0
- package/dist/src/common/duration.d.ts.map +1 -0
- package/dist/src/common/duration.js +14 -0
- package/dist/src/common/duration.js.map +1 -0
- package/dist/src/common/index.d.ts +2 -0
- package/dist/src/common/index.d.ts.map +1 -0
- package/dist/src/common/index.js +2 -0
- package/dist/src/common/index.js.map +1 -0
- package/dist/src/common/payloads/converter.d.ts +16 -0
- package/dist/src/common/payloads/converter.d.ts.map +1 -0
- package/dist/src/common/payloads/converter.js +33 -0
- package/dist/src/common/payloads/converter.js.map +1 -0
- package/dist/src/common/payloads/failure.d.ts +7 -0
- package/dist/src/common/payloads/failure.d.ts.map +1 -0
- package/dist/src/common/payloads/failure.js +53 -0
- package/dist/src/common/payloads/failure.js.map +1 -0
- package/dist/src/common/payloads/index.d.ts +4 -0
- package/dist/src/common/payloads/index.d.ts.map +1 -0
- package/dist/src/common/payloads/index.js +4 -0
- package/dist/src/common/payloads/index.js.map +1 -0
- package/dist/src/common/payloads/json-codec.d.ts +16 -0
- package/dist/src/common/payloads/json-codec.d.ts.map +1 -0
- package/dist/src/common/payloads/json-codec.js +185 -0
- package/dist/src/common/payloads/json-codec.js.map +1 -0
- package/dist/src/common/sleep.d.ts +2 -0
- package/dist/src/common/sleep.d.ts.map +1 -0
- package/dist/src/common/sleep.js +3 -0
- package/dist/src/common/sleep.js.map +1 -0
- package/dist/src/config.d.ts +115 -0
- package/dist/src/config.d.ts.map +1 -0
- package/dist/src/config.js +505 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/core-bridge/client.d.ts +36 -0
- package/dist/src/core-bridge/client.d.ts.map +1 -0
- package/dist/src/core-bridge/client.js +111 -0
- package/dist/src/core-bridge/client.js.map +1 -0
- package/dist/src/core-bridge/index.d.ts +4 -0
- package/dist/src/core-bridge/index.d.ts.map +1 -0
- package/dist/src/core-bridge/index.js +4 -0
- package/dist/src/core-bridge/index.js.map +1 -0
- package/dist/src/core-bridge/runtime.d.ts +20 -0
- package/dist/src/core-bridge/runtime.d.ts.map +1 -0
- package/dist/src/core-bridge/runtime.js +62 -0
- package/dist/src/core-bridge/runtime.js.map +1 -0
- package/dist/src/core-bridge/runtime.test.d.ts +2 -0
- package/dist/src/core-bridge/runtime.test.d.ts.map +1 -0
- package/dist/src/core-bridge/runtime.test.js +68 -0
- package/dist/src/core-bridge/runtime.test.js.map +1 -0
- package/dist/src/index.d.ts +11 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +7 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/internal/core-bridge/native.d.ts +176 -0
- package/dist/src/internal/core-bridge/native.d.ts.map +1 -0
- package/dist/src/internal/core-bridge/native.js +1208 -0
- package/dist/src/internal/core-bridge/native.js.map +1 -0
- package/dist/src/observability/index.d.ts +21 -0
- package/dist/src/observability/index.d.ts.map +1 -0
- package/dist/src/observability/index.js +19 -0
- package/dist/src/observability/index.js.map +1 -0
- package/dist/src/observability/logger.d.ts +28 -0
- package/dist/src/observability/logger.d.ts.map +1 -0
- package/dist/src/observability/logger.js +53 -0
- package/dist/src/observability/logger.js.map +1 -0
- package/dist/src/observability/metrics.d.ts +28 -0
- package/dist/src/observability/metrics.d.ts.map +1 -0
- package/dist/src/observability/metrics.js +355 -0
- package/dist/src/observability/metrics.js.map +1 -0
- package/dist/src/proto/google/api/annotations_pb.d.ts +14 -0
- package/dist/src/proto/google/api/annotations_pb.d.ts.map +1 -0
- package/dist/src/proto/google/api/annotations_pb.js +27 -0
- package/dist/src/proto/google/api/annotations_pb.js.map +1 -0
- package/dist/src/proto/google/api/http_pb.d.ts +441 -0
- package/dist/src/proto/google/api/http_pb.d.ts.map +1 -0
- package/dist/src/proto/google/api/http_pb.js +34 -0
- package/dist/src/proto/google/api/http_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/activity/v1/message_pb.d.ts +67 -0
- package/dist/src/proto/temporal/api/activity/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/activity/v1/message_pb.js +17 -0
- package/dist/src/proto/temporal/api/activity/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/batch/v1/message_pb.d.ts +464 -0
- package/dist/src/proto/temporal/api/batch/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/batch/v1/message_pb.js +71 -0
- package/dist/src/proto/temporal/api/batch/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/command/v1/message_pb.d.ts +796 -0
- package/dist/src/proto/temporal/api/command/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/command/v1/message_pb.js +106 -0
- package/dist/src/proto/temporal/api/command/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/common/v1/message_pb.d.ts +751 -0
- package/dist/src/proto/temporal/api/common/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/common/v1/message_pb.js +133 -0
- package/dist/src/proto/temporal/api/common/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/deployment/v1/message_pb.d.ts +639 -0
- package/dist/src/proto/temporal/api/deployment/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/deployment/v1/message_pb.js +83 -0
- package/dist/src/proto/temporal/api/deployment/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/batch_operation_pb.d.ts +80 -0
- package/dist/src/proto/temporal/api/enums/v1/batch_operation_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/batch_operation_pb.js +85 -0
- package/dist/src/proto/temporal/api/enums/v1/batch_operation_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/command_type_pb.d.ts +89 -0
- package/dist/src/proto/temporal/api/enums/v1/command_type_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/command_type_pb.js +93 -0
- package/dist/src/proto/temporal/api/enums/v1/command_type_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/common_pb.d.ts +314 -0
- package/dist/src/proto/temporal/api/enums/v1/common_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/common_pb.js +326 -0
- package/dist/src/proto/temporal/api/enums/v1/common_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/deployment_pb.d.ts +186 -0
- package/dist/src/proto/temporal/api/enums/v1/deployment_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/deployment_pb.js +193 -0
- package/dist/src/proto/temporal/api/enums/v1/deployment_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/event_type_pb.d.ts +407 -0
- package/dist/src/proto/temporal/api/enums/v1/event_type_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/event_type_pb.js +411 -0
- package/dist/src/proto/temporal/api/enums/v1/event_type_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/failed_cause_pb.d.ts +371 -0
- package/dist/src/proto/temporal/api/enums/v1/failed_cause_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/failed_cause_pb.js +380 -0
- package/dist/src/proto/temporal/api/enums/v1/failed_cause_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/namespace_pb.d.ts +73 -0
- package/dist/src/proto/temporal/api/enums/v1/namespace_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/namespace_pb.js +79 -0
- package/dist/src/proto/temporal/api/enums/v1/namespace_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/nexus_pb.d.ts +35 -0
- package/dist/src/proto/temporal/api/enums/v1/nexus_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/nexus_pb.js +39 -0
- package/dist/src/proto/temporal/api/enums/v1/nexus_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/query_pb.d.ts +58 -0
- package/dist/src/proto/temporal/api/enums/v1/query_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/query_pb.js +63 -0
- package/dist/src/proto/temporal/api/enums/v1/query_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/reset_pb.d.ts +108 -0
- package/dist/src/proto/temporal/api/enums/v1/reset_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/reset_pb.js +114 -0
- package/dist/src/proto/temporal/api/enums/v1/reset_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/schedule_pb.d.ts +67 -0
- package/dist/src/proto/temporal/api/enums/v1/schedule_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/schedule_pb.js +71 -0
- package/dist/src/proto/temporal/api/enums/v1/schedule_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/task_queue_pb.d.ts +249 -0
- package/dist/src/proto/temporal/api/enums/v1/task_queue_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/task_queue_pb.js +259 -0
- package/dist/src/proto/temporal/api/enums/v1/task_queue_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/update_pb.d.ts +78 -0
- package/dist/src/proto/temporal/api/enums/v1/update_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/update_pb.js +83 -0
- package/dist/src/proto/temporal/api/enums/v1/update_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/workflow_pb.d.ts +408 -0
- package/dist/src/proto/temporal/api/enums/v1/workflow_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/enums/v1/workflow_pb.js +422 -0
- package/dist/src/proto/temporal/api/enums/v1/workflow_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/errordetails/v1/message_pb.d.ts +331 -0
- package/dist/src/proto/temporal/api/errordetails/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/errordetails/v1/message_pb.js +104 -0
- package/dist/src/proto/temporal/api/errordetails/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/export/v1/message_pb.d.ts +39 -0
- package/dist/src/proto/temporal/api/export/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/export/v1/message_pb.js +20 -0
- package/dist/src/proto/temporal/api/export/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/failure/v1/message_pb.d.ts +381 -0
- package/dist/src/proto/temporal/api/failure/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/failure/v1/message_pb.js +74 -0
- package/dist/src/proto/temporal/api/failure/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/filter/v1/message_pb.d.ts +73 -0
- package/dist/src/proto/temporal/api/filter/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/filter/v1/message_pb.js +31 -0
- package/dist/src/proto/temporal/api/filter/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/history/v1/message_pb.d.ts +3136 -0
- package/dist/src/proto/temporal/api/history/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/history/v1/message_pb.js +317 -0
- package/dist/src/proto/temporal/api/history/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/namespace/v1/message_pb.d.ts +242 -0
- package/dist/src/proto/temporal/api/namespace/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/namespace/v1/message_pb.js +46 -0
- package/dist/src/proto/temporal/api/namespace/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/nexus/v1/message_pb.d.ts +549 -0
- package/dist/src/proto/temporal/api/nexus/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/nexus/v1/message_pb.js +97 -0
- package/dist/src/proto/temporal/api/nexus/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/request_response_pb.d.ts +499 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/request_response_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/request_response_pb.js +137 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/request_response_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/service_pb.d.ts +153 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/service_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/service_pb.js +22 -0
- package/dist/src/proto/temporal/api/operatorservice/v1/service_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/protocol/v1/message_pb.d.ts +64 -0
- package/dist/src/proto/temporal/api/protocol/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/protocol/v1/message_pb.js +15 -0
- package/dist/src/proto/temporal/api/protocol/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/query/v1/message_pb.d.ts +96 -0
- package/dist/src/proto/temporal/api/query/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/query/v1/message_pb.js +28 -0
- package/dist/src/proto/temporal/api/query/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/replication/v1/message_pb.d.ts +67 -0
- package/dist/src/proto/temporal/api/replication/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/replication/v1/message_pb.js +26 -0
- package/dist/src/proto/temporal/api/replication/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/rules/v1/message_pb.d.ts +172 -0
- package/dist/src/proto/temporal/api/rules/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/rules/v1/message_pb.js +35 -0
- package/dist/src/proto/temporal/api/rules/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/schedule/v1/message_pb.d.ts +779 -0
- package/dist/src/proto/temporal/api/schedule/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/schedule/v1/message_pb.js +95 -0
- package/dist/src/proto/temporal/api/schedule/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/enhanced_stack_trace_pb.d.ts +157 -0
- package/dist/src/proto/temporal/api/sdk/v1/enhanced_stack_trace_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/enhanced_stack_trace_pb.js +34 -0
- package/dist/src/proto/temporal/api/sdk/v1/enhanced_stack_trace_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/task_complete_metadata_pb.d.ts +71 -0
- package/dist/src/proto/temporal/api/sdk/v1/task_complete_metadata_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/task_complete_metadata_pb.js +14 -0
- package/dist/src/proto/temporal/api/sdk/v1/task_complete_metadata_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/user_metadata_pb.d.ts +37 -0
- package/dist/src/proto/temporal/api/sdk/v1/user_metadata_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/user_metadata_pb.js +15 -0
- package/dist/src/proto/temporal/api/sdk/v1/user_metadata_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/worker_config_pb.d.ts +84 -0
- package/dist/src/proto/temporal/api/sdk/v1/worker_config_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/worker_config_pb.js +24 -0
- package/dist/src/proto/temporal/api/sdk/v1/worker_config_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/workflow_metadata_pb.d.ts +99 -0
- package/dist/src/proto/temporal/api/sdk/v1/workflow_metadata_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/sdk/v1/workflow_metadata_pb.js +24 -0
- package/dist/src/proto/temporal/api/sdk/v1/workflow_metadata_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/taskqueue/v1/message_pb.d.ts +757 -0
- package/dist/src/proto/temporal/api/taskqueue/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/taskqueue/v1/message_pb.js +138 -0
- package/dist/src/proto/temporal/api/taskqueue/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/update/v1/message_pb.d.ts +230 -0
- package/dist/src/proto/temporal/api/update/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/update/v1/message_pb.js +57 -0
- package/dist/src/proto/temporal/api/update/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/version/v1/message_pb.d.ts +85 -0
- package/dist/src/proto/temporal/api/version/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/version/v1/message_pb.js +26 -0
- package/dist/src/proto/temporal/api/version/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/worker/v1/message_pb.d.ts +311 -0
- package/dist/src/proto/temporal/api/worker/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/worker/v1/message_pb.js +42 -0
- package/dist/src/proto/temporal/api/worker/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/workflow/v1/message_pb.d.ts +1500 -0
- package/dist/src/proto/temporal/api/workflow/v1/message_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/workflow/v1/message_pb.js +183 -0
- package/dist/src/proto/temporal/api/workflow/v1/message_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/request_response_pb.d.ts +6967 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/request_response_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/request_response_pb.js +1073 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/request_response_pb.js.map +1 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/service_pb.d.ts +1305 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/service_pb.d.ts.map +1 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/service_pb.js +27 -0
- package/dist/src/proto/temporal/api/workflowservice/v1/service_pb.js.map +1 -0
- package/dist/src/runtime/cli-layer.d.ts +12 -0
- package/dist/src/runtime/cli-layer.d.ts.map +1 -0
- package/dist/src/runtime/cli-layer.js +19 -0
- package/dist/src/runtime/cli-layer.js.map +1 -0
- package/dist/src/runtime/config-layer.d.ts +9 -0
- package/dist/src/runtime/config-layer.d.ts.map +1 -0
- package/dist/src/runtime/config-layer.js +15 -0
- package/dist/src/runtime/config-layer.js.map +1 -0
- package/dist/src/runtime/effect-layers.d.ts +518 -0
- package/dist/src/runtime/effect-layers.d.ts.map +1 -0
- package/dist/src/runtime/effect-layers.js +68 -0
- package/dist/src/runtime/effect-layers.js.map +1 -0
- package/dist/src/runtime/worker-app.d.ts +14 -0
- package/dist/src/runtime/worker-app.d.ts.map +1 -0
- package/dist/src/runtime/worker-app.js +58 -0
- package/dist/src/runtime/worker-app.js.map +1 -0
- package/dist/src/telemetry/runtime.d.ts +5 -0
- package/dist/src/telemetry/runtime.d.ts.map +1 -0
- package/dist/src/telemetry/runtime.js +94 -0
- package/dist/src/telemetry/runtime.js.map +1 -0
- package/dist/src/worker/activity-context.d.ts +30 -0
- package/dist/src/worker/activity-context.d.ts.map +1 -0
- package/dist/src/worker/activity-context.js +9 -0
- package/dist/src/worker/activity-context.js.map +1 -0
- package/dist/src/worker/build-id.d.ts +20 -0
- package/dist/src/worker/build-id.d.ts.map +1 -0
- package/dist/src/worker/build-id.js +98 -0
- package/dist/src/worker/build-id.js.map +1 -0
- package/dist/src/worker/concurrency.d.ts +31 -0
- package/dist/src/worker/concurrency.d.ts.map +1 -0
- package/dist/src/worker/concurrency.js +129 -0
- package/dist/src/worker/concurrency.js.map +1 -0
- package/dist/src/worker/defaults.d.ts +9 -0
- package/dist/src/worker/defaults.d.ts.map +1 -0
- package/dist/src/worker/defaults.js +53 -0
- package/dist/src/worker/defaults.js.map +1 -0
- package/dist/src/worker/index.d.ts +7 -0
- package/dist/src/worker/index.d.ts.map +1 -0
- package/dist/src/worker/index.js +4 -0
- package/dist/src/worker/index.js.map +1 -0
- package/dist/src/worker/layer.d.ts +19 -0
- package/dist/src/worker/layer.d.ts.map +1 -0
- package/dist/src/worker/layer.js +71 -0
- package/dist/src/worker/layer.js.map +1 -0
- package/dist/src/worker/runtime.d.ts +59 -0
- package/dist/src/worker/runtime.d.ts.map +1 -0
- package/dist/src/worker/runtime.js +1415 -0
- package/dist/src/worker/runtime.js.map +1 -0
- package/dist/src/worker/service.d.ts +19 -0
- package/dist/src/worker/service.d.ts.map +1 -0
- package/dist/src/worker/service.js +14 -0
- package/dist/src/worker/service.js.map +1 -0
- package/dist/src/worker/sticky-cache.d.ts +41 -0
- package/dist/src/worker/sticky-cache.d.ts.map +1 -0
- package/dist/src/worker/sticky-cache.js +127 -0
- package/dist/src/worker/sticky-cache.js.map +1 -0
- package/dist/src/worker.d.ts +30 -0
- package/dist/src/worker.d.ts.map +1 -0
- package/dist/src/worker.js +82 -0
- package/dist/src/worker.js.map +1 -0
- package/dist/src/workflow/commands.d.ts +84 -0
- package/dist/src/workflow/commands.d.ts.map +1 -0
- package/dist/src/workflow/commands.js +159 -0
- package/dist/src/workflow/commands.js.map +1 -0
- package/dist/src/workflow/context.d.ts +119 -0
- package/dist/src/workflow/context.d.ts.map +1 -0
- package/dist/src/workflow/context.js +197 -0
- package/dist/src/workflow/context.js.map +1 -0
- package/dist/src/workflow/definition.d.ts +15 -0
- package/dist/src/workflow/definition.d.ts.map +1 -0
- package/dist/src/workflow/definition.js +19 -0
- package/dist/src/workflow/definition.js.map +1 -0
- package/dist/src/workflow/determinism.d.ts +54 -0
- package/dist/src/workflow/determinism.d.ts.map +1 -0
- package/dist/src/workflow/determinism.js +147 -0
- package/dist/src/workflow/determinism.js.map +1 -0
- package/dist/src/workflow/errors.d.ts +37 -0
- package/dist/src/workflow/errors.d.ts.map +1 -0
- package/dist/src/workflow/errors.js +35 -0
- package/dist/src/workflow/errors.js.map +1 -0
- package/dist/src/workflow/executor.d.ts +35 -0
- package/dist/src/workflow/executor.d.ts.map +1 -0
- package/dist/src/workflow/executor.js +178 -0
- package/dist/src/workflow/executor.js.map +1 -0
- package/dist/src/workflow/index.d.ts +8 -0
- package/dist/src/workflow/index.d.ts.map +1 -0
- package/dist/src/workflow/index.js +8 -0
- package/dist/src/workflow/index.js.map +1 -0
- package/dist/src/workflow/registry.d.ts +9 -0
- package/dist/src/workflow/registry.d.ts.map +1 -0
- package/dist/src/workflow/registry.js +51 -0
- package/dist/src/workflow/registry.js.map +1 -0
- package/dist/src/workflow/replay.d.ts +87 -0
- package/dist/src/workflow/replay.d.ts.map +1 -0
- package/dist/src/workflow/replay.js +759 -0
- package/dist/src/workflow/replay.js.map +1 -0
- package/dist/src/workflow/runtime/bootstrap.d.ts +15 -0
- package/dist/src/workflow/runtime/bootstrap.d.ts.map +1 -0
- package/dist/src/workflow/runtime/bootstrap.js +124 -0
- package/dist/src/workflow/runtime/bootstrap.js.map +1 -0
- package/dist/src/workflow/runtime/engine.d.ts +21 -0
- package/dist/src/workflow/runtime/engine.d.ts.map +1 -0
- package/dist/src/workflow/runtime/engine.js +73 -0
- package/dist/src/workflow/runtime/engine.js.map +1 -0
- package/dist/src/workflow/runtime/environment.d.ts +29 -0
- package/dist/src/workflow/runtime/environment.d.ts.map +1 -0
- package/dist/src/workflow/runtime/environment.js +298 -0
- package/dist/src/workflow/runtime/environment.js.map +1 -0
- package/dist/src/workflow/runtime/index.d.ts +7 -0
- package/dist/src/workflow/runtime/index.d.ts.map +1 -0
- package/dist/src/workflow/runtime/index.js +4 -0
- package/dist/src/workflow/runtime/index.js.map +1 -0
- package/dist/src/workflow/runtime/info.d.ts +5 -0
- package/dist/src/workflow/runtime/info.d.ts.map +1 -0
- package/dist/src/workflow/runtime/info.js +22 -0
- package/dist/src/workflow/runtime/info.js.map +1 -0
- package/dist/src/workflow/runtime/replay.d.ts +26 -0
- package/dist/src/workflow/runtime/replay.d.ts.map +1 -0
- package/dist/src/workflow/runtime/replay.js +254 -0
- package/dist/src/workflow/runtime/replay.js.map +1 -0
- package/dist/src/workflows/index.d.ts +3 -0
- package/dist/src/workflows/index.d.ts.map +1 -0
- package/dist/src/workflows/index.js +15 -0
- package/dist/src/workflows/index.js.map +1 -0
- package/package.json +74 -0
|
@@ -0,0 +1,306 @@
|
|
|
1
|
+
import { create } from '@bufbuild/protobuf';
|
|
2
|
+
import { Code, ConnectError } from '@connectrpc/connect';
|
|
3
|
+
import { Effect } from 'effect';
|
|
4
|
+
import { encodeValuesToPayloads } from '../common/payloads/converter';
|
|
5
|
+
import { sleep } from '../common/sleep';
|
|
6
|
+
import { PayloadsSchema } from '../proto/temporal/api/common/v1/message_pb';
|
|
7
|
+
import { RecordActivityTaskHeartbeatRequestSchema } from '../proto/temporal/api/workflowservice/v1/request_response_pb';
|
|
8
|
+
const MIN_HEARTBEAT_INTERVAL_MS = 250;
|
|
9
|
+
const DEFAULT_HEARTBEAT_JITTER_RATIO = 0.2;
|
|
10
|
+
const DEFAULT_ACTIVITY_RETRY_INITIAL_INTERVAL_MS = 1_000;
|
|
11
|
+
const DEFAULT_ACTIVITY_RETRY_BACKOFF = 2;
|
|
12
|
+
const DEFAULT_ACTIVITY_RETRY_MAX_INTERVAL_MULTIPLIER = 100;
|
|
13
|
+
const RETRIABLE_HEARTBEAT_CODES = new Set([
|
|
14
|
+
Code.Unavailable,
|
|
15
|
+
Code.ResourceExhausted,
|
|
16
|
+
Code.Internal,
|
|
17
|
+
Code.Aborted,
|
|
18
|
+
Code.DeadlineExceeded,
|
|
19
|
+
]);
|
|
20
|
+
export const makeActivityLifecycle = (config) => Effect.sync(() => {
|
|
21
|
+
const registerHeartbeat = (options) => Effect.try(() => {
|
|
22
|
+
const driver = new ActivityHeartbeatDriver(config, options, config.observability);
|
|
23
|
+
return {
|
|
24
|
+
heartbeat: (details) => Effect.tryPromise(async () => await driver.enqueue(details)),
|
|
25
|
+
shutdown: Effect.tryPromise(async () => {
|
|
26
|
+
await driver.shutdown();
|
|
27
|
+
}).pipe(Effect.catchAll(() => Effect.void)),
|
|
28
|
+
};
|
|
29
|
+
});
|
|
30
|
+
const nextRetryDelay = (retry, state) => Effect.sync(() => {
|
|
31
|
+
if (!retry) {
|
|
32
|
+
return undefined;
|
|
33
|
+
}
|
|
34
|
+
const nextAttempt = state.attempt + 1;
|
|
35
|
+
const maxAttempts = retry.maximumAttempts ?? 0;
|
|
36
|
+
if (maxAttempts === 1) {
|
|
37
|
+
return undefined;
|
|
38
|
+
}
|
|
39
|
+
if (maxAttempts > 0 && nextAttempt > maxAttempts) {
|
|
40
|
+
return undefined;
|
|
41
|
+
}
|
|
42
|
+
const initialInterval = retry.initialIntervalMs ?? DEFAULT_ACTIVITY_RETRY_INITIAL_INTERVAL_MS;
|
|
43
|
+
const backoffCoefficient = retry.backoffCoefficient ?? DEFAULT_ACTIVITY_RETRY_BACKOFF;
|
|
44
|
+
const maxInterval = retry.maximumIntervalMs ?? initialInterval * DEFAULT_ACTIVITY_RETRY_MAX_INTERVAL_MULTIPLIER;
|
|
45
|
+
const retryCount = state.retryCount + 1;
|
|
46
|
+
const attemptBasedExponent = Math.max(state.attempt - 1, 0);
|
|
47
|
+
const exponentialDelay = initialInterval * backoffCoefficient ** attemptBasedExponent;
|
|
48
|
+
const nextDelayMs = Math.min(exponentialDelay, maxInterval);
|
|
49
|
+
return {
|
|
50
|
+
attempt: nextAttempt,
|
|
51
|
+
retryCount,
|
|
52
|
+
nextDelayMs,
|
|
53
|
+
};
|
|
54
|
+
});
|
|
55
|
+
return {
|
|
56
|
+
registerHeartbeat,
|
|
57
|
+
nextRetryDelay,
|
|
58
|
+
};
|
|
59
|
+
});
|
|
60
|
+
class ActivityHeartbeatDriver {
|
|
61
|
+
#config;
|
|
62
|
+
#options;
|
|
63
|
+
#observability;
|
|
64
|
+
#intervalMs;
|
|
65
|
+
#retryJitterRatio;
|
|
66
|
+
#recordedHeartbeatErrors = new WeakSet();
|
|
67
|
+
#pending;
|
|
68
|
+
#timer;
|
|
69
|
+
#sending;
|
|
70
|
+
#stopped = false;
|
|
71
|
+
#lastSentAt = 0;
|
|
72
|
+
constructor(config, options, observability) {
|
|
73
|
+
this.#config = config;
|
|
74
|
+
this.#options = options;
|
|
75
|
+
this.#observability = observability;
|
|
76
|
+
this.#retryJitterRatio = config.heartbeatRetry.jitterRatio ?? DEFAULT_HEARTBEAT_JITTER_RATIO;
|
|
77
|
+
this.#intervalMs = this.#computeInterval(options.context.info.heartbeatTimeoutMs);
|
|
78
|
+
const onAbort = () => {
|
|
79
|
+
this.#stopImmediately();
|
|
80
|
+
};
|
|
81
|
+
options.abortController.signal.addEventListener('abort', onAbort, { once: true });
|
|
82
|
+
}
|
|
83
|
+
enqueue(details) {
|
|
84
|
+
if (this.#stopped) {
|
|
85
|
+
return Promise.reject(createAbortError('Activity heartbeat requested after shutdown'));
|
|
86
|
+
}
|
|
87
|
+
if (this.#options.abortController.signal.aborted) {
|
|
88
|
+
return Promise.reject(this.#options.abortController.signal.reason ?? createAbortError('Activity cancelled'));
|
|
89
|
+
}
|
|
90
|
+
return new Promise((resolve, reject) => {
|
|
91
|
+
const payload = details ?? [];
|
|
92
|
+
if (this.#pending) {
|
|
93
|
+
this.#pending.details = payload;
|
|
94
|
+
this.#pending.waiters.push({ resolve, reject });
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
this.#pending = { details: payload, waiters: [{ resolve, reject }] };
|
|
98
|
+
}
|
|
99
|
+
this.#scheduleFlush();
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
async shutdown() {
|
|
103
|
+
this.#stopped = true;
|
|
104
|
+
if (this.#timer) {
|
|
105
|
+
clearTimeout(this.#timer);
|
|
106
|
+
this.#timer = undefined;
|
|
107
|
+
}
|
|
108
|
+
this.#rejectPending(createAbortError('Activity heartbeat stopped'));
|
|
109
|
+
if (this.#sending) {
|
|
110
|
+
try {
|
|
111
|
+
await this.#sending;
|
|
112
|
+
}
|
|
113
|
+
catch {
|
|
114
|
+
// Ignore flush errors during shutdown.
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
#scheduleFlush() {
|
|
119
|
+
if (this.#stopped || !this.#pending) {
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
const now = Date.now();
|
|
123
|
+
const elapsed = now - this.#lastSentAt;
|
|
124
|
+
if (!this.#sending && elapsed >= this.#intervalMs) {
|
|
125
|
+
this.#startFlush();
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
const remaining = Math.max(this.#intervalMs - elapsed, MIN_HEARTBEAT_INTERVAL_MS);
|
|
129
|
+
if (this.#timer) {
|
|
130
|
+
clearTimeout(this.#timer);
|
|
131
|
+
}
|
|
132
|
+
this.#timer = setTimeout(() => {
|
|
133
|
+
this.#timer = undefined;
|
|
134
|
+
if (!this.#sending) {
|
|
135
|
+
this.#startFlush();
|
|
136
|
+
}
|
|
137
|
+
}, remaining);
|
|
138
|
+
}
|
|
139
|
+
#startFlush() {
|
|
140
|
+
const pendingFlush = this.#flush();
|
|
141
|
+
this.#sending = pendingFlush;
|
|
142
|
+
void pendingFlush
|
|
143
|
+
.catch((error) => {
|
|
144
|
+
this.#recordHeartbeatFailure(error);
|
|
145
|
+
})
|
|
146
|
+
.finally(() => {
|
|
147
|
+
if (this.#sending === pendingFlush) {
|
|
148
|
+
this.#sending = undefined;
|
|
149
|
+
}
|
|
150
|
+
if (this.#pending && !this.#stopped) {
|
|
151
|
+
this.#scheduleFlush();
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
async #flush() {
|
|
156
|
+
if (!this.#pending || this.#stopped) {
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
const batch = this.#pending;
|
|
160
|
+
this.#pending = undefined;
|
|
161
|
+
try {
|
|
162
|
+
await this.#send(batch.details);
|
|
163
|
+
this.#lastSentAt = Date.now();
|
|
164
|
+
batch.waiters.forEach(({ resolve }) => {
|
|
165
|
+
resolve();
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
catch (error) {
|
|
169
|
+
batch.waiters.forEach(({ reject }) => {
|
|
170
|
+
reject(error);
|
|
171
|
+
});
|
|
172
|
+
throw error;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
async #send(details) {
|
|
176
|
+
const payloads = (await encodeValuesToPayloads(this.#options.dataConverter, details)) ?? [];
|
|
177
|
+
const request = create(RecordActivityTaskHeartbeatRequestSchema, {
|
|
178
|
+
taskToken: this.#options.taskToken,
|
|
179
|
+
identity: this.#options.identity,
|
|
180
|
+
namespace: this.#options.namespace,
|
|
181
|
+
details: payloads.length > 0 ? create(PayloadsSchema, { payloads }) : undefined,
|
|
182
|
+
});
|
|
183
|
+
const response = await this.#executeWithRetry(async () => {
|
|
184
|
+
return await this.#options.workflowService.recordActivityTaskHeartbeat(request, {
|
|
185
|
+
timeoutMs: this.#config.heartbeatRpcTimeoutMs,
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
this.#options.context.info.lastHeartbeatDetails = details;
|
|
189
|
+
this.#options.context.info.lastHeartbeatTime = new Date();
|
|
190
|
+
if (response.cancelRequested && !this.#options.abortController.signal.aborted) {
|
|
191
|
+
this.#options.context.info.cancellationReason = 'cancel-requested';
|
|
192
|
+
this.#options.abortController.abort(createAbortError('Activity cancellation requested by Temporal'));
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
async #executeWithRetry(operation) {
|
|
196
|
+
let attempt = 0;
|
|
197
|
+
let delayMs = this.#config.heartbeatRetry.initialIntervalMs;
|
|
198
|
+
for (;;) {
|
|
199
|
+
try {
|
|
200
|
+
return await operation();
|
|
201
|
+
}
|
|
202
|
+
catch (error) {
|
|
203
|
+
if (this.#options.abortController.signal.aborted) {
|
|
204
|
+
throw this.#options.abortController.signal.reason ?? error;
|
|
205
|
+
}
|
|
206
|
+
if (isHeartbeatNotFound(error)) {
|
|
207
|
+
this.#options.context.info.cancellationReason = 'not-found';
|
|
208
|
+
this.#options.abortController.abort(createAbortError('Activity heartbeat rejected: task not found'));
|
|
209
|
+
throw error;
|
|
210
|
+
}
|
|
211
|
+
if (!isRetriableHeartbeatError(error)) {
|
|
212
|
+
throw error;
|
|
213
|
+
}
|
|
214
|
+
attempt += 1;
|
|
215
|
+
if (attempt >= this.#config.heartbeatRetry.maxAttempts) {
|
|
216
|
+
this.#recordHeartbeatFailure(error);
|
|
217
|
+
throw error;
|
|
218
|
+
}
|
|
219
|
+
const capped = Math.min(delayMs, this.#config.heartbeatRetry.maxIntervalMs);
|
|
220
|
+
const jittered = applyJitter(capped, this.#retryJitterRatio);
|
|
221
|
+
this.#trackHeartbeatRetry();
|
|
222
|
+
await sleep(jittered);
|
|
223
|
+
delayMs = Math.min(delayMs * this.#config.heartbeatRetry.backoffCoefficient, this.#config.heartbeatRetry.maxIntervalMs);
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
#computeInterval(heartbeatTimeoutMs) {
|
|
228
|
+
if (!heartbeatTimeoutMs) {
|
|
229
|
+
return Math.max(this.#config.heartbeatIntervalMs, MIN_HEARTBEAT_INTERVAL_MS);
|
|
230
|
+
}
|
|
231
|
+
const safeInterval = Math.max(Math.floor(heartbeatTimeoutMs * 0.8), MIN_HEARTBEAT_INTERVAL_MS);
|
|
232
|
+
return Math.min(this.#config.heartbeatIntervalMs, safeInterval);
|
|
233
|
+
}
|
|
234
|
+
#stopImmediately() {
|
|
235
|
+
this.#stopped = true;
|
|
236
|
+
if (this.#timer) {
|
|
237
|
+
clearTimeout(this.#timer);
|
|
238
|
+
this.#timer = undefined;
|
|
239
|
+
}
|
|
240
|
+
this.#rejectPending(createAbortError('Activity heartbeat stopped'));
|
|
241
|
+
}
|
|
242
|
+
#rejectPending(error) {
|
|
243
|
+
const pending = this.#pending;
|
|
244
|
+
if (!pending) {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
this.#pending = undefined;
|
|
248
|
+
for (const waiter of pending.waiters) {
|
|
249
|
+
waiter.reject(error);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
#recordHeartbeatFailure(error) {
|
|
253
|
+
if (typeof error === 'object' && error !== null) {
|
|
254
|
+
if (this.#recordedHeartbeatErrors.has(error)) {
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
this.#recordedHeartbeatErrors.add(error);
|
|
258
|
+
}
|
|
259
|
+
const observability = this.#observability;
|
|
260
|
+
if (!observability) {
|
|
261
|
+
return;
|
|
262
|
+
}
|
|
263
|
+
const info = this.#options.context.info;
|
|
264
|
+
const fields = {
|
|
265
|
+
namespace: this.#options.namespace,
|
|
266
|
+
taskQueue: info.taskQueue,
|
|
267
|
+
workflowId: info.workflowId,
|
|
268
|
+
runId: info.runId,
|
|
269
|
+
activityId: info.activityId,
|
|
270
|
+
attempt: info.attempt,
|
|
271
|
+
errorName: error instanceof Error ? error.name : undefined,
|
|
272
|
+
errorMessage: error instanceof Error ? error.message : String(error),
|
|
273
|
+
};
|
|
274
|
+
void Effect.runPromise(observability.logger.log('warn', 'activity heartbeat failure', fields));
|
|
275
|
+
void Effect.runPromise(observability.heartbeatFailureCounter.inc());
|
|
276
|
+
}
|
|
277
|
+
#trackHeartbeatRetry() {
|
|
278
|
+
const observability = this.#observability;
|
|
279
|
+
if (!observability) {
|
|
280
|
+
return;
|
|
281
|
+
}
|
|
282
|
+
void Effect.runPromise(observability.heartbeatRetryCounter.inc());
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
const isRetriableHeartbeatError = (error) => {
|
|
286
|
+
if (!(error instanceof ConnectError)) {
|
|
287
|
+
return false;
|
|
288
|
+
}
|
|
289
|
+
return RETRIABLE_HEARTBEAT_CODES.has(error.code);
|
|
290
|
+
};
|
|
291
|
+
const isHeartbeatNotFound = (error) => error instanceof ConnectError && error.code === Code.NotFound;
|
|
292
|
+
const createAbortError = (message) => {
|
|
293
|
+
const error = new Error(message);
|
|
294
|
+
error.name = 'AbortError';
|
|
295
|
+
return error;
|
|
296
|
+
};
|
|
297
|
+
const applyJitter = (delayMs, ratio) => {
|
|
298
|
+
if (ratio <= 0) {
|
|
299
|
+
return delayMs;
|
|
300
|
+
}
|
|
301
|
+
const minFactor = 1 - ratio / 2;
|
|
302
|
+
const maxFactor = 1 + ratio / 2;
|
|
303
|
+
const factor = minFactor + Math.random() * (maxFactor - minFactor);
|
|
304
|
+
return Math.max(MIN_HEARTBEAT_INTERVAL_MS, Math.round(delayMs * factor));
|
|
305
|
+
};
|
|
306
|
+
//# sourceMappingURL=lifecycle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifecycle.js","sourceRoot":"","sources":["../../../src/activities/lifecycle.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Effect } from 'effect';
|
|
2
|
+
import type { TemporalConfig } from '../config';
|
|
3
|
+
import { type HistoryEvent } from '../proto/temporal/api/history/v1/message_pb';
|
|
4
|
+
import { ObservabilityService, TemporalConfigService, type WorkflowServiceClient, WorkflowServiceClientService } from '../runtime/effect-layers';
|
|
5
|
+
import type { WorkflowInfo } from '../workflow/context';
|
|
6
|
+
import type { WorkflowDeterminismFailureMetadata } from '../workflow/determinism';
|
|
7
|
+
import { type DeterminismDiffResult } from '../workflow/replay';
|
|
8
|
+
type ReplayHistorySourceKind = 'file' | 'cli' | 'service';
|
|
9
|
+
export type ReplayHistorySourcePreference = 'auto' | 'cli' | 'service';
|
|
10
|
+
interface WorkflowExecutionRef {
|
|
11
|
+
readonly workflowId: string;
|
|
12
|
+
readonly runId: string;
|
|
13
|
+
}
|
|
14
|
+
interface ReplayCommandOptions {
|
|
15
|
+
readonly historyFile?: string;
|
|
16
|
+
readonly execution?: WorkflowExecutionRef;
|
|
17
|
+
readonly workflowType?: string;
|
|
18
|
+
readonly namespaceOverride?: string;
|
|
19
|
+
readonly temporalCliPath?: string;
|
|
20
|
+
readonly source: ReplayHistorySourcePreference;
|
|
21
|
+
readonly jsonOutput: boolean;
|
|
22
|
+
}
|
|
23
|
+
interface HistoryMetadata {
|
|
24
|
+
readonly workflowId?: string;
|
|
25
|
+
readonly runId?: string;
|
|
26
|
+
readonly workflowType?: string;
|
|
27
|
+
readonly namespace?: string;
|
|
28
|
+
readonly taskQueue?: string;
|
|
29
|
+
readonly temporalVersion?: string;
|
|
30
|
+
}
|
|
31
|
+
interface HistorySourceRecord {
|
|
32
|
+
readonly events: HistoryEvent[];
|
|
33
|
+
readonly source: ReplayHistorySourceKind;
|
|
34
|
+
readonly description: string;
|
|
35
|
+
readonly metadata: HistoryMetadata;
|
|
36
|
+
}
|
|
37
|
+
interface HistoryLoaderAttempt {
|
|
38
|
+
readonly source: Exclude<ReplayHistorySourceKind, 'file'>;
|
|
39
|
+
readonly error: string;
|
|
40
|
+
}
|
|
41
|
+
interface HistoryLoadOutcome {
|
|
42
|
+
readonly record: HistorySourceRecord;
|
|
43
|
+
readonly attempts: HistoryLoaderAttempt[];
|
|
44
|
+
}
|
|
45
|
+
type HistoryLoaders = {
|
|
46
|
+
readonly cli: typeof loadHistoryViaCli;
|
|
47
|
+
readonly service: typeof loadHistoryViaService;
|
|
48
|
+
};
|
|
49
|
+
export interface ReplayRunResult {
|
|
50
|
+
readonly exitCode: number;
|
|
51
|
+
readonly summary: ReplaySummary;
|
|
52
|
+
}
|
|
53
|
+
export interface ReplaySummary {
|
|
54
|
+
readonly workflow: WorkflowInfo;
|
|
55
|
+
readonly history: {
|
|
56
|
+
readonly source: ReplayHistorySourceKind;
|
|
57
|
+
readonly description: string;
|
|
58
|
+
readonly eventCount: number;
|
|
59
|
+
readonly lastEventId: string | null;
|
|
60
|
+
readonly metadata: HistoryMetadata;
|
|
61
|
+
};
|
|
62
|
+
readonly determinism: {
|
|
63
|
+
readonly hasMarker: boolean;
|
|
64
|
+
readonly mismatchCount: number;
|
|
65
|
+
readonly mismatches: DeterminismDiffResult['mismatches'];
|
|
66
|
+
readonly failureMetadata?: WorkflowDeterminismFailureMetadata;
|
|
67
|
+
};
|
|
68
|
+
readonly attempts: HistoryLoaderAttempt[];
|
|
69
|
+
readonly preference: ReplayHistorySourcePreference;
|
|
70
|
+
readonly startedAtIso: string;
|
|
71
|
+
readonly durationMs: number;
|
|
72
|
+
readonly status: 'ok' | 'nondeterministic';
|
|
73
|
+
}
|
|
74
|
+
declare class ReplayCommandError extends Error {
|
|
75
|
+
readonly details?: Record<string, unknown>;
|
|
76
|
+
constructor(message: string, details?: Record<string, unknown>);
|
|
77
|
+
}
|
|
78
|
+
export declare const executeReplay: (flagsOrOptions: Record<string, string | boolean> | ReplayCommandOptions) => Effect.Effect<ReplayRunResult, ReplayCommandError, TemporalConfigService | ObservabilityService | WorkflowServiceClientService>;
|
|
79
|
+
export declare const parseReplayOptions: (flags: Record<string, string | boolean>) => ReplayCommandOptions;
|
|
80
|
+
export declare const parseExecutionFlag: (value: string) => WorkflowExecutionRef;
|
|
81
|
+
declare function loadHistoryViaCli({ options, config, namespace, }: {
|
|
82
|
+
readonly options: ReplayCommandOptions;
|
|
83
|
+
readonly config: TemporalConfig;
|
|
84
|
+
readonly namespace: string;
|
|
85
|
+
}): Promise<HistorySourceRecord>;
|
|
86
|
+
declare function loadHistoryViaService({ options, config, namespace, workflowService, }: {
|
|
87
|
+
readonly options: ReplayCommandOptions;
|
|
88
|
+
readonly config: TemporalConfig;
|
|
89
|
+
readonly namespace: string;
|
|
90
|
+
readonly workflowService: WorkflowServiceClient;
|
|
91
|
+
}): Promise<HistorySourceRecord>;
|
|
92
|
+
export declare const printReplaySummary: (summary: ReplaySummary, jsonOutput: boolean) => void;
|
|
93
|
+
export declare const replayCommandTestHooks: {
|
|
94
|
+
loadHistoryFromFile: (filePath: string) => Promise<HistorySourceRecord>;
|
|
95
|
+
loadExecutionHistory: ({ options, config, loaders, workflowService, }: {
|
|
96
|
+
readonly options: ReplayCommandOptions;
|
|
97
|
+
readonly config: TemporalConfig;
|
|
98
|
+
readonly loaders: HistoryLoaders;
|
|
99
|
+
readonly workflowService: WorkflowServiceClient;
|
|
100
|
+
}) => Promise<HistoryLoadOutcome>;
|
|
101
|
+
executeReplay: (flagsOrOptions: Record<string, string | boolean> | ReplayCommandOptions) => Effect.Effect<ReplayRunResult, ReplayCommandError, TemporalConfigService | ObservabilityService | WorkflowServiceClientService>;
|
|
102
|
+
};
|
|
103
|
+
export {};
|
|
104
|
+
//# sourceMappingURL=replay-command.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"replay-command.d.ts","sourceRoot":"","sources":["../../../src/bin/replay-command.ts"],"names":[],"mappings":"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"}
|