temporalio 0.1.1 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Cargo.lock +4035 -0
- data/Cargo.toml +25 -0
- data/Gemfile +20 -0
- data/LICENSE +16 -15
- data/README.md +455 -195
- data/Rakefile +387 -0
- data/ext/Cargo.toml +25 -0
- data/lib/temporalio/activity/complete_async_error.rb +11 -0
- data/lib/temporalio/activity/context.rb +82 -77
- data/lib/temporalio/activity/definition.rb +77 -0
- data/lib/temporalio/activity/info.rb +42 -46
- data/lib/temporalio/activity.rb +49 -65
- data/lib/temporalio/api/batch/v1/message.rb +31 -0
- data/lib/temporalio/api/cloud/cloudservice/v1/request_response.rb +93 -0
- data/lib/temporalio/api/cloud/cloudservice/v1/service.rb +25 -0
- data/lib/temporalio/api/cloud/cloudservice.rb +3 -0
- data/lib/temporalio/api/cloud/identity/v1/message.rb +36 -0
- data/lib/temporalio/api/cloud/namespace/v1/message.rb +35 -0
- data/lib/temporalio/api/cloud/operation/v1/message.rb +27 -0
- data/lib/temporalio/api/cloud/region/v1/message.rb +23 -0
- data/lib/temporalio/api/command/v1/message.rb +46 -0
- data/lib/temporalio/api/common/v1/grpc_status.rb +23 -0
- data/lib/temporalio/api/common/v1/message.rb +41 -0
- data/lib/temporalio/api/enums/v1/batch_operation.rb +22 -0
- data/lib/temporalio/api/enums/v1/command_type.rb +21 -0
- data/lib/temporalio/api/enums/v1/common.rb +26 -0
- data/lib/temporalio/api/enums/v1/event_type.rb +21 -0
- data/lib/temporalio/api/enums/v1/failed_cause.rb +26 -0
- data/lib/temporalio/api/enums/v1/namespace.rb +23 -0
- data/lib/temporalio/api/enums/v1/query.rb +22 -0
- data/lib/temporalio/api/enums/v1/reset.rb +23 -0
- data/lib/temporalio/api/enums/v1/schedule.rb +21 -0
- data/lib/temporalio/api/enums/v1/task_queue.rb +25 -0
- data/lib/temporalio/api/enums/v1/update.rb +22 -0
- data/lib/temporalio/api/enums/v1/workflow.rb +30 -0
- data/lib/temporalio/api/errordetails/v1/message.rb +42 -0
- data/lib/temporalio/api/export/v1/message.rb +24 -0
- data/lib/temporalio/api/failure/v1/message.rb +35 -0
- data/lib/temporalio/api/filter/v1/message.rb +27 -0
- data/lib/temporalio/api/history/v1/message.rb +90 -0
- data/lib/temporalio/api/namespace/v1/message.rb +31 -0
- data/lib/temporalio/api/nexus/v1/message.rb +40 -0
- data/lib/temporalio/api/operatorservice/v1/request_response.rb +49 -0
- data/lib/temporalio/api/operatorservice/v1/service.rb +23 -0
- data/lib/temporalio/api/operatorservice.rb +3 -0
- data/lib/temporalio/api/protocol/v1/message.rb +23 -0
- data/lib/temporalio/api/query/v1/message.rb +27 -0
- data/lib/temporalio/api/replication/v1/message.rb +26 -0
- data/lib/temporalio/api/schedule/v1/message.rb +42 -0
- data/lib/temporalio/api/sdk/v1/enhanced_stack_trace.rb +25 -0
- data/lib/temporalio/api/sdk/v1/task_complete_metadata.rb +21 -0
- data/lib/temporalio/api/sdk/v1/user_metadata.rb +23 -0
- data/lib/temporalio/api/sdk/v1/workflow_metadata.rb +23 -0
- data/lib/temporalio/api/taskqueue/v1/message.rb +45 -0
- data/lib/temporalio/api/update/v1/message.rb +33 -0
- data/lib/temporalio/api/version/v1/message.rb +26 -0
- data/lib/temporalio/api/workflow/v1/message.rb +43 -0
- data/lib/temporalio/api/workflowservice/v1/request_response.rb +189 -0
- data/lib/temporalio/api/workflowservice/v1/service.rb +23 -0
- data/lib/temporalio/api/workflowservice.rb +3 -0
- data/lib/temporalio/api.rb +13 -0
- data/lib/temporalio/cancellation.rb +150 -0
- data/lib/temporalio/client/activity_id_reference.rb +32 -0
- data/lib/temporalio/client/async_activity_handle.rb +110 -0
- data/lib/temporalio/client/connection/cloud_service.rb +648 -0
- data/lib/temporalio/client/connection/operator_service.rb +249 -0
- data/lib/temporalio/client/connection/service.rb +41 -0
- data/lib/temporalio/client/connection/workflow_service.rb +1218 -0
- data/lib/temporalio/client/connection.rb +270 -0
- data/lib/temporalio/client/interceptor.rb +316 -0
- data/lib/temporalio/client/workflow_execution.rb +103 -0
- data/lib/temporalio/client/workflow_execution_count.rb +36 -0
- data/lib/temporalio/client/workflow_execution_status.rb +18 -0
- data/lib/temporalio/client/workflow_handle.rb +380 -177
- data/lib/temporalio/client/workflow_query_reject_condition.rb +14 -0
- data/lib/temporalio/client/workflow_update_handle.rb +67 -0
- data/lib/temporalio/client/workflow_update_wait_stage.rb +17 -0
- data/lib/temporalio/client.rb +366 -93
- data/lib/temporalio/common_enums.rb +24 -0
- data/lib/temporalio/converters/data_converter.rb +102 -0
- data/lib/temporalio/converters/failure_converter.rb +200 -0
- data/lib/temporalio/converters/payload_codec.rb +26 -0
- data/lib/temporalio/converters/payload_converter/binary_null.rb +34 -0
- data/lib/temporalio/converters/payload_converter/binary_plain.rb +35 -0
- data/lib/temporalio/converters/payload_converter/binary_protobuf.rb +42 -0
- data/lib/temporalio/converters/payload_converter/composite.rb +62 -0
- data/lib/temporalio/converters/payload_converter/encoding.rb +35 -0
- data/lib/temporalio/converters/payload_converter/json_plain.rb +44 -0
- data/lib/temporalio/converters/payload_converter/json_protobuf.rb +41 -0
- data/lib/temporalio/converters/payload_converter.rb +73 -0
- data/lib/temporalio/converters.rb +9 -0
- data/lib/temporalio/error/failure.rb +119 -94
- data/lib/temporalio/error.rb +147 -0
- data/lib/temporalio/internal/bridge/api/activity_result/activity_result.rb +34 -0
- data/lib/temporalio/internal/bridge/api/activity_task/activity_task.rb +31 -0
- data/lib/temporalio/internal/bridge/api/child_workflow/child_workflow.rb +33 -0
- data/lib/temporalio/internal/bridge/api/common/common.rb +26 -0
- data/lib/temporalio/internal/bridge/api/core_interface.rb +36 -0
- data/lib/temporalio/internal/bridge/api/external_data/external_data.rb +27 -0
- data/lib/temporalio/internal/bridge/api/workflow_activation/workflow_activation.rb +52 -0
- data/lib/temporalio/internal/bridge/api/workflow_commands/workflow_commands.rb +54 -0
- data/lib/temporalio/internal/bridge/api/workflow_completion/workflow_completion.rb +30 -0
- data/lib/temporalio/internal/bridge/api.rb +3 -0
- data/lib/temporalio/internal/bridge/client.rb +90 -0
- data/lib/temporalio/internal/bridge/runtime.rb +53 -0
- data/lib/temporalio/internal/bridge/testing.rb +46 -0
- data/lib/temporalio/internal/bridge/worker.rb +83 -0
- data/lib/temporalio/internal/bridge.rb +36 -0
- data/lib/temporalio/internal/client/implementation.rb +525 -0
- data/lib/temporalio/internal/proto_utils.rb +54 -0
- data/lib/temporalio/internal/worker/activity_worker.rb +345 -0
- data/lib/temporalio/internal/worker/multi_runner.rb +169 -0
- data/lib/temporalio/internal.rb +7 -0
- data/lib/temporalio/retry_policy.rb +39 -80
- data/lib/temporalio/runtime.rb +259 -13
- data/lib/temporalio/scoped_logger.rb +96 -0
- data/lib/temporalio/search_attributes.rb +300 -0
- data/lib/temporalio/testing/activity_environment.rb +132 -0
- data/lib/temporalio/testing/workflow_environment.rb +113 -88
- data/lib/temporalio/testing.rb +4 -169
- data/lib/temporalio/version.rb +3 -1
- data/lib/temporalio/worker/activity_executor/fiber.rb +49 -0
- data/lib/temporalio/worker/activity_executor/thread_pool.rb +254 -0
- data/lib/temporalio/worker/activity_executor.rb +55 -0
- data/lib/temporalio/worker/interceptor.rb +88 -0
- data/lib/temporalio/worker/tuner.rb +151 -0
- data/lib/temporalio/worker.rb +385 -163
- data/lib/temporalio/workflow_history.rb +22 -0
- data/lib/temporalio.rb +2 -7
- data/temporalio.gemspec +20 -39
- metadata +131 -712
- data/bridge/Cargo.lock +0 -2997
- data/bridge/Cargo.toml +0 -29
- data/bridge/sdk-core/ARCHITECTURE.md +0 -76
- data/bridge/sdk-core/Cargo.toml +0 -2
- data/bridge/sdk-core/LICENSE.txt +0 -23
- data/bridge/sdk-core/README.md +0 -117
- data/bridge/sdk-core/arch_docs/diagrams/README.md +0 -10
- data/bridge/sdk-core/arch_docs/diagrams/sticky_queues.puml +0 -40
- data/bridge/sdk-core/arch_docs/diagrams/workflow_internals.svg +0 -1
- data/bridge/sdk-core/arch_docs/sticky_queues.md +0 -51
- data/bridge/sdk-core/client/Cargo.toml +0 -40
- data/bridge/sdk-core/client/LICENSE.txt +0 -23
- data/bridge/sdk-core/client/src/lib.rs +0 -1462
- data/bridge/sdk-core/client/src/metrics.rs +0 -174
- data/bridge/sdk-core/client/src/raw.rs +0 -932
- data/bridge/sdk-core/client/src/retry.rs +0 -763
- data/bridge/sdk-core/client/src/workflow_handle/mod.rs +0 -185
- data/bridge/sdk-core/core/Cargo.toml +0 -129
- data/bridge/sdk-core/core/LICENSE.txt +0 -23
- data/bridge/sdk-core/core/benches/workflow_replay.rs +0 -76
- data/bridge/sdk-core/core/src/abstractions.rs +0 -355
- data/bridge/sdk-core/core/src/core_tests/activity_tasks.rs +0 -1049
- data/bridge/sdk-core/core/src/core_tests/child_workflows.rs +0 -221
- data/bridge/sdk-core/core/src/core_tests/determinism.rs +0 -270
- data/bridge/sdk-core/core/src/core_tests/local_activities.rs +0 -1046
- data/bridge/sdk-core/core/src/core_tests/mod.rs +0 -100
- data/bridge/sdk-core/core/src/core_tests/queries.rs +0 -893
- data/bridge/sdk-core/core/src/core_tests/replay_flag.rs +0 -65
- data/bridge/sdk-core/core/src/core_tests/workers.rs +0 -257
- data/bridge/sdk-core/core/src/core_tests/workflow_cancels.rs +0 -124
- data/bridge/sdk-core/core/src/core_tests/workflow_tasks.rs +0 -2433
- data/bridge/sdk-core/core/src/ephemeral_server/mod.rs +0 -609
- data/bridge/sdk-core/core/src/internal_flags.rs +0 -136
- data/bridge/sdk-core/core/src/lib.rs +0 -289
- data/bridge/sdk-core/core/src/pollers/mod.rs +0 -54
- data/bridge/sdk-core/core/src/pollers/poll_buffer.rs +0 -297
- data/bridge/sdk-core/core/src/protosext/mod.rs +0 -428
- data/bridge/sdk-core/core/src/replay/mod.rs +0 -215
- data/bridge/sdk-core/core/src/retry_logic.rs +0 -202
- data/bridge/sdk-core/core/src/telemetry/log_export.rs +0 -190
- data/bridge/sdk-core/core/src/telemetry/metrics.rs +0 -462
- data/bridge/sdk-core/core/src/telemetry/mod.rs +0 -423
- data/bridge/sdk-core/core/src/telemetry/prometheus_server.rs +0 -83
- data/bridge/sdk-core/core/src/test_help/mod.rs +0 -939
- data/bridge/sdk-core/core/src/worker/activities/activity_heartbeat_manager.rs +0 -536
- data/bridge/sdk-core/core/src/worker/activities/activity_task_poller_stream.rs +0 -89
- data/bridge/sdk-core/core/src/worker/activities/local_activities.rs +0 -1278
- data/bridge/sdk-core/core/src/worker/activities.rs +0 -557
- data/bridge/sdk-core/core/src/worker/client/mocks.rs +0 -107
- data/bridge/sdk-core/core/src/worker/client.rs +0 -389
- data/bridge/sdk-core/core/src/worker/mod.rs +0 -677
- data/bridge/sdk-core/core/src/worker/workflow/bridge.rs +0 -35
- data/bridge/sdk-core/core/src/worker/workflow/driven_workflow.rs +0 -99
- data/bridge/sdk-core/core/src/worker/workflow/history_update.rs +0 -1111
- data/bridge/sdk-core/core/src/worker/workflow/machines/activity_state_machine.rs +0 -964
- data/bridge/sdk-core/core/src/worker/workflow/machines/cancel_external_state_machine.rs +0 -294
- data/bridge/sdk-core/core/src/worker/workflow/machines/cancel_workflow_state_machine.rs +0 -168
- data/bridge/sdk-core/core/src/worker/workflow/machines/child_workflow_state_machine.rs +0 -918
- data/bridge/sdk-core/core/src/worker/workflow/machines/complete_workflow_state_machine.rs +0 -137
- data/bridge/sdk-core/core/src/worker/workflow/machines/continue_as_new_workflow_state_machine.rs +0 -158
- data/bridge/sdk-core/core/src/worker/workflow/machines/fail_workflow_state_machine.rs +0 -130
- data/bridge/sdk-core/core/src/worker/workflow/machines/local_activity_state_machine.rs +0 -1525
- data/bridge/sdk-core/core/src/worker/workflow/machines/mod.rs +0 -324
- data/bridge/sdk-core/core/src/worker/workflow/machines/modify_workflow_properties_state_machine.rs +0 -179
- data/bridge/sdk-core/core/src/worker/workflow/machines/patch_state_machine.rs +0 -659
- data/bridge/sdk-core/core/src/worker/workflow/machines/signal_external_state_machine.rs +0 -439
- data/bridge/sdk-core/core/src/worker/workflow/machines/timer_state_machine.rs +0 -435
- data/bridge/sdk-core/core/src/worker/workflow/machines/transition_coverage.rs +0 -175
- data/bridge/sdk-core/core/src/worker/workflow/machines/upsert_search_attributes_state_machine.rs +0 -249
- data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_machines/local_acts.rs +0 -85
- data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_machines.rs +0 -1280
- data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_task_state_machine.rs +0 -269
- data/bridge/sdk-core/core/src/worker/workflow/managed_run/managed_wf_test.rs +0 -213
- data/bridge/sdk-core/core/src/worker/workflow/managed_run.rs +0 -1305
- data/bridge/sdk-core/core/src/worker/workflow/mod.rs +0 -1276
- data/bridge/sdk-core/core/src/worker/workflow/run_cache.rs +0 -128
- data/bridge/sdk-core/core/src/worker/workflow/wft_extraction.rs +0 -125
- data/bridge/sdk-core/core/src/worker/workflow/wft_poller.rs +0 -85
- data/bridge/sdk-core/core/src/worker/workflow/workflow_stream/saved_wf_inputs.rs +0 -117
- data/bridge/sdk-core/core/src/worker/workflow/workflow_stream/tonic_status_serde.rs +0 -24
- data/bridge/sdk-core/core/src/worker/workflow/workflow_stream.rs +0 -715
- data/bridge/sdk-core/core-api/Cargo.toml +0 -33
- data/bridge/sdk-core/core-api/LICENSE.txt +0 -23
- data/bridge/sdk-core/core-api/src/errors.rs +0 -62
- data/bridge/sdk-core/core-api/src/lib.rs +0 -113
- data/bridge/sdk-core/core-api/src/telemetry.rs +0 -141
- data/bridge/sdk-core/core-api/src/worker.rs +0 -161
- data/bridge/sdk-core/etc/deps.svg +0 -162
- data/bridge/sdk-core/etc/dynamic-config.yaml +0 -2
- data/bridge/sdk-core/etc/otel-collector-config.yaml +0 -36
- data/bridge/sdk-core/etc/prometheus.yaml +0 -6
- data/bridge/sdk-core/etc/regen-depgraph.sh +0 -5
- data/bridge/sdk-core/fsm/Cargo.toml +0 -18
- data/bridge/sdk-core/fsm/LICENSE.txt +0 -23
- data/bridge/sdk-core/fsm/README.md +0 -3
- data/bridge/sdk-core/fsm/rustfsm_procmacro/Cargo.toml +0 -27
- data/bridge/sdk-core/fsm/rustfsm_procmacro/LICENSE.txt +0 -23
- data/bridge/sdk-core/fsm/rustfsm_procmacro/src/lib.rs +0 -650
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/progress.rs +0 -8
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/dupe_transitions_fail.rs +0 -18
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/dupe_transitions_fail.stderr +0 -12
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/dynamic_dest_pass.rs +0 -41
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/forgot_name_fail.rs +0 -14
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/forgot_name_fail.stderr +0 -11
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/handler_arg_pass.rs +0 -32
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/handler_pass.rs +0 -31
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/medium_complex_pass.rs +0 -46
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/no_handle_conversions_require_into_fail.rs +0 -29
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/no_handle_conversions_require_into_fail.stderr +0 -12
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/simple_pass.rs +0 -32
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/struct_event_variant_fail.rs +0 -18
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/struct_event_variant_fail.stderr +0 -5
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_more_item_event_variant_fail.rs +0 -11
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_more_item_event_variant_fail.stderr +0 -5
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_zero_item_event_variant_fail.rs +0 -11
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_zero_item_event_variant_fail.stderr +0 -5
- data/bridge/sdk-core/fsm/rustfsm_trait/Cargo.toml +0 -14
- data/bridge/sdk-core/fsm/rustfsm_trait/LICENSE.txt +0 -23
- data/bridge/sdk-core/fsm/rustfsm_trait/src/lib.rs +0 -254
- data/bridge/sdk-core/fsm/src/lib.rs +0 -2
- data/bridge/sdk-core/histories/evict_while_la_running_no_interference-16_history.bin +0 -0
- data/bridge/sdk-core/histories/evict_while_la_running_no_interference-23_history.bin +0 -0
- data/bridge/sdk-core/histories/evict_while_la_running_no_interference-85_history.bin +0 -0
- data/bridge/sdk-core/histories/fail_wf_task.bin +0 -0
- data/bridge/sdk-core/histories/timer_workflow_history.bin +0 -0
- data/bridge/sdk-core/integ-with-otel.sh +0 -7
- data/bridge/sdk-core/protos/api_upstream/README.md +0 -9
- data/bridge/sdk-core/protos/api_upstream/api-linter.yaml +0 -40
- data/bridge/sdk-core/protos/api_upstream/buf.yaml +0 -9
- data/bridge/sdk-core/protos/api_upstream/build/go.mod +0 -7
- data/bridge/sdk-core/protos/api_upstream/build/go.sum +0 -5
- data/bridge/sdk-core/protos/api_upstream/build/tools.go +0 -29
- data/bridge/sdk-core/protos/api_upstream/dependencies/gogoproto/gogo.proto +0 -141
- data/bridge/sdk-core/protos/api_upstream/go.mod +0 -6
- data/bridge/sdk-core/protos/api_upstream/temporal/api/batch/v1/message.proto +0 -89
- data/bridge/sdk-core/protos/api_upstream/temporal/api/command/v1/message.proto +0 -248
- data/bridge/sdk-core/protos/api_upstream/temporal/api/common/v1/message.proto +0 -123
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/batch_operation.proto +0 -47
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/command_type.proto +0 -52
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/common.proto +0 -56
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/event_type.proto +0 -170
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/failed_cause.proto +0 -123
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/namespace.proto +0 -51
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/query.proto +0 -50
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/reset.proto +0 -41
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/schedule.proto +0 -60
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/task_queue.proto +0 -59
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/update.proto +0 -56
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/workflow.proto +0 -122
- data/bridge/sdk-core/protos/api_upstream/temporal/api/errordetails/v1/message.proto +0 -108
- data/bridge/sdk-core/protos/api_upstream/temporal/api/failure/v1/message.proto +0 -114
- data/bridge/sdk-core/protos/api_upstream/temporal/api/filter/v1/message.proto +0 -56
- data/bridge/sdk-core/protos/api_upstream/temporal/api/history/v1/message.proto +0 -787
- data/bridge/sdk-core/protos/api_upstream/temporal/api/namespace/v1/message.proto +0 -99
- data/bridge/sdk-core/protos/api_upstream/temporal/api/operatorservice/v1/request_response.proto +0 -124
- data/bridge/sdk-core/protos/api_upstream/temporal/api/operatorservice/v1/service.proto +0 -80
- data/bridge/sdk-core/protos/api_upstream/temporal/api/protocol/v1/message.proto +0 -57
- data/bridge/sdk-core/protos/api_upstream/temporal/api/query/v1/message.proto +0 -61
- data/bridge/sdk-core/protos/api_upstream/temporal/api/replication/v1/message.proto +0 -55
- data/bridge/sdk-core/protos/api_upstream/temporal/api/schedule/v1/message.proto +0 -379
- data/bridge/sdk-core/protos/api_upstream/temporal/api/sdk/v1/task_complete_metadata.proto +0 -63
- data/bridge/sdk-core/protos/api_upstream/temporal/api/taskqueue/v1/message.proto +0 -108
- data/bridge/sdk-core/protos/api_upstream/temporal/api/update/v1/message.proto +0 -111
- data/bridge/sdk-core/protos/api_upstream/temporal/api/version/v1/message.proto +0 -59
- data/bridge/sdk-core/protos/api_upstream/temporal/api/workflow/v1/message.proto +0 -146
- data/bridge/sdk-core/protos/api_upstream/temporal/api/workflowservice/v1/request_response.proto +0 -1199
- data/bridge/sdk-core/protos/api_upstream/temporal/api/workflowservice/v1/service.proto +0 -415
- data/bridge/sdk-core/protos/grpc/health/v1/health.proto +0 -63
- data/bridge/sdk-core/protos/local/temporal/sdk/core/activity_result/activity_result.proto +0 -79
- data/bridge/sdk-core/protos/local/temporal/sdk/core/activity_task/activity_task.proto +0 -80
- data/bridge/sdk-core/protos/local/temporal/sdk/core/child_workflow/child_workflow.proto +0 -78
- data/bridge/sdk-core/protos/local/temporal/sdk/core/common/common.proto +0 -16
- data/bridge/sdk-core/protos/local/temporal/sdk/core/core_interface.proto +0 -31
- data/bridge/sdk-core/protos/local/temporal/sdk/core/external_data/external_data.proto +0 -31
- data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_activation/workflow_activation.proto +0 -270
- data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_commands/workflow_commands.proto +0 -305
- data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_completion/workflow_completion.proto +0 -35
- data/bridge/sdk-core/protos/testsrv_upstream/api-linter.yaml +0 -38
- data/bridge/sdk-core/protos/testsrv_upstream/buf.yaml +0 -13
- data/bridge/sdk-core/protos/testsrv_upstream/dependencies/gogoproto/gogo.proto +0 -141
- data/bridge/sdk-core/protos/testsrv_upstream/temporal/api/testservice/v1/request_response.proto +0 -63
- data/bridge/sdk-core/protos/testsrv_upstream/temporal/api/testservice/v1/service.proto +0 -90
- data/bridge/sdk-core/rustfmt.toml +0 -1
- data/bridge/sdk-core/sdk/Cargo.toml +0 -48
- data/bridge/sdk-core/sdk/LICENSE.txt +0 -23
- data/bridge/sdk-core/sdk/src/activity_context.rs +0 -230
- data/bridge/sdk-core/sdk/src/app_data.rs +0 -37
- data/bridge/sdk-core/sdk/src/interceptors.rs +0 -50
- data/bridge/sdk-core/sdk/src/lib.rs +0 -861
- data/bridge/sdk-core/sdk/src/payload_converter.rs +0 -11
- data/bridge/sdk-core/sdk/src/workflow_context/options.rs +0 -295
- data/bridge/sdk-core/sdk/src/workflow_context.rs +0 -694
- data/bridge/sdk-core/sdk/src/workflow_future.rs +0 -500
- data/bridge/sdk-core/sdk-core-protos/Cargo.toml +0 -33
- data/bridge/sdk-core/sdk-core-protos/LICENSE.txt +0 -23
- data/bridge/sdk-core/sdk-core-protos/build.rs +0 -142
- data/bridge/sdk-core/sdk-core-protos/src/constants.rs +0 -7
- data/bridge/sdk-core/sdk-core-protos/src/history_builder.rs +0 -557
- data/bridge/sdk-core/sdk-core-protos/src/history_info.rs +0 -234
- data/bridge/sdk-core/sdk-core-protos/src/lib.rs +0 -2088
- data/bridge/sdk-core/sdk-core-protos/src/task_token.rs +0 -48
- data/bridge/sdk-core/sdk-core-protos/src/utilities.rs +0 -14
- data/bridge/sdk-core/test-utils/Cargo.toml +0 -38
- data/bridge/sdk-core/test-utils/src/canned_histories.rs +0 -1389
- data/bridge/sdk-core/test-utils/src/histfetch.rs +0 -28
- data/bridge/sdk-core/test-utils/src/lib.rs +0 -709
- data/bridge/sdk-core/test-utils/src/wf_input_saver.rs +0 -50
- data/bridge/sdk-core/test-utils/src/workflows.rs +0 -29
- data/bridge/sdk-core/tests/fuzzy_workflow.rs +0 -130
- data/bridge/sdk-core/tests/heavy_tests.rs +0 -265
- data/bridge/sdk-core/tests/integ_tests/client_tests.rs +0 -36
- data/bridge/sdk-core/tests/integ_tests/ephemeral_server_tests.rs +0 -150
- data/bridge/sdk-core/tests/integ_tests/heartbeat_tests.rs +0 -223
- data/bridge/sdk-core/tests/integ_tests/metrics_tests.rs +0 -239
- data/bridge/sdk-core/tests/integ_tests/polling_tests.rs +0 -90
- data/bridge/sdk-core/tests/integ_tests/queries_tests.rs +0 -314
- data/bridge/sdk-core/tests/integ_tests/visibility_tests.rs +0 -151
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/activities.rs +0 -902
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/appdata_propagation.rs +0 -61
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/cancel_external.rs +0 -60
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/cancel_wf.rs +0 -51
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/child_workflows.rs +0 -51
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/continue_as_new.rs +0 -64
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/determinism.rs +0 -47
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/local_activities.rs +0 -669
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/modify_wf_properties.rs +0 -54
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/patches.rs +0 -92
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/replay.rs +0 -228
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/resets.rs +0 -94
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/signals.rs +0 -171
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/stickyness.rs +0 -85
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/timers.rs +0 -120
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/upsert_search_attrs.rs +0 -77
- data/bridge/sdk-core/tests/integ_tests/workflow_tests.rs +0 -596
- data/bridge/sdk-core/tests/main.rs +0 -103
- data/bridge/sdk-core/tests/runner.rs +0 -132
- data/bridge/sdk-core/tests/wf_input_replay.rs +0 -32
- data/bridge/src/connection.rs +0 -202
- data/bridge/src/lib.rs +0 -494
- data/bridge/src/runtime.rs +0 -54
- data/bridge/src/test_server.rs +0 -153
- data/bridge/src/worker.rs +0 -197
- data/ext/Rakefile +0 -9
- data/lib/gen/dependencies/gogoproto/gogo_pb.rb +0 -14
- data/lib/gen/temporal/api/batch/v1/message_pb.rb +0 -50
- data/lib/gen/temporal/api/command/v1/message_pb.rb +0 -160
- data/lib/gen/temporal/api/common/v1/message_pb.rb +0 -73
- data/lib/gen/temporal/api/enums/v1/batch_operation_pb.rb +0 -33
- data/lib/gen/temporal/api/enums/v1/command_type_pb.rb +0 -37
- data/lib/gen/temporal/api/enums/v1/common_pb.rb +0 -42
- data/lib/gen/temporal/api/enums/v1/event_type_pb.rb +0 -68
- data/lib/gen/temporal/api/enums/v1/failed_cause_pb.rb +0 -79
- data/lib/gen/temporal/api/enums/v1/namespace_pb.rb +0 -37
- data/lib/gen/temporal/api/enums/v1/query_pb.rb +0 -31
- data/lib/gen/temporal/api/enums/v1/reset_pb.rb +0 -24
- data/lib/gen/temporal/api/enums/v1/schedule_pb.rb +0 -28
- data/lib/gen/temporal/api/enums/v1/task_queue_pb.rb +0 -30
- data/lib/gen/temporal/api/enums/v1/update_pb.rb +0 -25
- data/lib/gen/temporal/api/enums/v1/workflow_pb.rb +0 -89
- data/lib/gen/temporal/api/errordetails/v1/message_pb.rb +0 -84
- data/lib/gen/temporal/api/failure/v1/message_pb.rb +0 -83
- data/lib/gen/temporal/api/filter/v1/message_pb.rb +0 -40
- data/lib/gen/temporal/api/history/v1/message_pb.rb +0 -498
- data/lib/gen/temporal/api/namespace/v1/message_pb.rb +0 -64
- data/lib/gen/temporal/api/operatorservice/v1/request_response_pb.rb +0 -88
- data/lib/gen/temporal/api/operatorservice/v1/service_pb.rb +0 -20
- data/lib/gen/temporal/api/protocol/v1/message_pb.rb +0 -30
- data/lib/gen/temporal/api/query/v1/message_pb.rb +0 -38
- data/lib/gen/temporal/api/replication/v1/message_pb.rb +0 -37
- data/lib/gen/temporal/api/schedule/v1/message_pb.rb +0 -149
- data/lib/gen/temporal/api/sdk/v1/task_complete_metadata_pb.rb +0 -23
- data/lib/gen/temporal/api/taskqueue/v1/message_pb.rb +0 -73
- data/lib/gen/temporal/api/testservice/v1/request_response_pb.rb +0 -49
- data/lib/gen/temporal/api/testservice/v1/service_pb.rb +0 -21
- data/lib/gen/temporal/api/update/v1/message_pb.rb +0 -72
- data/lib/gen/temporal/api/version/v1/message_pb.rb +0 -41
- data/lib/gen/temporal/api/workflow/v1/message_pb.rb +0 -111
- data/lib/gen/temporal/api/workflowservice/v1/request_response_pb.rb +0 -798
- data/lib/gen/temporal/api/workflowservice/v1/service_pb.rb +0 -20
- data/lib/gen/temporal/sdk/core/activity_result/activity_result_pb.rb +0 -62
- data/lib/gen/temporal/sdk/core/activity_task/activity_task_pb.rb +0 -61
- data/lib/gen/temporal/sdk/core/child_workflow/child_workflow_pb.rb +0 -61
- data/lib/gen/temporal/sdk/core/common/common_pb.rb +0 -26
- data/lib/gen/temporal/sdk/core/core_interface_pb.rb +0 -40
- data/lib/gen/temporal/sdk/core/external_data/external_data_pb.rb +0 -31
- data/lib/gen/temporal/sdk/core/workflow_activation/workflow_activation_pb.rb +0 -171
- data/lib/gen/temporal/sdk/core/workflow_commands/workflow_commands_pb.rb +0 -200
- data/lib/gen/temporal/sdk/core/workflow_completion/workflow_completion_pb.rb +0 -41
- data/lib/temporalio/bridge/connect_options.rb +0 -15
- data/lib/temporalio/bridge/error.rb +0 -8
- data/lib/temporalio/bridge/retry_config.rb +0 -24
- data/lib/temporalio/bridge/tls_options.rb +0 -19
- data/lib/temporalio/bridge.rb +0 -14
- data/lib/temporalio/client/implementation.rb +0 -340
- data/lib/temporalio/connection/retry_config.rb +0 -44
- data/lib/temporalio/connection/service.rb +0 -20
- data/lib/temporalio/connection/test_service.rb +0 -92
- data/lib/temporalio/connection/tls_options.rb +0 -51
- data/lib/temporalio/connection/workflow_service.rb +0 -731
- data/lib/temporalio/connection.rb +0 -86
- data/lib/temporalio/data_converter.rb +0 -191
- data/lib/temporalio/error/workflow_failure.rb +0 -19
- data/lib/temporalio/errors.rb +0 -40
- data/lib/temporalio/failure_converter/base.rb +0 -26
- data/lib/temporalio/failure_converter/basic.rb +0 -319
- data/lib/temporalio/failure_converter.rb +0 -7
- data/lib/temporalio/interceptor/activity_inbound.rb +0 -22
- data/lib/temporalio/interceptor/activity_outbound.rb +0 -24
- data/lib/temporalio/interceptor/chain.rb +0 -28
- data/lib/temporalio/interceptor/client.rb +0 -127
- data/lib/temporalio/interceptor.rb +0 -22
- data/lib/temporalio/payload_codec/base.rb +0 -32
- data/lib/temporalio/payload_converter/base.rb +0 -24
- data/lib/temporalio/payload_converter/bytes.rb +0 -27
- data/lib/temporalio/payload_converter/composite.rb +0 -49
- data/lib/temporalio/payload_converter/encoding_base.rb +0 -35
- data/lib/temporalio/payload_converter/json.rb +0 -26
- data/lib/temporalio/payload_converter/nil.rb +0 -26
- data/lib/temporalio/payload_converter.rb +0 -14
- data/lib/temporalio/retry_state.rb +0 -35
- data/lib/temporalio/testing/time_skipping_handle.rb +0 -32
- data/lib/temporalio/testing/time_skipping_interceptor.rb +0 -23
- data/lib/temporalio/timeout_type.rb +0 -29
- data/lib/temporalio/worker/activity_runner.rb +0 -114
- data/lib/temporalio/worker/activity_worker.rb +0 -164
- data/lib/temporalio/worker/reactor.rb +0 -46
- data/lib/temporalio/worker/runner.rb +0 -63
- data/lib/temporalio/worker/sync_worker.rb +0 -124
- data/lib/temporalio/worker/thread_pool_executor.rb +0 -51
- data/lib/temporalio/workflow/async.rb +0 -46
- data/lib/temporalio/workflow/execution_info.rb +0 -54
- data/lib/temporalio/workflow/execution_status.rb +0 -36
- data/lib/temporalio/workflow/future.rb +0 -138
- data/lib/temporalio/workflow/id_reuse_policy.rb +0 -36
- data/lib/temporalio/workflow/info.rb +0 -76
- data/lib/temporalio/workflow/query_reject_condition.rb +0 -33
- data/lib/thermite_patch.rb +0 -33
- data/sig/async.rbs +0 -17
- data/sig/protobuf.rbs +0 -16
- data/sig/protos/dependencies/gogoproto/gogo.rbs +0 -914
- data/sig/protos/google/protobuf/any.rbs +0 -157
- data/sig/protos/google/protobuf/descriptor.rbs +0 -2825
- data/sig/protos/google/protobuf/duration.rbs +0 -114
- data/sig/protos/google/protobuf/empty.rbs +0 -36
- data/sig/protos/google/protobuf/timestamp.rbs +0 -145
- data/sig/protos/google/protobuf/wrappers.rbs +0 -358
- data/sig/protos/temporal/api/batch/v1/message.rbs +0 -300
- data/sig/protos/temporal/api/command/v1/message.rbs +0 -1399
- data/sig/protos/temporal/api/common/v1/message.rbs +0 -528
- data/sig/protos/temporal/api/enums/v1/batch_operation.rbs +0 -79
- data/sig/protos/temporal/api/enums/v1/command_type.rbs +0 -68
- data/sig/protos/temporal/api/enums/v1/common.rbs +0 -118
- data/sig/protos/temporal/api/enums/v1/event_type.rbs +0 -264
- data/sig/protos/temporal/api/enums/v1/failed_cause.rbs +0 -277
- data/sig/protos/temporal/api/enums/v1/namespace.rbs +0 -108
- data/sig/protos/temporal/api/enums/v1/query.rbs +0 -81
- data/sig/protos/temporal/api/enums/v1/reset.rbs +0 -44
- data/sig/protos/temporal/api/enums/v1/schedule.rbs +0 -72
- data/sig/protos/temporal/api/enums/v1/task_queue.rbs +0 -92
- data/sig/protos/temporal/api/enums/v1/update.rbs +0 -64
- data/sig/protos/temporal/api/enums/v1/workflow.rbs +0 -371
- data/sig/protos/temporal/api/errordetails/v1/message.rbs +0 -551
- data/sig/protos/temporal/api/failure/v1/message.rbs +0 -581
- data/sig/protos/temporal/api/filter/v1/message.rbs +0 -171
- data/sig/protos/temporal/api/history/v1/message.rbs +0 -4609
- data/sig/protos/temporal/api/namespace/v1/message.rbs +0 -410
- data/sig/protos/temporal/api/operatorservice/v1/request_response.rbs +0 -643
- data/sig/protos/temporal/api/operatorservice/v1/service.rbs +0 -17
- data/sig/protos/temporal/api/protocol/v1/message.rbs +0 -84
- data/sig/protos/temporal/api/query/v1/message.rbs +0 -182
- data/sig/protos/temporal/api/replication/v1/message.rbs +0 -148
- data/sig/protos/temporal/api/schedule/v1/message.rbs +0 -1488
- data/sig/protos/temporal/api/sdk/v1/task_complete_metadata.rbs +0 -110
- data/sig/protos/temporal/api/taskqueue/v1/message.rbs +0 -486
- data/sig/protos/temporal/api/testservice/v1/request_response.rbs +0 -249
- data/sig/protos/temporal/api/testservice/v1/service.rbs +0 -15
- data/sig/protos/temporal/api/update/v1/message.rbs +0 -489
- data/sig/protos/temporal/api/version/v1/message.rbs +0 -184
- data/sig/protos/temporal/api/workflow/v1/message.rbs +0 -824
- data/sig/protos/temporal/api/workflowservice/v1/request_response.rbs +0 -7250
- data/sig/protos/temporal/api/workflowservice/v1/service.rbs +0 -22
- data/sig/protos/temporal/sdk/core/activity_result/activity_result.rbs +0 -380
- data/sig/protos/temporal/sdk/core/activity_task/activity_task.rbs +0 -386
- data/sig/protos/temporal/sdk/core/child_workflow/child_workflow.rbs +0 -323
- data/sig/protos/temporal/sdk/core/common/common.rbs +0 -62
- data/sig/protos/temporal/sdk/core/core_interface.rbs +0 -101
- data/sig/protos/temporal/sdk/core/external_data/external_data.rbs +0 -119
- data/sig/protos/temporal/sdk/core/workflow_activation/workflow_activation.rbs +0 -1473
- data/sig/protos/temporal/sdk/core/workflow_commands/workflow_commands.rbs +0 -1784
- data/sig/protos/temporal/sdk/core/workflow_completion/workflow_completion.rbs +0 -180
- data/sig/ruby.rbs +0 -12
- data/sig/temporalio/activity/context.rbs +0 -29
- data/sig/temporalio/activity/info.rbs +0 -43
- data/sig/temporalio/activity.rbs +0 -19
- data/sig/temporalio/bridge/connect_options.rbs +0 -19
- data/sig/temporalio/bridge/error.rbs +0 -8
- data/sig/temporalio/bridge/retry_config.rbs +0 -21
- data/sig/temporalio/bridge/tls_options.rbs +0 -17
- data/sig/temporalio/bridge.rbs +0 -71
- data/sig/temporalio/client/implementation.rbs +0 -38
- data/sig/temporalio/client/workflow_handle.rbs +0 -41
- data/sig/temporalio/client.rbs +0 -35
- data/sig/temporalio/connection/retry_config.rbs +0 -37
- data/sig/temporalio/connection/service.rbs +0 -14
- data/sig/temporalio/connection/test_service.rbs +0 -13
- data/sig/temporalio/connection/tls_options.rbs +0 -43
- data/sig/temporalio/connection/workflow_service.rbs +0 -48
- data/sig/temporalio/connection.rbs +0 -30
- data/sig/temporalio/data_converter.rbs +0 -35
- data/sig/temporalio/error/failure.rbs +0 -121
- data/sig/temporalio/error/workflow_failure.rbs +0 -9
- data/sig/temporalio/errors.rbs +0 -36
- data/sig/temporalio/failure_converter/base.rbs +0 -12
- data/sig/temporalio/failure_converter/basic.rbs +0 -86
- data/sig/temporalio/failure_converter.rbs +0 -5
- data/sig/temporalio/interceptor/activity_inbound.rbs +0 -21
- data/sig/temporalio/interceptor/activity_outbound.rbs +0 -10
- data/sig/temporalio/interceptor/chain.rbs +0 -24
- data/sig/temporalio/interceptor/client.rbs +0 -148
- data/sig/temporalio/interceptor.rbs +0 -6
- data/sig/temporalio/payload_codec/base.rbs +0 -12
- data/sig/temporalio/payload_converter/base.rbs +0 -12
- data/sig/temporalio/payload_converter/bytes.rbs +0 -9
- data/sig/temporalio/payload_converter/composite.rbs +0 -19
- data/sig/temporalio/payload_converter/encoding_base.rbs +0 -14
- data/sig/temporalio/payload_converter/json.rbs +0 -9
- data/sig/temporalio/payload_converter/nil.rbs +0 -9
- data/sig/temporalio/payload_converter.rbs +0 -5
- data/sig/temporalio/retry_policy.rbs +0 -25
- data/sig/temporalio/retry_state.rbs +0 -20
- data/sig/temporalio/runtime.rbs +0 -12
- data/sig/temporalio/testing/time_skipping_handle.rbs +0 -15
- data/sig/temporalio/testing/time_skipping_interceptor.rbs +0 -13
- data/sig/temporalio/testing/workflow_environment.rbs +0 -22
- data/sig/temporalio/testing.rbs +0 -35
- data/sig/temporalio/timeout_type.rbs +0 -15
- data/sig/temporalio/version.rbs +0 -3
- data/sig/temporalio/worker/activity_runner.rbs +0 -35
- data/sig/temporalio/worker/activity_worker.rbs +0 -44
- data/sig/temporalio/worker/reactor.rbs +0 -22
- data/sig/temporalio/worker/runner.rbs +0 -21
- data/sig/temporalio/worker/sync_worker.rbs +0 -23
- data/sig/temporalio/worker/thread_pool_executor.rbs +0 -23
- data/sig/temporalio/worker.rbs +0 -46
- data/sig/temporalio/workflow/async.rbs +0 -9
- data/sig/temporalio/workflow/execution_info.rbs +0 -55
- data/sig/temporalio/workflow/execution_status.rbs +0 -21
- data/sig/temporalio/workflow/future.rbs +0 -40
- data/sig/temporalio/workflow/id_reuse_policy.rbs +0 -15
- data/sig/temporalio/workflow/info.rbs +0 -55
- data/sig/temporalio/workflow/query_reject_condition.rbs +0 -14
- data/sig/temporalio.rbs +0 -2
- data/sig/thermite_patch.rbs +0 -15
@@ -1,86 +0,0 @@
|
|
1
|
-
require 'temporalio/bridge'
|
2
|
-
require 'temporalio/bridge/connect_options'
|
3
|
-
require 'temporalio/bridge/tls_options'
|
4
|
-
require 'temporalio/connection/tls_options'
|
5
|
-
require 'temporalio/connection/test_service'
|
6
|
-
require 'temporalio/connection/workflow_service'
|
7
|
-
require 'temporalio/errors'
|
8
|
-
require 'temporalio/runtime'
|
9
|
-
require 'uri'
|
10
|
-
|
11
|
-
module Temporalio
|
12
|
-
# A connection to the Temporal server. It provides gRPC level communication to a Temporal server.
|
13
|
-
#
|
14
|
-
# Connections are usually used through either a {Temporalio::Client} or a {Temporalio::Worker}.
|
15
|
-
# It may also be used to perform gRPC requests to the server (see {#workflow_service}).
|
16
|
-
class Connection
|
17
|
-
# @api private
|
18
|
-
attr_reader :core_connection
|
19
|
-
|
20
|
-
# @param address [String | nil] `host[:port]` for the Temporal server. Defaults to `localhost:7233`.
|
21
|
-
# @param tls [Temporalio::Connection::TlsOptions | nil] TLS/mTLS options for the connection.
|
22
|
-
# By default, TLS is disabled.
|
23
|
-
# @param metadata [Hash | nil] gRPC metadata (ie. HTTP headers) to send with each request to the server. Optional.
|
24
|
-
# @param retry_config [Temporalio::Connection::RetryConfig | nil] gRPC retry configuration to use by default on this
|
25
|
-
# connection.
|
26
|
-
def initialize(
|
27
|
-
address = nil,
|
28
|
-
tls: nil,
|
29
|
-
metadata: nil,
|
30
|
-
retry_config: nil
|
31
|
-
)
|
32
|
-
host, port = parse_url(address)
|
33
|
-
|
34
|
-
runtime = Temporalio::Runtime.instance
|
35
|
-
|
36
|
-
@core_connection = Temporalio::Bridge::Connection.connect(
|
37
|
-
runtime.core_runtime,
|
38
|
-
Temporalio::Bridge::ConnectOptions.new(
|
39
|
-
url: tls ? "https://#{host}:#{port}" : "http://#{host}:#{port}",
|
40
|
-
tls: tls && Temporalio::Bridge::TlsOptions.new(
|
41
|
-
server_root_ca_cert: tls.server_root_ca_cert,
|
42
|
-
client_cert: tls.client_cert,
|
43
|
-
client_private_key: tls.client_private_key,
|
44
|
-
server_name_override: tls.server_name_override,
|
45
|
-
),
|
46
|
-
metadata: metadata,
|
47
|
-
retry_config: retry_config && Temporalio::Bridge::RetryConfig.new(
|
48
|
-
initial_interval_millis: retry_config.initial_interval_millis,
|
49
|
-
randomization_factor: retry_config.randomization_factor,
|
50
|
-
multiplier: retry_config.multiplier,
|
51
|
-
max_interval_millis: retry_config.max_interval_millis,
|
52
|
-
max_elapsed_time_millis: retry_config.max_elapsed_time_millis,
|
53
|
-
max_retries: retry_config.max_retries,
|
54
|
-
),
|
55
|
-
client_version: Temporalio::VERSION,
|
56
|
-
),
|
57
|
-
)
|
58
|
-
end
|
59
|
-
|
60
|
-
# Get an object for making WorkflowService RPCs.
|
61
|
-
#
|
62
|
-
# @return [Temporalio::Connection::WorkflowService]
|
63
|
-
def workflow_service
|
64
|
-
@workflow_service ||= Temporalio::Connection::WorkflowService.new(core_connection)
|
65
|
-
end
|
66
|
-
|
67
|
-
# Get an object for making TestService RPCs.
|
68
|
-
#
|
69
|
-
# @return [Temporalio::Connection::TestService]
|
70
|
-
def test_service
|
71
|
-
@test_service ||= Temporalio::Connection::TestService.new(core_connection)
|
72
|
-
end
|
73
|
-
|
74
|
-
private
|
75
|
-
|
76
|
-
def parse_url(url)
|
77
|
-
url ||= 'localhost:7233'
|
78
|
-
|
79
|
-
# Turn this into a valid URI before parsing
|
80
|
-
uri = URI.parse(url.include?('://') ? url : "//#{url}")
|
81
|
-
raise Temporalio::Error, 'Target host as URL with scheme are not supported' if uri.scheme
|
82
|
-
|
83
|
-
[uri.host || 'localhost', uri.port || 7233]
|
84
|
-
end
|
85
|
-
end
|
86
|
-
end
|
@@ -1,191 +0,0 @@
|
|
1
|
-
require 'temporal/api/common/v1/message_pb'
|
2
|
-
require 'temporalio/errors'
|
3
|
-
require 'temporalio/failure_converter'
|
4
|
-
require 'temporalio/payload_converter'
|
5
|
-
|
6
|
-
module Temporalio
|
7
|
-
class DataConverter
|
8
|
-
class MissingPayload < Temporalio::Error; end
|
9
|
-
|
10
|
-
# Initialize a new data converter with optional payload converter, codecs and failure converter.
|
11
|
-
#
|
12
|
-
# @param payload_converter [Temporalio::PayloadConverter::Base] A custom payload converter for
|
13
|
-
# converting Ruby values to/from protos. See {Temporalio::PayloadConverter::Base} for the
|
14
|
-
# interface definition.
|
15
|
-
# @param payload_codecs [Array<Temporalio::PayloadCodec::Base>] A list of payload codecs to
|
16
|
-
# transform payload protos. See {Temporalio::PayloadCodec::Base} for the interface definition.
|
17
|
-
# @param failure_converter [Temporalio::FailureConverter::Base] A custom failure converter for
|
18
|
-
# converting Exceptions to/from protos. See {Temporalio::FailureConverter::Base} for the
|
19
|
-
# interface definition.
|
20
|
-
#
|
21
|
-
# @see https://docs.temporal.io/concepts/what-is-a-data-converter for more information on
|
22
|
-
# payload converters and codecs.
|
23
|
-
def initialize(
|
24
|
-
payload_converter: Temporalio::PayloadConverter::DEFAULT,
|
25
|
-
payload_codecs: [],
|
26
|
-
failure_converter: Temporalio::FailureConverter::DEFAULT
|
27
|
-
)
|
28
|
-
@payload_converter = payload_converter
|
29
|
-
@payload_codecs = payload_codecs
|
30
|
-
@failure_converter = failure_converter
|
31
|
-
end
|
32
|
-
|
33
|
-
def to_payload(value)
|
34
|
-
payload = value_to_payload(value)
|
35
|
-
encoded_payload = encode([payload]).first
|
36
|
-
raise MissingPayload, 'Payload Codecs returned no payloads' unless encoded_payload
|
37
|
-
|
38
|
-
encoded_payload
|
39
|
-
end
|
40
|
-
|
41
|
-
def to_payload_array(data)
|
42
|
-
return [] if data.nil? || Array(data).empty?
|
43
|
-
|
44
|
-
payloads = Array(data).map { |value| value_to_payload(value) }
|
45
|
-
encode(payloads)
|
46
|
-
end
|
47
|
-
|
48
|
-
def to_payloads(data)
|
49
|
-
return if data.nil? || Array(data).empty?
|
50
|
-
|
51
|
-
payloads = Array(data).map { |value| value_to_payload(value) }
|
52
|
-
Temporalio::Api::Common::V1::Payloads.new(payloads: encode(payloads))
|
53
|
-
end
|
54
|
-
|
55
|
-
def to_payload_map(data)
|
56
|
-
data.to_h do |key, value|
|
57
|
-
[key.to_s, to_payload(value)]
|
58
|
-
end
|
59
|
-
end
|
60
|
-
|
61
|
-
def to_failure(error)
|
62
|
-
failure = failure_converter.to_failure(error, payload_converter)
|
63
|
-
encode_failure(failure)
|
64
|
-
end
|
65
|
-
|
66
|
-
def from_payload(payload)
|
67
|
-
decoded_payload = decode([payload]).first
|
68
|
-
raise MissingPayload, 'Payload Codecs returned no payloads' unless decoded_payload
|
69
|
-
|
70
|
-
payload_to_value(decoded_payload)
|
71
|
-
end
|
72
|
-
|
73
|
-
def from_payload_array(payloads)
|
74
|
-
return [] if payloads.empty?
|
75
|
-
|
76
|
-
decode(payloads)
|
77
|
-
.map { |payload| payload_to_value(payload) }
|
78
|
-
end
|
79
|
-
|
80
|
-
def from_payloads(payloads)
|
81
|
-
return unless payloads
|
82
|
-
|
83
|
-
decode(payloads.payloads)
|
84
|
-
.map { |payload| payload_to_value(payload) }
|
85
|
-
end
|
86
|
-
|
87
|
-
def from_payload_map(payload_map)
|
88
|
-
return unless payload_map
|
89
|
-
|
90
|
-
# Protobuf's Hash isn't compatible with the native Hash, ignore rubocop here
|
91
|
-
# rubocop:disable Style/MapToHash, Style/HashTransformValues
|
92
|
-
payload_map.map do |key, payload|
|
93
|
-
[key, from_payload(payload)]
|
94
|
-
end.to_h
|
95
|
-
# rubocop:enable Style/MapToHash, Style/HashTransformValues
|
96
|
-
end
|
97
|
-
|
98
|
-
def from_failure(failure)
|
99
|
-
raise ArgumentError, 'missing a failure to convert from' unless failure
|
100
|
-
|
101
|
-
failure = decode_failure(failure)
|
102
|
-
failure_converter.from_failure(failure, payload_converter)
|
103
|
-
end
|
104
|
-
|
105
|
-
private
|
106
|
-
|
107
|
-
attr_reader :payload_converter, :payload_codecs, :failure_converter
|
108
|
-
|
109
|
-
def value_to_payload(value)
|
110
|
-
payload_converter.to_payload(value)
|
111
|
-
end
|
112
|
-
|
113
|
-
def payload_to_value(payload)
|
114
|
-
payload_converter.from_payload(payload)
|
115
|
-
end
|
116
|
-
|
117
|
-
def encode(payloads)
|
118
|
-
return [] unless payloads
|
119
|
-
|
120
|
-
payload_codecs.each do |codec|
|
121
|
-
payloads = codec.encode(payloads)
|
122
|
-
end
|
123
|
-
|
124
|
-
payloads
|
125
|
-
end
|
126
|
-
|
127
|
-
def decode(payloads)
|
128
|
-
return [] unless payloads
|
129
|
-
|
130
|
-
payload_codecs.reverse_each do |codec|
|
131
|
-
payloads = codec.decode(payloads)
|
132
|
-
end
|
133
|
-
|
134
|
-
payloads
|
135
|
-
end
|
136
|
-
|
137
|
-
def encode_failure(failure)
|
138
|
-
failure = failure.dup
|
139
|
-
|
140
|
-
failure.encoded_attributes = failure.encoded_attributes ? encode([failure.encoded_attributes])&.first : nil
|
141
|
-
failure.cause = failure.cause ? encode_failure(failure.cause) : nil
|
142
|
-
|
143
|
-
if failure.application_failure_info
|
144
|
-
failure.application_failure_info.details = Temporalio::Api::Common::V1::Payloads.new(
|
145
|
-
payloads: encode(failure.application_failure_info.details&.payloads).to_a,
|
146
|
-
)
|
147
|
-
elsif failure.timeout_failure_info
|
148
|
-
failure.timeout_failure_info.last_heartbeat_details = Temporalio::Api::Common::V1::Payloads.new(
|
149
|
-
payloads: encode(failure.timeout_failure_info.last_heartbeat_details&.payloads).to_a,
|
150
|
-
)
|
151
|
-
elsif failure.canceled_failure_info
|
152
|
-
failure.canceled_failure_info.details = Temporalio::Api::Common::V1::Payloads.new(
|
153
|
-
payloads: encode(failure.canceled_failure_info.details&.payloads).to_a,
|
154
|
-
)
|
155
|
-
elsif failure.reset_workflow_failure_info
|
156
|
-
failure.reset_workflow_failure_info.last_heartbeat_details = Temporalio::Api::Common::V1::Payloads.new(
|
157
|
-
payloads: encode(failure.reset_workflow_failure_info.last_heartbeat_details&.payloads).to_a,
|
158
|
-
)
|
159
|
-
end
|
160
|
-
|
161
|
-
failure
|
162
|
-
end
|
163
|
-
|
164
|
-
def decode_failure(failure)
|
165
|
-
failure = failure.dup
|
166
|
-
|
167
|
-
failure.encoded_attributes = failure.encoded_attributes ? decode([failure.encoded_attributes])&.first : nil
|
168
|
-
failure.cause = failure.cause ? decode_failure(failure.cause) : nil
|
169
|
-
|
170
|
-
if failure.application_failure_info
|
171
|
-
failure.application_failure_info.details = Temporalio::Api::Common::V1::Payloads.new(
|
172
|
-
payloads: decode(failure.application_failure_info.details&.payloads).to_a,
|
173
|
-
)
|
174
|
-
elsif failure.timeout_failure_info
|
175
|
-
failure.timeout_failure_info.last_heartbeat_details = Temporalio::Api::Common::V1::Payloads.new(
|
176
|
-
payloads: decode(failure.timeout_failure_info.last_heartbeat_details&.payloads).to_a,
|
177
|
-
)
|
178
|
-
elsif failure.canceled_failure_info
|
179
|
-
failure.canceled_failure_info.details = Temporalio::Api::Common::V1::Payloads.new(
|
180
|
-
payloads: decode(failure.canceled_failure_info.details&.payloads).to_a,
|
181
|
-
)
|
182
|
-
elsif failure.reset_workflow_failure_info
|
183
|
-
failure.reset_workflow_failure_info.last_heartbeat_details = Temporalio::Api::Common::V1::Payloads.new(
|
184
|
-
payloads: decode(failure.reset_workflow_failure_info.last_heartbeat_details&.payloads).to_a,
|
185
|
-
)
|
186
|
-
end
|
187
|
-
|
188
|
-
failure
|
189
|
-
end
|
190
|
-
end
|
191
|
-
end
|
@@ -1,19 +0,0 @@
|
|
1
|
-
require 'temporalio/errors'
|
2
|
-
|
3
|
-
module Temporalio
|
4
|
-
class Error
|
5
|
-
# Used as a wrapper to perserve failure hierarchy in nested calls
|
6
|
-
# i.e. WorkflowFailure(ActivityError(WorkflowFailure(CancelledError)))
|
7
|
-
#
|
8
|
-
# @api private
|
9
|
-
class WorkflowFailure < Error
|
10
|
-
attr_reader :cause
|
11
|
-
|
12
|
-
def initialize(cause:)
|
13
|
-
super
|
14
|
-
|
15
|
-
@cause = cause
|
16
|
-
end
|
17
|
-
end
|
18
|
-
end
|
19
|
-
end
|
data/lib/temporalio/errors.rb
DELETED
@@ -1,40 +0,0 @@
|
|
1
|
-
module Temporalio
|
2
|
-
# Superclass for all Temporal errors
|
3
|
-
class Error < StandardError
|
4
|
-
# Superclass for RPC and proto related errors
|
5
|
-
class RPCError < Error; end
|
6
|
-
|
7
|
-
class UnexpectedResponse < RPCError; end
|
8
|
-
|
9
|
-
class WorkflowExecutionAlreadyStarted < RPCError; end
|
10
|
-
|
11
|
-
class QueryFailed < RPCError; end
|
12
|
-
|
13
|
-
class QueryRejected < RPCError
|
14
|
-
attr_reader :status
|
15
|
-
|
16
|
-
def initialize(status)
|
17
|
-
super("Query rejected, workflow status: #{status}")
|
18
|
-
@status = status
|
19
|
-
end
|
20
|
-
end
|
21
|
-
|
22
|
-
# Superclass for internal errors
|
23
|
-
class Internal < Error; end
|
24
|
-
|
25
|
-
class WorkerShutdown < Internal; end
|
26
|
-
|
27
|
-
# This error is used within the SDK to communicate Activity cancellations
|
28
|
-
# (and whether it was requested by server or not)
|
29
|
-
class ActivityCancelled < Internal
|
30
|
-
def initialize(reason, by_request)
|
31
|
-
super(reason)
|
32
|
-
@by_request = by_request
|
33
|
-
end
|
34
|
-
|
35
|
-
def by_request?
|
36
|
-
@by_request
|
37
|
-
end
|
38
|
-
end
|
39
|
-
end
|
40
|
-
end
|
@@ -1,26 +0,0 @@
|
|
1
|
-
module Temporalio
|
2
|
-
module FailureConverter
|
3
|
-
# @abstract Use this Interface for implementing your failure converter.
|
4
|
-
class Base
|
5
|
-
# Convert an Error object to a proto Failure.
|
6
|
-
#
|
7
|
-
# @param _error [Exception] An Error to be converter.
|
8
|
-
# @param _payload_converter [Temporalio::PayloadConverter::Base] A payload converter.
|
9
|
-
#
|
10
|
-
# @return [Temporalio::Api::Failure::V1::Failure]
|
11
|
-
def to_failure(_error, _payload_converter)
|
12
|
-
raise NoMethodError, 'must implement #to_failure'
|
13
|
-
end
|
14
|
-
|
15
|
-
# Convert an proto Failure object to an Error.
|
16
|
-
#
|
17
|
-
# @param _failure [Temporalio::Api::Failure::V1::Failure] A proto Failure to be converted.
|
18
|
-
# @param _payload_converter [Temporalio::PayloadConverter::Base] A payload converter.
|
19
|
-
#
|
20
|
-
# @return [Exception]
|
21
|
-
def from_failure(_failure, _payload_converter)
|
22
|
-
raise NoMethodError, 'must implement #from_failure'
|
23
|
-
end
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
@@ -1,319 +0,0 @@
|
|
1
|
-
require 'temporal/api/common/v1/message_pb'
|
2
|
-
require 'temporal/api/failure/v1/message_pb'
|
3
|
-
require 'temporalio/error/failure'
|
4
|
-
require 'temporalio/failure_converter/base'
|
5
|
-
require 'temporalio/retry_state'
|
6
|
-
require 'temporalio/timeout_type'
|
7
|
-
|
8
|
-
module Temporalio
|
9
|
-
module FailureConverter
|
10
|
-
# A default implementation of a FailureConverter.
|
11
|
-
#
|
12
|
-
# Use {Temporalio::DataConverter} for the set of helper method for interaction with converters.
|
13
|
-
#
|
14
|
-
# @api private
|
15
|
-
class Basic < Base
|
16
|
-
def initialize(encode_common_attributes: false)
|
17
|
-
super()
|
18
|
-
|
19
|
-
@encode_common_attributes = encode_common_attributes
|
20
|
-
end
|
21
|
-
|
22
|
-
def to_failure(error, payload_converter)
|
23
|
-
return error.raw if error.is_a?(Temporalio::Error::Failure) && error.raw
|
24
|
-
|
25
|
-
failure =
|
26
|
-
case error
|
27
|
-
when Temporalio::Error::ApplicationError
|
28
|
-
to_application_failure(error, payload_converter)
|
29
|
-
when Temporalio::Error::TimeoutError
|
30
|
-
to_timeout_failure(error, payload_converter)
|
31
|
-
when Temporalio::Error::CancelledError
|
32
|
-
to_cancelled_failure(error, payload_converter)
|
33
|
-
when Temporalio::Error::TerminatedError
|
34
|
-
to_terminated_failure(error, payload_converter)
|
35
|
-
when Temporalio::Error::ServerError
|
36
|
-
to_server_failure(error, payload_converter)
|
37
|
-
when Temporalio::Error::ResetWorkflowError
|
38
|
-
to_reset_workflow_failure(error, payload_converter)
|
39
|
-
when Temporalio::Error::ActivityError
|
40
|
-
to_activity_failure(error, payload_converter)
|
41
|
-
when Temporalio::Error::ChildWorkflowError
|
42
|
-
to_child_workflow_execution_failure(error, payload_converter)
|
43
|
-
else
|
44
|
-
to_generic_failure(error, payload_converter)
|
45
|
-
end
|
46
|
-
|
47
|
-
failure.message = error.message
|
48
|
-
failure.stack_trace = error.backtrace&.join("\n") || ''
|
49
|
-
# RBS: StandardError fallback is only needed to satisfy steep - https://github.com/soutaro/steep/issues/477
|
50
|
-
failure.cause = to_failure(error.cause || StandardError.new, payload_converter) if error.cause
|
51
|
-
|
52
|
-
if encode_common_attributes?
|
53
|
-
failure.encoded_attributes = payload_converter.to_payload(
|
54
|
-
'message' => failure.message,
|
55
|
-
'stack_trace' => failure.stack_trace,
|
56
|
-
)
|
57
|
-
failure.message = 'Encoded failure'
|
58
|
-
failure.stack_trace = ''
|
59
|
-
end
|
60
|
-
|
61
|
-
failure
|
62
|
-
end
|
63
|
-
|
64
|
-
def from_failure(failure, payload_converter)
|
65
|
-
failure = apply_from_encoded_attributes(failure, payload_converter)
|
66
|
-
cause = failure.cause ? from_failure(failure.cause, payload_converter) : nil
|
67
|
-
|
68
|
-
error =
|
69
|
-
if failure.application_failure_info
|
70
|
-
from_application_failure(failure, failure.application_failure_info, cause, payload_converter)
|
71
|
-
elsif failure.timeout_failure_info
|
72
|
-
from_timeout_failure(failure, failure.timeout_failure_info, cause, payload_converter)
|
73
|
-
elsif failure.canceled_failure_info
|
74
|
-
from_cancelled_failure(failure, failure.canceled_failure_info, cause, payload_converter)
|
75
|
-
elsif failure.terminated_failure_info
|
76
|
-
from_terminated_failure(failure, failure.terminated_failure_info, cause, payload_converter)
|
77
|
-
elsif failure.server_failure_info
|
78
|
-
from_server_failure(failure, failure.server_failure_info, cause, payload_converter)
|
79
|
-
elsif failure.reset_workflow_failure_info
|
80
|
-
from_reset_workflow_failure(failure, failure.reset_workflow_failure_info, cause, payload_converter)
|
81
|
-
elsif failure.activity_failure_info
|
82
|
-
from_activity_failure(failure, failure.activity_failure_info, cause, payload_converter)
|
83
|
-
elsif failure.child_workflow_execution_failure_info
|
84
|
-
from_child_workflow_execution_failure(
|
85
|
-
failure,
|
86
|
-
failure.child_workflow_execution_failure_info,
|
87
|
-
cause,
|
88
|
-
payload_converter,
|
89
|
-
)
|
90
|
-
else
|
91
|
-
from_generic_failure(failure, cause, payload_converter)
|
92
|
-
end
|
93
|
-
|
94
|
-
unless failure.stack_trace.empty?
|
95
|
-
error.set_backtrace(failure.stack_trace.split("\n"))
|
96
|
-
end
|
97
|
-
|
98
|
-
error
|
99
|
-
end
|
100
|
-
|
101
|
-
private
|
102
|
-
|
103
|
-
def encode_common_attributes?
|
104
|
-
@encode_common_attributes
|
105
|
-
end
|
106
|
-
|
107
|
-
def to_payloads(data, payload_converter)
|
108
|
-
return if data.nil? || Array(data).empty?
|
109
|
-
|
110
|
-
payloads = Array(data).map { |value| payload_converter.to_payload(value) }
|
111
|
-
Temporalio::Api::Common::V1::Payloads.new(payloads: payloads)
|
112
|
-
end
|
113
|
-
|
114
|
-
def from_payloads(payloads, payload_converter)
|
115
|
-
return [] unless payloads
|
116
|
-
|
117
|
-
payloads.payloads.map { |payload| payload_converter.from_payload(payload) }
|
118
|
-
end
|
119
|
-
|
120
|
-
def apply_from_encoded_attributes(failure, payload_converter)
|
121
|
-
return failure unless failure.encoded_attributes
|
122
|
-
|
123
|
-
attributes = payload_converter.from_payload(failure.encoded_attributes)
|
124
|
-
return failure unless attributes.is_a?(Hash)
|
125
|
-
|
126
|
-
failure = failure.dup
|
127
|
-
if attributes['message'].is_a?(String)
|
128
|
-
failure.message = attributes['message']
|
129
|
-
end
|
130
|
-
|
131
|
-
if attributes['stack_trace'].is_a?(String)
|
132
|
-
failure.stack_trace = attributes['stack_trace']
|
133
|
-
end
|
134
|
-
|
135
|
-
failure
|
136
|
-
end
|
137
|
-
|
138
|
-
def to_application_failure(error, payload_converter)
|
139
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
140
|
-
application_failure_info: Temporalio::Api::Failure::V1::ApplicationFailureInfo.new(
|
141
|
-
type: error.type,
|
142
|
-
non_retryable: error.non_retryable,
|
143
|
-
details: to_payloads(error.details, payload_converter),
|
144
|
-
),
|
145
|
-
)
|
146
|
-
end
|
147
|
-
|
148
|
-
def to_timeout_failure(error, payload_converter)
|
149
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
150
|
-
timeout_failure_info: Temporalio::Api::Failure::V1::TimeoutFailureInfo.new(
|
151
|
-
timeout_type: Temporalio::TimeoutType.to_raw(error.type),
|
152
|
-
last_heartbeat_details: to_payloads(error.last_heartbeat_details, payload_converter),
|
153
|
-
),
|
154
|
-
)
|
155
|
-
end
|
156
|
-
|
157
|
-
def to_cancelled_failure(error, payload_converter)
|
158
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
159
|
-
canceled_failure_info: Temporalio::Api::Failure::V1::CanceledFailureInfo.new(
|
160
|
-
details: to_payloads(error.details, payload_converter),
|
161
|
-
),
|
162
|
-
)
|
163
|
-
end
|
164
|
-
|
165
|
-
def to_terminated_failure(_error, _payload_converter)
|
166
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
167
|
-
terminated_failure_info: Temporalio::Api::Failure::V1::TerminatedFailureInfo.new,
|
168
|
-
)
|
169
|
-
end
|
170
|
-
|
171
|
-
def to_server_failure(error, _payload_converter)
|
172
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
173
|
-
server_failure_info: Temporalio::Api::Failure::V1::ServerFailureInfo.new(
|
174
|
-
non_retryable: error.non_retryable,
|
175
|
-
),
|
176
|
-
)
|
177
|
-
end
|
178
|
-
|
179
|
-
def to_reset_workflow_failure(error, payload_converter)
|
180
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
181
|
-
reset_workflow_failure_info: Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo.new(
|
182
|
-
last_heartbeat_details: to_payloads(error.last_heartbeat_details, payload_converter),
|
183
|
-
),
|
184
|
-
)
|
185
|
-
end
|
186
|
-
|
187
|
-
def to_activity_failure(error, _payload_converter)
|
188
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
189
|
-
activity_failure_info: Temporalio::Api::Failure::V1::ActivityFailureInfo.new(
|
190
|
-
scheduled_event_id: error.scheduled_event_id,
|
191
|
-
started_event_id: error.started_event_id,
|
192
|
-
identity: error.identity,
|
193
|
-
activity_type: Temporalio::Api::Common::V1::ActivityType.new(name: error.activity_name || ''),
|
194
|
-
activity_id: error.activity_id,
|
195
|
-
retry_state: Temporalio::RetryState.to_raw(error.retry_state),
|
196
|
-
),
|
197
|
-
)
|
198
|
-
end
|
199
|
-
|
200
|
-
def to_child_workflow_execution_failure(error, _payload_converter)
|
201
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
202
|
-
child_workflow_execution_failure_info:
|
203
|
-
Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo.new(
|
204
|
-
namespace: error.namespace,
|
205
|
-
workflow_execution: Temporalio::Api::Common::V1::WorkflowExecution.new(
|
206
|
-
workflow_id: error.workflow_id || '',
|
207
|
-
run_id: error.run_id || '',
|
208
|
-
),
|
209
|
-
workflow_type: Temporalio::Api::Common::V1::WorkflowType.new(name: error.workflow_name || ''),
|
210
|
-
initiated_event_id: error.initiated_event_id,
|
211
|
-
started_event_id: error.started_event_id,
|
212
|
-
retry_state: Temporalio::RetryState.to_raw(error.retry_state),
|
213
|
-
),
|
214
|
-
)
|
215
|
-
end
|
216
|
-
|
217
|
-
def to_generic_failure(error, _payload_converter)
|
218
|
-
Temporalio::Api::Failure::V1::Failure.new(
|
219
|
-
application_failure_info: Temporalio::Api::Failure::V1::ApplicationFailureInfo.new(
|
220
|
-
type: error.class.name,
|
221
|
-
),
|
222
|
-
)
|
223
|
-
end
|
224
|
-
|
225
|
-
def from_application_failure(failure, failure_info, cause, payload_converter)
|
226
|
-
Temporalio::Error::ApplicationError.new(
|
227
|
-
failure.message || 'Application error',
|
228
|
-
type: failure_info.type,
|
229
|
-
details: from_payloads(failure_info.details, payload_converter),
|
230
|
-
non_retryable: failure_info.non_retryable,
|
231
|
-
raw: failure,
|
232
|
-
cause: cause,
|
233
|
-
)
|
234
|
-
end
|
235
|
-
|
236
|
-
def from_timeout_failure(failure, failure_info, cause, payload_converter)
|
237
|
-
Temporalio::Error::TimeoutError.new(
|
238
|
-
failure.message || 'Timeout',
|
239
|
-
type: Temporalio::TimeoutType.from_raw(failure_info.timeout_type),
|
240
|
-
last_heartbeat_details: from_payloads(failure_info.last_heartbeat_details, payload_converter),
|
241
|
-
raw: failure,
|
242
|
-
cause: cause,
|
243
|
-
)
|
244
|
-
end
|
245
|
-
|
246
|
-
def from_cancelled_failure(failure, failure_info, cause, payload_converter)
|
247
|
-
Temporalio::Error::CancelledError.new(
|
248
|
-
failure.message || 'Cancelled',
|
249
|
-
details: from_payloads(failure_info.details, payload_converter),
|
250
|
-
raw: failure,
|
251
|
-
cause: cause,
|
252
|
-
)
|
253
|
-
end
|
254
|
-
|
255
|
-
def from_terminated_failure(failure, _failure_info, cause, _payload_converter)
|
256
|
-
Temporalio::Error::TerminatedError.new(
|
257
|
-
failure.message || 'Terminated',
|
258
|
-
raw: failure,
|
259
|
-
cause: cause,
|
260
|
-
)
|
261
|
-
end
|
262
|
-
|
263
|
-
def from_server_failure(failure, failure_info, cause, _payload_converter)
|
264
|
-
Temporalio::Error::ServerError.new(
|
265
|
-
failure.message || 'Server error',
|
266
|
-
non_retryable: failure_info.non_retryable,
|
267
|
-
raw: failure,
|
268
|
-
cause: cause,
|
269
|
-
)
|
270
|
-
end
|
271
|
-
|
272
|
-
def from_reset_workflow_failure(failure, failure_info, cause, payload_converter)
|
273
|
-
Temporalio::Error::ResetWorkflowError.new(
|
274
|
-
failure.message || 'Reset workflow error',
|
275
|
-
last_heartbeat_details: from_payloads(failure_info.last_heartbeat_details, payload_converter),
|
276
|
-
raw: failure,
|
277
|
-
cause: cause,
|
278
|
-
)
|
279
|
-
end
|
280
|
-
|
281
|
-
def from_activity_failure(failure, failure_info, cause, _payload_converter)
|
282
|
-
Temporalio::Error::ActivityError.new(
|
283
|
-
failure.message || 'Activity error',
|
284
|
-
scheduled_event_id: failure_info.scheduled_event_id,
|
285
|
-
started_event_id: failure_info.started_event_id,
|
286
|
-
identity: failure_info.identity,
|
287
|
-
activity_name: failure_info.activity_type&.name,
|
288
|
-
activity_id: failure_info.activity_id,
|
289
|
-
retry_state: Temporalio::RetryState.from_raw(failure_info.retry_state),
|
290
|
-
raw: failure,
|
291
|
-
cause: cause,
|
292
|
-
)
|
293
|
-
end
|
294
|
-
|
295
|
-
def from_child_workflow_execution_failure(failure, failure_info, cause, _payload_converter)
|
296
|
-
Temporalio::Error::ChildWorkflowError.new(
|
297
|
-
failure.message || 'Child workflow error',
|
298
|
-
namespace: failure_info.namespace,
|
299
|
-
workflow_id: failure_info.workflow_execution&.workflow_id,
|
300
|
-
run_id: failure_info.workflow_execution&.run_id,
|
301
|
-
workflow_name: failure_info.workflow_type&.name,
|
302
|
-
initiated_event_id: failure_info.initiated_event_id,
|
303
|
-
started_event_id: failure_info.started_event_id,
|
304
|
-
retry_state: Temporalio::RetryState.from_raw(failure_info.retry_state),
|
305
|
-
raw: failure,
|
306
|
-
cause: cause,
|
307
|
-
)
|
308
|
-
end
|
309
|
-
|
310
|
-
def from_generic_failure(failure, cause, _payload_converter)
|
311
|
-
Temporalio::Error::Failure.new(
|
312
|
-
failure.message || 'Failure error',
|
313
|
-
raw: failure,
|
314
|
-
cause: cause,
|
315
|
-
)
|
316
|
-
end
|
317
|
-
end
|
318
|
-
end
|
319
|
-
end
|