temporalio 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/Gemfile +3 -0
- data/LICENSE +20 -0
- data/README.md +130 -0
- data/bridge/Cargo.lock +2865 -0
- data/bridge/Cargo.toml +26 -0
- data/bridge/sdk-core/ARCHITECTURE.md +76 -0
- data/bridge/sdk-core/Cargo.lock +2606 -0
- data/bridge/sdk-core/Cargo.toml +2 -0
- data/bridge/sdk-core/LICENSE.txt +23 -0
- data/bridge/sdk-core/README.md +107 -0
- data/bridge/sdk-core/arch_docs/diagrams/README.md +10 -0
- data/bridge/sdk-core/arch_docs/diagrams/sticky_queues.puml +40 -0
- data/bridge/sdk-core/arch_docs/diagrams/workflow_internals.svg +1 -0
- data/bridge/sdk-core/arch_docs/sticky_queues.md +51 -0
- data/bridge/sdk-core/bridge-ffi/Cargo.toml +24 -0
- data/bridge/sdk-core/bridge-ffi/LICENSE.txt +23 -0
- data/bridge/sdk-core/bridge-ffi/build.rs +25 -0
- data/bridge/sdk-core/bridge-ffi/include/sdk-core-bridge.h +249 -0
- data/bridge/sdk-core/bridge-ffi/src/lib.rs +825 -0
- data/bridge/sdk-core/bridge-ffi/src/wrappers.rs +211 -0
- data/bridge/sdk-core/client/Cargo.toml +40 -0
- data/bridge/sdk-core/client/LICENSE.txt +23 -0
- data/bridge/sdk-core/client/src/lib.rs +1294 -0
- data/bridge/sdk-core/client/src/metrics.rs +165 -0
- data/bridge/sdk-core/client/src/raw.rs +931 -0
- data/bridge/sdk-core/client/src/retry.rs +674 -0
- data/bridge/sdk-core/client/src/workflow_handle/mod.rs +185 -0
- data/bridge/sdk-core/core/Cargo.toml +116 -0
- data/bridge/sdk-core/core/LICENSE.txt +23 -0
- data/bridge/sdk-core/core/benches/workflow_replay.rs +73 -0
- data/bridge/sdk-core/core/src/abstractions.rs +166 -0
- data/bridge/sdk-core/core/src/core_tests/activity_tasks.rs +911 -0
- data/bridge/sdk-core/core/src/core_tests/child_workflows.rs +221 -0
- data/bridge/sdk-core/core/src/core_tests/determinism.rs +107 -0
- data/bridge/sdk-core/core/src/core_tests/local_activities.rs +515 -0
- data/bridge/sdk-core/core/src/core_tests/mod.rs +100 -0
- data/bridge/sdk-core/core/src/core_tests/queries.rs +736 -0
- data/bridge/sdk-core/core/src/core_tests/replay_flag.rs +65 -0
- data/bridge/sdk-core/core/src/core_tests/workers.rs +259 -0
- data/bridge/sdk-core/core/src/core_tests/workflow_cancels.rs +124 -0
- data/bridge/sdk-core/core/src/core_tests/workflow_tasks.rs +2070 -0
- data/bridge/sdk-core/core/src/ephemeral_server/mod.rs +515 -0
- data/bridge/sdk-core/core/src/lib.rs +175 -0
- data/bridge/sdk-core/core/src/log_export.rs +62 -0
- data/bridge/sdk-core/core/src/pollers/mod.rs +54 -0
- data/bridge/sdk-core/core/src/pollers/poll_buffer.rs +297 -0
- data/bridge/sdk-core/core/src/protosext/mod.rs +428 -0
- data/bridge/sdk-core/core/src/replay/mod.rs +71 -0
- data/bridge/sdk-core/core/src/retry_logic.rs +202 -0
- data/bridge/sdk-core/core/src/telemetry/metrics.rs +383 -0
- data/bridge/sdk-core/core/src/telemetry/mod.rs +412 -0
- data/bridge/sdk-core/core/src/telemetry/prometheus_server.rs +77 -0
- data/bridge/sdk-core/core/src/test_help/mod.rs +875 -0
- data/bridge/sdk-core/core/src/worker/activities/activity_heartbeat_manager.rs +580 -0
- data/bridge/sdk-core/core/src/worker/activities/local_activities.rs +1042 -0
- data/bridge/sdk-core/core/src/worker/activities.rs +464 -0
- data/bridge/sdk-core/core/src/worker/client/mocks.rs +87 -0
- data/bridge/sdk-core/core/src/worker/client.rs +347 -0
- data/bridge/sdk-core/core/src/worker/mod.rs +566 -0
- data/bridge/sdk-core/core/src/worker/workflow/bridge.rs +37 -0
- data/bridge/sdk-core/core/src/worker/workflow/driven_workflow.rs +110 -0
- data/bridge/sdk-core/core/src/worker/workflow/history_update.rs +458 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/activity_state_machine.rs +911 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/cancel_external_state_machine.rs +298 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/cancel_workflow_state_machine.rs +171 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/child_workflow_state_machine.rs +860 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/complete_workflow_state_machine.rs +140 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/continue_as_new_workflow_state_machine.rs +161 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/fail_workflow_state_machine.rs +133 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/local_activity_state_machine.rs +1448 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/mod.rs +342 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/mutable_side_effect_state_machine.rs +127 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/patch_state_machine.rs +712 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/side_effect_state_machine.rs +71 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/signal_external_state_machine.rs +443 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/timer_state_machine.rs +439 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/transition_coverage.rs +169 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/upsert_search_attributes_state_machine.rs +246 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_machines/local_acts.rs +96 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_machines.rs +1184 -0
- data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_task_state_machine.rs +277 -0
- data/bridge/sdk-core/core/src/worker/workflow/managed_run/managed_wf_test.rs +198 -0
- data/bridge/sdk-core/core/src/worker/workflow/managed_run.rs +647 -0
- data/bridge/sdk-core/core/src/worker/workflow/mod.rs +1143 -0
- data/bridge/sdk-core/core/src/worker/workflow/run_cache.rs +145 -0
- data/bridge/sdk-core/core/src/worker/workflow/wft_poller.rs +88 -0
- data/bridge/sdk-core/core/src/worker/workflow/workflow_stream.rs +940 -0
- data/bridge/sdk-core/core-api/Cargo.toml +31 -0
- data/bridge/sdk-core/core-api/LICENSE.txt +23 -0
- data/bridge/sdk-core/core-api/src/errors.rs +95 -0
- data/bridge/sdk-core/core-api/src/lib.rs +151 -0
- data/bridge/sdk-core/core-api/src/worker.rs +135 -0
- data/bridge/sdk-core/etc/deps.svg +187 -0
- data/bridge/sdk-core/etc/dynamic-config.yaml +2 -0
- data/bridge/sdk-core/etc/otel-collector-config.yaml +36 -0
- data/bridge/sdk-core/etc/prometheus.yaml +6 -0
- data/bridge/sdk-core/fsm/Cargo.toml +18 -0
- data/bridge/sdk-core/fsm/LICENSE.txt +23 -0
- data/bridge/sdk-core/fsm/README.md +3 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/Cargo.toml +27 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/LICENSE.txt +23 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/src/lib.rs +647 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/progress.rs +8 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/dupe_transitions_fail.rs +18 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/dupe_transitions_fail.stderr +12 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/dynamic_dest_pass.rs +41 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/forgot_name_fail.rs +14 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/forgot_name_fail.stderr +11 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/handler_arg_pass.rs +32 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/handler_pass.rs +31 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/medium_complex_pass.rs +46 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/no_handle_conversions_require_into_fail.rs +29 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/no_handle_conversions_require_into_fail.stderr +12 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/simple_pass.rs +32 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/struct_event_variant_fail.rs +18 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/struct_event_variant_fail.stderr +5 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_more_item_event_variant_fail.rs +11 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_more_item_event_variant_fail.stderr +5 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_zero_item_event_variant_fail.rs +11 -0
- data/bridge/sdk-core/fsm/rustfsm_procmacro/tests/trybuild/tuple_zero_item_event_variant_fail.stderr +5 -0
- data/bridge/sdk-core/fsm/rustfsm_trait/Cargo.toml +14 -0
- data/bridge/sdk-core/fsm/rustfsm_trait/LICENSE.txt +23 -0
- data/bridge/sdk-core/fsm/rustfsm_trait/src/lib.rs +249 -0
- data/bridge/sdk-core/fsm/src/lib.rs +2 -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 +7 -0
- data/bridge/sdk-core/protos/api_upstream/README.md +9 -0
- data/bridge/sdk-core/protos/api_upstream/api-linter.yaml +40 -0
- data/bridge/sdk-core/protos/api_upstream/buf.yaml +12 -0
- data/bridge/sdk-core/protos/api_upstream/dependencies/gogoproto/gogo.proto +141 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/batch/v1/message.proto +86 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/cluster/v1/message.proto +83 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/command/v1/message.proto +259 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/common/v1/message.proto +112 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/batch_operation.proto +46 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/cluster.proto +40 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/command_type.proto +57 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/common.proto +55 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/event_type.proto +168 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/failed_cause.proto +97 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/namespace.proto +51 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/query.proto +50 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/reset.proto +41 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/schedule.proto +60 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/task_queue.proto +59 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/update.proto +51 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/workflow.proto +122 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/errordetails/v1/message.proto +108 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/failure/v1/message.proto +114 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/filter/v1/message.proto +56 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/history/v1/message.proto +751 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/namespace/v1/message.proto +97 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/operatorservice/v1/request_response.proto +161 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/operatorservice/v1/service.proto +99 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/query/v1/message.proto +61 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/replication/v1/message.proto +55 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/schedule/v1/message.proto +300 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/taskqueue/v1/message.proto +108 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/update/v1/message.proto +46 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/version/v1/message.proto +59 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/workflow/v1/message.proto +145 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/workflowservice/v1/request_response.proto +1124 -0
- data/bridge/sdk-core/protos/api_upstream/temporal/api/workflowservice/v1/service.proto +401 -0
- data/bridge/sdk-core/protos/grpc/health/v1/health.proto +63 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/activity_result/activity_result.proto +78 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/activity_task/activity_task.proto +79 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/bridge/bridge.proto +210 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/child_workflow/child_workflow.proto +77 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/common/common.proto +15 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/core_interface.proto +30 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/external_data/external_data.proto +30 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_activation/workflow_activation.proto +261 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_commands/workflow_commands.proto +297 -0
- data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_completion/workflow_completion.proto +29 -0
- data/bridge/sdk-core/protos/testsrv_upstream/api-linter.yaml +38 -0
- data/bridge/sdk-core/protos/testsrv_upstream/buf.yaml +13 -0
- data/bridge/sdk-core/protos/testsrv_upstream/dependencies/gogoproto/gogo.proto +141 -0
- data/bridge/sdk-core/protos/testsrv_upstream/temporal/api/testservice/v1/request_response.proto +63 -0
- data/bridge/sdk-core/protos/testsrv_upstream/temporal/api/testservice/v1/service.proto +90 -0
- data/bridge/sdk-core/rustfmt.toml +1 -0
- data/bridge/sdk-core/sdk/Cargo.toml +47 -0
- data/bridge/sdk-core/sdk/LICENSE.txt +23 -0
- data/bridge/sdk-core/sdk/src/activity_context.rs +230 -0
- data/bridge/sdk-core/sdk/src/app_data.rs +37 -0
- data/bridge/sdk-core/sdk/src/conversions.rs +8 -0
- data/bridge/sdk-core/sdk/src/interceptors.rs +17 -0
- data/bridge/sdk-core/sdk/src/lib.rs +792 -0
- data/bridge/sdk-core/sdk/src/payload_converter.rs +11 -0
- data/bridge/sdk-core/sdk/src/workflow_context/options.rs +295 -0
- data/bridge/sdk-core/sdk/src/workflow_context.rs +683 -0
- data/bridge/sdk-core/sdk/src/workflow_future.rs +503 -0
- data/bridge/sdk-core/sdk-core-protos/Cargo.toml +30 -0
- data/bridge/sdk-core/sdk-core-protos/LICENSE.txt +23 -0
- data/bridge/sdk-core/sdk-core-protos/build.rs +108 -0
- data/bridge/sdk-core/sdk-core-protos/src/constants.rs +7 -0
- data/bridge/sdk-core/sdk-core-protos/src/history_builder.rs +497 -0
- data/bridge/sdk-core/sdk-core-protos/src/history_info.rs +230 -0
- data/bridge/sdk-core/sdk-core-protos/src/lib.rs +1910 -0
- data/bridge/sdk-core/sdk-core-protos/src/task_token.rs +38 -0
- data/bridge/sdk-core/sdk-core-protos/src/utilities.rs +14 -0
- data/bridge/sdk-core/test-utils/Cargo.toml +35 -0
- data/bridge/sdk-core/test-utils/src/canned_histories.rs +1579 -0
- data/bridge/sdk-core/test-utils/src/histfetch.rs +28 -0
- data/bridge/sdk-core/test-utils/src/lib.rs +598 -0
- data/bridge/sdk-core/tests/integ_tests/client_tests.rs +36 -0
- data/bridge/sdk-core/tests/integ_tests/ephemeral_server_tests.rs +128 -0
- data/bridge/sdk-core/tests/integ_tests/heartbeat_tests.rs +218 -0
- data/bridge/sdk-core/tests/integ_tests/polling_tests.rs +146 -0
- data/bridge/sdk-core/tests/integ_tests/queries_tests.rs +437 -0
- data/bridge/sdk-core/tests/integ_tests/visibility_tests.rs +93 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/activities.rs +878 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/appdata_propagation.rs +61 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/cancel_external.rs +59 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/cancel_wf.rs +58 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/child_workflows.rs +50 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/continue_as_new.rs +60 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/determinism.rs +54 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/local_activities.rs +634 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/patches.rs +113 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/replay.rs +137 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/resets.rs +93 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/signals.rs +167 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/stickyness.rs +99 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/timers.rs +131 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests/upsert_search_attrs.rs +75 -0
- data/bridge/sdk-core/tests/integ_tests/workflow_tests.rs +587 -0
- data/bridge/sdk-core/tests/load_tests.rs +191 -0
- data/bridge/sdk-core/tests/main.rs +111 -0
- data/bridge/sdk-core/tests/runner.rs +93 -0
- data/bridge/src/connection.rs +167 -0
- data/bridge/src/lib.rs +180 -0
- data/bridge/src/runtime.rs +47 -0
- data/bridge/src/worker.rs +73 -0
- data/ext/Rakefile +9 -0
- data/lib/bridge.so +0 -0
- data/lib/gen/dependencies/gogoproto/gogo_pb.rb +14 -0
- data/lib/gen/temporal/api/batch/v1/message_pb.rb +48 -0
- data/lib/gen/temporal/api/cluster/v1/message_pb.rb +67 -0
- data/lib/gen/temporal/api/command/v1/message_pb.rb +166 -0
- data/lib/gen/temporal/api/common/v1/message_pb.rb +69 -0
- data/lib/gen/temporal/api/enums/v1/batch_operation_pb.rb +32 -0
- data/lib/gen/temporal/api/enums/v1/cluster_pb.rb +26 -0
- data/lib/gen/temporal/api/enums/v1/command_type_pb.rb +37 -0
- data/lib/gen/temporal/api/enums/v1/common_pb.rb +41 -0
- data/lib/gen/temporal/api/enums/v1/event_type_pb.rb +67 -0
- data/lib/gen/temporal/api/enums/v1/failed_cause_pb.rb +71 -0
- data/lib/gen/temporal/api/enums/v1/namespace_pb.rb +37 -0
- data/lib/gen/temporal/api/enums/v1/query_pb.rb +31 -0
- data/lib/gen/temporal/api/enums/v1/reset_pb.rb +24 -0
- data/lib/gen/temporal/api/enums/v1/schedule_pb.rb +28 -0
- data/lib/gen/temporal/api/enums/v1/task_queue_pb.rb +30 -0
- data/lib/gen/temporal/api/enums/v1/update_pb.rb +28 -0
- data/lib/gen/temporal/api/enums/v1/workflow_pb.rb +89 -0
- data/lib/gen/temporal/api/errordetails/v1/message_pb.rb +84 -0
- data/lib/gen/temporal/api/failure/v1/message_pb.rb +83 -0
- data/lib/gen/temporal/api/filter/v1/message_pb.rb +40 -0
- data/lib/gen/temporal/api/history/v1/message_pb.rb +489 -0
- data/lib/gen/temporal/api/namespace/v1/message_pb.rb +63 -0
- data/lib/gen/temporal/api/operatorservice/v1/request_response_pb.rb +125 -0
- data/lib/gen/temporal/api/operatorservice/v1/service_pb.rb +20 -0
- data/lib/gen/temporal/api/query/v1/message_pb.rb +38 -0
- data/lib/gen/temporal/api/replication/v1/message_pb.rb +37 -0
- data/lib/gen/temporal/api/schedule/v1/message_pb.rb +128 -0
- data/lib/gen/temporal/api/taskqueue/v1/message_pb.rb +73 -0
- data/lib/gen/temporal/api/update/v1/message_pb.rb +26 -0
- data/lib/gen/temporal/api/version/v1/message_pb.rb +41 -0
- data/lib/gen/temporal/api/workflow/v1/message_pb.rb +110 -0
- data/lib/gen/temporal/api/workflowservice/v1/request_response_pb.rb +771 -0
- data/lib/gen/temporal/api/workflowservice/v1/service_pb.rb +20 -0
- data/lib/gen/temporal/sdk/core/activity_result/activity_result_pb.rb +58 -0
- data/lib/gen/temporal/sdk/core/activity_task/activity_task_pb.rb +57 -0
- data/lib/gen/temporal/sdk/core/bridge/bridge_pb.rb +222 -0
- data/lib/gen/temporal/sdk/core/child_workflow/child_workflow_pb.rb +57 -0
- data/lib/gen/temporal/sdk/core/common/common_pb.rb +22 -0
- data/lib/gen/temporal/sdk/core/core_interface_pb.rb +34 -0
- data/lib/gen/temporal/sdk/core/external_data/external_data_pb.rb +27 -0
- data/lib/gen/temporal/sdk/core/workflow_activation/workflow_activation_pb.rb +164 -0
- data/lib/gen/temporal/sdk/core/workflow_commands/workflow_commands_pb.rb +192 -0
- data/lib/gen/temporal/sdk/core/workflow_completion/workflow_completion_pb.rb +34 -0
- data/lib/temporal/bridge.rb +14 -0
- data/lib/temporal/client/implementation.rb +339 -0
- data/lib/temporal/client/workflow_handle.rb +243 -0
- data/lib/temporal/client.rb +144 -0
- data/lib/temporal/connection.rb +736 -0
- data/lib/temporal/data_converter.rb +150 -0
- data/lib/temporal/error/failure.rb +194 -0
- data/lib/temporal/error/workflow_failure.rb +17 -0
- data/lib/temporal/errors.rb +22 -0
- data/lib/temporal/failure_converter/base.rb +26 -0
- data/lib/temporal/failure_converter/basic.rb +313 -0
- data/lib/temporal/failure_converter.rb +8 -0
- data/lib/temporal/interceptor/chain.rb +27 -0
- data/lib/temporal/interceptor/client.rb +102 -0
- data/lib/temporal/payload_codec/base.rb +32 -0
- data/lib/temporal/payload_converter/base.rb +24 -0
- data/lib/temporal/payload_converter/bytes.rb +26 -0
- data/lib/temporal/payload_converter/composite.rb +47 -0
- data/lib/temporal/payload_converter/encoding_base.rb +35 -0
- data/lib/temporal/payload_converter/json.rb +25 -0
- data/lib/temporal/payload_converter/nil.rb +25 -0
- data/lib/temporal/payload_converter.rb +14 -0
- data/lib/temporal/retry_policy.rb +82 -0
- data/lib/temporal/retry_state.rb +35 -0
- data/lib/temporal/runtime.rb +22 -0
- data/lib/temporal/timeout_type.rb +29 -0
- data/lib/temporal/version.rb +3 -0
- data/lib/temporal/workflow/execution_info.rb +54 -0
- data/lib/temporal/workflow/execution_status.rb +36 -0
- data/lib/temporal/workflow/id_reuse_policy.rb +36 -0
- data/lib/temporal/workflow/query_reject_condition.rb +33 -0
- data/lib/temporal.rb +8 -0
- data/lib/temporalio.rb +3 -0
- data/lib/thermite_patch.rb +23 -0
- data/temporalio.gemspec +41 -0
- metadata +583 -0
@@ -0,0 +1,141 @@
|
|
1
|
+
// Protocol Buffers for Go with Gadgets
|
2
|
+
//
|
3
|
+
// Copyright (c) 2013, The GoGo Authors. All rights reserved.
|
4
|
+
// http://github.com/temporalio/gogo-protobuf
|
5
|
+
//
|
6
|
+
// Redistribution and use in source and binary forms, with or without
|
7
|
+
// modification, are permitted provided that the following conditions are
|
8
|
+
// met:
|
9
|
+
//
|
10
|
+
// * Redistributions of source code must retain the above copyright
|
11
|
+
// notice, this list of conditions and the following disclaimer.
|
12
|
+
// * Redistributions in binary form must reproduce the above
|
13
|
+
// copyright notice, this list of conditions and the following disclaimer
|
14
|
+
// in the documentation and/or other materials provided with the
|
15
|
+
// distribution.
|
16
|
+
//
|
17
|
+
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
18
|
+
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
19
|
+
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
20
|
+
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
21
|
+
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
22
|
+
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
23
|
+
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
24
|
+
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
25
|
+
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
26
|
+
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
27
|
+
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
28
|
+
|
29
|
+
syntax = "proto2";
|
30
|
+
package gogoproto;
|
31
|
+
|
32
|
+
import "google/protobuf/descriptor.proto";
|
33
|
+
|
34
|
+
option go_package = "github.com/gogo/protobuf/gogoproto";
|
35
|
+
|
36
|
+
extend google.protobuf.EnumOptions {
|
37
|
+
optional bool goproto_enum_prefix = 62001;
|
38
|
+
optional bool goproto_enum_stringer = 62021;
|
39
|
+
optional bool enum_stringer = 62022;
|
40
|
+
optional string enum_customname = 62023;
|
41
|
+
optional bool enumdecl = 62024;
|
42
|
+
}
|
43
|
+
|
44
|
+
extend google.protobuf.EnumValueOptions {
|
45
|
+
optional string enumvalue_customname = 66001;
|
46
|
+
}
|
47
|
+
|
48
|
+
extend google.protobuf.FileOptions {
|
49
|
+
optional bool goproto_getters_all = 63001;
|
50
|
+
optional bool goproto_enum_prefix_all = 63002;
|
51
|
+
optional bool goproto_stringer_all = 63003;
|
52
|
+
optional bool verbose_equal_all = 63004;
|
53
|
+
optional bool face_all = 63005;
|
54
|
+
optional bool gostring_all = 63006;
|
55
|
+
optional bool populate_all = 63007;
|
56
|
+
optional bool stringer_all = 63008;
|
57
|
+
optional bool onlyone_all = 63009;
|
58
|
+
|
59
|
+
optional bool equal_all = 63013;
|
60
|
+
optional bool description_all = 63014;
|
61
|
+
optional bool testgen_all = 63015;
|
62
|
+
optional bool benchgen_all = 63016;
|
63
|
+
optional bool marshaler_all = 63017;
|
64
|
+
optional bool unmarshaler_all = 63018;
|
65
|
+
optional bool stable_marshaler_all = 63019;
|
66
|
+
|
67
|
+
optional bool sizer_all = 63020;
|
68
|
+
|
69
|
+
optional bool goproto_enum_stringer_all = 63021;
|
70
|
+
optional bool enum_stringer_all = 63022;
|
71
|
+
|
72
|
+
optional bool unsafe_marshaler_all = 63023;
|
73
|
+
optional bool unsafe_unmarshaler_all = 63024;
|
74
|
+
|
75
|
+
optional bool goproto_extensions_map_all = 63025;
|
76
|
+
optional bool goproto_unrecognized_all = 63026;
|
77
|
+
optional bool gogoproto_import = 63027;
|
78
|
+
optional bool protosizer_all = 63028;
|
79
|
+
optional bool compare_all = 63029;
|
80
|
+
optional bool typedecl_all = 63030;
|
81
|
+
optional bool enumdecl_all = 63031;
|
82
|
+
|
83
|
+
optional bool goproto_registration = 63032;
|
84
|
+
optional bool messagename_all = 63033;
|
85
|
+
|
86
|
+
optional bool goproto_sizecache_all = 63034;
|
87
|
+
optional bool goproto_unkeyed_all = 63035;
|
88
|
+
}
|
89
|
+
|
90
|
+
extend google.protobuf.MessageOptions {
|
91
|
+
optional bool goproto_getters = 64001;
|
92
|
+
optional bool goproto_stringer = 64003;
|
93
|
+
optional bool verbose_equal = 64004;
|
94
|
+
optional bool face = 64005;
|
95
|
+
optional bool gostring = 64006;
|
96
|
+
optional bool populate = 64007;
|
97
|
+
optional bool stringer = 67008;
|
98
|
+
optional bool onlyone = 64009;
|
99
|
+
|
100
|
+
optional bool equal = 64013;
|
101
|
+
optional bool description = 64014;
|
102
|
+
optional bool testgen = 64015;
|
103
|
+
optional bool benchgen = 64016;
|
104
|
+
optional bool marshaler = 64017;
|
105
|
+
optional bool unmarshaler = 64018;
|
106
|
+
optional bool stable_marshaler = 64019;
|
107
|
+
|
108
|
+
optional bool sizer = 64020;
|
109
|
+
|
110
|
+
optional bool unsafe_marshaler = 64023;
|
111
|
+
optional bool unsafe_unmarshaler = 64024;
|
112
|
+
|
113
|
+
optional bool goproto_extensions_map = 64025;
|
114
|
+
optional bool goproto_unrecognized = 64026;
|
115
|
+
|
116
|
+
optional bool protosizer = 64028;
|
117
|
+
optional bool compare = 64029;
|
118
|
+
|
119
|
+
optional bool typedecl = 64030;
|
120
|
+
|
121
|
+
optional bool messagename = 64033;
|
122
|
+
|
123
|
+
optional bool goproto_sizecache = 64034;
|
124
|
+
optional bool goproto_unkeyed = 64035;
|
125
|
+
}
|
126
|
+
|
127
|
+
extend google.protobuf.FieldOptions {
|
128
|
+
optional bool nullable = 65001;
|
129
|
+
optional bool embed = 65002;
|
130
|
+
optional string customtype = 65003;
|
131
|
+
optional string customname = 65004;
|
132
|
+
optional string jsontag = 65005;
|
133
|
+
optional string moretags = 65006;
|
134
|
+
optional string casttype = 65007;
|
135
|
+
optional string castkey = 65008;
|
136
|
+
optional string castvalue = 65009;
|
137
|
+
|
138
|
+
optional bool stdtime = 65010;
|
139
|
+
optional bool stdduration = 65011;
|
140
|
+
optional bool wktpointer = 65012;
|
141
|
+
}
|
@@ -0,0 +1,86 @@
|
|
1
|
+
// The MIT License
|
2
|
+
//
|
3
|
+
// Copyright (c) 2020 Temporal Technologies Inc. All rights reserved.
|
4
|
+
//
|
5
|
+
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
6
|
+
// of this software and associated documentation files (the "Software"), to deal
|
7
|
+
// in the Software without restriction, including without limitation the rights
|
8
|
+
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9
|
+
// copies of the Software, and to permit persons to whom the Software is
|
10
|
+
// furnished to do so, subject to the following conditions:
|
11
|
+
//
|
12
|
+
// The above copyright notice and this permission notice shall be included in
|
13
|
+
// all copies or substantial portions of the Software.
|
14
|
+
//
|
15
|
+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16
|
+
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
17
|
+
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
18
|
+
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
19
|
+
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
20
|
+
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
21
|
+
// THE SOFTWARE.
|
22
|
+
|
23
|
+
syntax = "proto3";
|
24
|
+
|
25
|
+
package temporal.api.batch.v1;
|
26
|
+
|
27
|
+
option go_package = "go.temporal.io/api/batch/v1;batch";
|
28
|
+
option java_package = "io.temporal.api.batch.v1";
|
29
|
+
option java_multiple_files = true;
|
30
|
+
option java_outer_classname = "MessageProto";
|
31
|
+
option ruby_package = "Temporal::Api::Batch::V1";
|
32
|
+
option csharp_namespace = "Temporal.Api.Batch.V1";
|
33
|
+
|
34
|
+
import "dependencies/gogoproto/gogo.proto";
|
35
|
+
import "google/protobuf/timestamp.proto";
|
36
|
+
|
37
|
+
|
38
|
+
import "temporal/api/common/v1/message.proto";
|
39
|
+
import "temporal/api/enums/v1/batch_operation.proto";
|
40
|
+
|
41
|
+
message BatchOperationInfo {
|
42
|
+
// Batch job ID
|
43
|
+
string job_id = 1;
|
44
|
+
// Batch operation state
|
45
|
+
temporal.api.enums.v1.BatchOperationState state = 2;
|
46
|
+
// Batch operation start time
|
47
|
+
google.protobuf.Timestamp start_time = 3 [(gogoproto.stdtime) = true];
|
48
|
+
// Batch operation close time
|
49
|
+
google.protobuf.Timestamp close_time = 4 [(gogoproto.stdtime) = true];
|
50
|
+
}
|
51
|
+
|
52
|
+
// BatchOperationTermination sends terminate requests to batch workflows.
|
53
|
+
// Keep the parameter in sync with temporal.api.workflowservice.v1.TerminateWorkflowExecutionRequest.
|
54
|
+
// Ignore first_execution_run_id because this is used for single workflow operation.
|
55
|
+
message BatchOperationTermination {
|
56
|
+
// Reason of terminate workflows
|
57
|
+
string reason = 1;
|
58
|
+
// Serialized value(s) to provide to the termination event
|
59
|
+
temporal.api.common.v1.Payloads details = 2;
|
60
|
+
// The identity of the worker/client
|
61
|
+
string identity = 3;
|
62
|
+
}
|
63
|
+
|
64
|
+
// BatchOperationSignal sends signals to batch workflows.
|
65
|
+
// Keep the parameter in sync with temporal.api.workflowservice.v1.SignalWorkflowExecutionRequest.
|
66
|
+
message BatchOperationSignal {
|
67
|
+
// The workflow author-defined name of the signal to send to the workflow
|
68
|
+
string signal = 1;
|
69
|
+
// Serialized value(s) to provide with the signal
|
70
|
+
temporal.api.common.v1.Payloads input = 2;
|
71
|
+
// Headers that are passed with the signal to the processing workflow.
|
72
|
+
// These can include things like auth or tracing tokens.
|
73
|
+
temporal.api.common.v1.Header header = 3;
|
74
|
+
// The identity of the worker/client
|
75
|
+
string identity = 4;
|
76
|
+
}
|
77
|
+
|
78
|
+
// BatchOperationCancellation sends cancel requests to batch workflows.
|
79
|
+
// Keep the parameter in sync with temporal.api.workflowservice.v1.RequestCancelWorkflowExecutionRequest.
|
80
|
+
// Ignore first_execution_run_id because this is used for single workflow operation.
|
81
|
+
message BatchOperationCancellation {
|
82
|
+
// Reason of cancel workflows
|
83
|
+
string reason = 1;
|
84
|
+
// The identity of the worker/client
|
85
|
+
string identity = 2;
|
86
|
+
}
|
@@ -0,0 +1,83 @@
|
|
1
|
+
// The MIT License
|
2
|
+
//
|
3
|
+
// Copyright (c) 2022 Temporal Technologies Inc. All rights reserved.
|
4
|
+
//
|
5
|
+
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
6
|
+
// of this software and associated documentation files (the "Software"), to deal
|
7
|
+
// in the Software without restriction, including without limitation the rights
|
8
|
+
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9
|
+
// copies of the Software, and to permit persons to whom the Software is
|
10
|
+
// furnished to do so, subject to the following conditions:
|
11
|
+
//
|
12
|
+
// The above copyright notice and this permission notice shall be included in
|
13
|
+
// all copies or substantial portions of the Software.
|
14
|
+
//
|
15
|
+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16
|
+
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
17
|
+
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
18
|
+
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
19
|
+
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
20
|
+
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
21
|
+
// THE SOFTWARE.
|
22
|
+
|
23
|
+
syntax = "proto3";
|
24
|
+
|
25
|
+
package temporal.api.cluster.v1;
|
26
|
+
|
27
|
+
option go_package = "go.temporal.io/api/cluster/v1;cluster";
|
28
|
+
option java_package = "io.temporal.api.cluster.v1";
|
29
|
+
option java_multiple_files = true;
|
30
|
+
option java_outer_classname = "MessageProto";
|
31
|
+
option ruby_package = "Temporal::Api::Cluster::V1";
|
32
|
+
option csharp_namespace = "Temporal.Api.Cluster.V1";
|
33
|
+
|
34
|
+
import "dependencies/gogoproto/gogo.proto";
|
35
|
+
import "google/protobuf/timestamp.proto";
|
36
|
+
|
37
|
+
import "temporal/api/enums/v1/cluster.proto";
|
38
|
+
import "temporal/api/enums/v1/common.proto";
|
39
|
+
import "temporal/api/version/v1/message.proto";
|
40
|
+
|
41
|
+
// data column
|
42
|
+
message ClusterMetadata {
|
43
|
+
string cluster = 1;
|
44
|
+
int32 history_shard_count = 2;
|
45
|
+
string cluster_id = 3;
|
46
|
+
temporal.api.version.v1.VersionInfo version_info = 4;
|
47
|
+
map<string,IndexSearchAttributes> index_search_attributes = 5;
|
48
|
+
string cluster_address = 6;
|
49
|
+
int64 failover_version_increment = 7;
|
50
|
+
int64 initial_failover_version = 8;
|
51
|
+
bool is_global_namespace_enabled = 9;
|
52
|
+
bool is_connection_enabled = 10;
|
53
|
+
}
|
54
|
+
|
55
|
+
message IndexSearchAttributes{
|
56
|
+
map<string,temporal.api.enums.v1.IndexedValueType> custom_search_attributes = 1;
|
57
|
+
}
|
58
|
+
|
59
|
+
message HostInfo {
|
60
|
+
string identity = 1;
|
61
|
+
}
|
62
|
+
|
63
|
+
message RingInfo {
|
64
|
+
string role = 1;
|
65
|
+
int32 member_count = 2;
|
66
|
+
repeated HostInfo members = 3;
|
67
|
+
}
|
68
|
+
|
69
|
+
message MembershipInfo {
|
70
|
+
HostInfo current_host = 1;
|
71
|
+
repeated string reachable_members = 2;
|
72
|
+
repeated RingInfo rings = 3;
|
73
|
+
}
|
74
|
+
|
75
|
+
message ClusterMember {
|
76
|
+
temporal.api.enums.v1.ClusterMemberRole role = 1;
|
77
|
+
string host_id = 2;
|
78
|
+
string rpc_address = 3;
|
79
|
+
int32 rpc_port = 4;
|
80
|
+
google.protobuf.Timestamp session_start_time = 5 [(gogoproto.stdtime) = true];
|
81
|
+
google.protobuf.Timestamp last_heartbit_time = 6 [(gogoproto.stdtime) = true];
|
82
|
+
google.protobuf.Timestamp record_expiry_time = 7 [(gogoproto.stdtime) = true];
|
83
|
+
}
|
@@ -0,0 +1,259 @@
|
|
1
|
+
// The MIT License
|
2
|
+
//
|
3
|
+
// Copyright (c) 2020 Temporal Technologies Inc. All rights reserved.
|
4
|
+
//
|
5
|
+
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
6
|
+
// of this software and associated documentation files (the "Software"), to deal
|
7
|
+
// in the Software without restriction, including without limitation the rights
|
8
|
+
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9
|
+
// copies of the Software, and to permit persons to whom the Software is
|
10
|
+
// furnished to do so, subject to the following conditions:
|
11
|
+
//
|
12
|
+
// The above copyright notice and this permission notice shall be included in
|
13
|
+
// all copies or substantial portions of the Software.
|
14
|
+
//
|
15
|
+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16
|
+
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
17
|
+
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
18
|
+
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
19
|
+
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
20
|
+
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
21
|
+
// THE SOFTWARE.
|
22
|
+
|
23
|
+
syntax = "proto3";
|
24
|
+
|
25
|
+
package temporal.api.command.v1;
|
26
|
+
|
27
|
+
option go_package = "go.temporal.io/api/command/v1;command";
|
28
|
+
option java_package = "io.temporal.api.command.v1";
|
29
|
+
option java_multiple_files = true;
|
30
|
+
option java_outer_classname = "MessageProto";
|
31
|
+
option ruby_package = "Temporal::Api::Command::V1";
|
32
|
+
option csharp_namespace = "Temporal.Api.Command.V1";
|
33
|
+
|
34
|
+
import "google/protobuf/duration.proto";
|
35
|
+
|
36
|
+
import "dependencies/gogoproto/gogo.proto";
|
37
|
+
|
38
|
+
import "temporal/api/enums/v1/workflow.proto";
|
39
|
+
import "temporal/api/enums/v1/command_type.proto";
|
40
|
+
import "temporal/api/enums/v1/update.proto";
|
41
|
+
import "temporal/api/common/v1/message.proto";
|
42
|
+
import "temporal/api/failure/v1/message.proto";
|
43
|
+
import "temporal/api/taskqueue/v1/message.proto";
|
44
|
+
|
45
|
+
message ScheduleActivityTaskCommandAttributes {
|
46
|
+
string activity_id = 1;
|
47
|
+
temporal.api.common.v1.ActivityType activity_type = 2;
|
48
|
+
// This used to be a `namespace` field which allowed to schedule activity in another namespace.
|
49
|
+
reserved 3;
|
50
|
+
temporal.api.taskqueue.v1.TaskQueue task_queue = 4;
|
51
|
+
temporal.api.common.v1.Header header = 5;
|
52
|
+
temporal.api.common.v1.Payloads input = 6;
|
53
|
+
// Indicates how long the caller is willing to wait for activity completion. The "schedule" time
|
54
|
+
// is when the activity is initially scheduled, not when the most recent retry is scheduled.
|
55
|
+
// Limits how long retries will be attempted. Either this or `start_to_close_timeout` must be
|
56
|
+
// specified. When not specified, defaults to the workflow execution timeout.
|
57
|
+
//
|
58
|
+
// (-- api-linter: core::0140::prepositions=disabled
|
59
|
+
// aip.dev/not-precedent: "to" is used to indicate interval. --)
|
60
|
+
google.protobuf.Duration schedule_to_close_timeout = 7 [(gogoproto.stdduration) = true];
|
61
|
+
// Limits the time an activity task can stay in a task queue before a worker picks it up. The
|
62
|
+
// "schedule" time is when the most recent retry is scheduled. This timeout should usually not
|
63
|
+
// be set: it's useful in specific scenarios like worker-specific task queues. This timeout is
|
64
|
+
// always non retryable, as all a retry would achieve is to put it back into the same queue.
|
65
|
+
// Defaults to `schedule_to_close_timeout` or workflow execution timeout if that is not
|
66
|
+
// specified. More info:
|
67
|
+
// https://docs.temporal.io/docs/content/what-is-a-schedule-to-start-timeout/
|
68
|
+
//
|
69
|
+
// (-- api-linter: core::0140::prepositions=disabled
|
70
|
+
// aip.dev/not-precedent: "to" is used to indicate interval. --)
|
71
|
+
google.protobuf.Duration schedule_to_start_timeout = 8 [(gogoproto.stdduration) = true];
|
72
|
+
// Maximum time an activity is allowed to execute after being picked up by a worker. This
|
73
|
+
// timeout is always retryable. Either this or `schedule_to_close_timeout` must be specified.
|
74
|
+
//
|
75
|
+
// (-- api-linter: core::0140::prepositions=disabled
|
76
|
+
// aip.dev/not-precedent: "to" is used to indicate interval. --)
|
77
|
+
google.protobuf.Duration start_to_close_timeout = 9 [(gogoproto.stdduration) = true];
|
78
|
+
// Maximum permitted time between successful worker heartbeats.
|
79
|
+
google.protobuf.Duration heartbeat_timeout = 10 [(gogoproto.stdduration) = true];
|
80
|
+
// Activities are provided by a default retry policy which is controlled through the service's
|
81
|
+
// dynamic configuration. Retries will be attempted until `schedule_to_close_timeout` has
|
82
|
+
// elapsed. To disable retries set retry_policy.maximum_attempts to 1.
|
83
|
+
temporal.api.common.v1.RetryPolicy retry_policy = 11;
|
84
|
+
// Request to start the activity directly bypassing matching service and worker polling
|
85
|
+
// The slot for executing the activity should be reserved when setting this field to true.
|
86
|
+
bool request_eager_execution = 12;
|
87
|
+
}
|
88
|
+
|
89
|
+
message RequestCancelActivityTaskCommandAttributes {
|
90
|
+
// The `ACTIVITY_TASK_SCHEDULED` event id for the activity being cancelled.
|
91
|
+
int64 scheduled_event_id = 1;
|
92
|
+
}
|
93
|
+
|
94
|
+
message StartTimerCommandAttributes {
|
95
|
+
// An id for the timer, currently live timers must have different ids. Typically autogenerated
|
96
|
+
// by the SDK.
|
97
|
+
string timer_id = 1;
|
98
|
+
// How long until the timer fires, producing a `TIMER_FIRED` event.
|
99
|
+
//
|
100
|
+
// (-- api-linter: core::0140::prepositions=disabled
|
101
|
+
// aip.dev/not-precedent: "to" is used to indicate interval. --)
|
102
|
+
google.protobuf.Duration start_to_fire_timeout = 2 [(gogoproto.stdduration) = true];
|
103
|
+
}
|
104
|
+
|
105
|
+
message CompleteWorkflowExecutionCommandAttributes {
|
106
|
+
temporal.api.common.v1.Payloads result = 1;
|
107
|
+
}
|
108
|
+
|
109
|
+
message FailWorkflowExecutionCommandAttributes {
|
110
|
+
temporal.api.failure.v1.Failure failure = 1;
|
111
|
+
}
|
112
|
+
|
113
|
+
message CancelTimerCommandAttributes {
|
114
|
+
// The same timer id from the start timer command
|
115
|
+
string timer_id = 1;
|
116
|
+
}
|
117
|
+
|
118
|
+
message CancelWorkflowExecutionCommandAttributes {
|
119
|
+
temporal.api.common.v1.Payloads details = 1;
|
120
|
+
}
|
121
|
+
|
122
|
+
message RequestCancelExternalWorkflowExecutionCommandAttributes {
|
123
|
+
string namespace = 1;
|
124
|
+
string workflow_id = 2;
|
125
|
+
string run_id = 3;
|
126
|
+
// Deprecated.
|
127
|
+
string control = 4;
|
128
|
+
// Set this to true if the workflow being cancelled is a child of the workflow originating this
|
129
|
+
// command. The request will be rejected if it is set to true and the target workflow is *not*
|
130
|
+
// a child of the requesting workflow.
|
131
|
+
bool child_workflow_only = 5;
|
132
|
+
// Reason for requesting the cancellation
|
133
|
+
string reason = 6;
|
134
|
+
}
|
135
|
+
|
136
|
+
message SignalExternalWorkflowExecutionCommandAttributes {
|
137
|
+
string namespace = 1;
|
138
|
+
temporal.api.common.v1.WorkflowExecution execution = 2;
|
139
|
+
// The workflow author-defined name of the signal to send to the workflow.
|
140
|
+
string signal_name = 3;
|
141
|
+
// Serialized value(s) to provide with the signal.
|
142
|
+
temporal.api.common.v1.Payloads input = 4;
|
143
|
+
// Deprecated
|
144
|
+
string control = 5;
|
145
|
+
// Set this to true if the workflow being cancelled is a child of the workflow originating this
|
146
|
+
// command. The request will be rejected if it is set to true and the target workflow is *not*
|
147
|
+
// a child of the requesting workflow.
|
148
|
+
bool child_workflow_only = 6;
|
149
|
+
// Headers that are passed by the workflow that is sending a signal to the external
|
150
|
+
// workflow that is receiving this signal.
|
151
|
+
temporal.api.common.v1.Header header = 7;
|
152
|
+
}
|
153
|
+
|
154
|
+
message UpsertWorkflowSearchAttributesCommandAttributes {
|
155
|
+
temporal.api.common.v1.SearchAttributes search_attributes = 1;
|
156
|
+
}
|
157
|
+
|
158
|
+
message RecordMarkerCommandAttributes {
|
159
|
+
string marker_name = 1;
|
160
|
+
map<string, temporal.api.common.v1.Payloads> details = 2;
|
161
|
+
temporal.api.common.v1.Header header = 3;
|
162
|
+
temporal.api.failure.v1.Failure failure = 4;
|
163
|
+
}
|
164
|
+
|
165
|
+
message ContinueAsNewWorkflowExecutionCommandAttributes {
|
166
|
+
temporal.api.common.v1.WorkflowType workflow_type = 1;
|
167
|
+
temporal.api.taskqueue.v1.TaskQueue task_queue = 2;
|
168
|
+
temporal.api.common.v1.Payloads input = 3;
|
169
|
+
|
170
|
+
// Timeout of a single workflow run.
|
171
|
+
google.protobuf.Duration workflow_run_timeout = 4 [(gogoproto.stdduration) = true];
|
172
|
+
// Timeout of a single workflow task.
|
173
|
+
google.protobuf.Duration workflow_task_timeout = 5 [(gogoproto.stdduration) = true];
|
174
|
+
// How long the workflow start will be delayed - not really a "backoff" in the traditional sense.
|
175
|
+
google.protobuf.Duration backoff_start_interval = 6 [(gogoproto.stdduration) = true];
|
176
|
+
temporal.api.common.v1.RetryPolicy retry_policy = 7;
|
177
|
+
// Should be removed
|
178
|
+
temporal.api.enums.v1.ContinueAsNewInitiator initiator = 8;
|
179
|
+
// Should be removed
|
180
|
+
temporal.api.failure.v1.Failure failure = 9;
|
181
|
+
// Should be removed
|
182
|
+
temporal.api.common.v1.Payloads last_completion_result = 10;
|
183
|
+
// Should be removed. Not necessarily unused but unclear and not exposed by SDKs.
|
184
|
+
string cron_schedule = 11;
|
185
|
+
temporal.api.common.v1.Header header = 12;
|
186
|
+
temporal.api.common.v1.Memo memo = 13;
|
187
|
+
temporal.api.common.v1.SearchAttributes search_attributes = 14;
|
188
|
+
|
189
|
+
// `workflow_execution_timeout` is omitted as it shouldn't be overridden from within a workflow.
|
190
|
+
}
|
191
|
+
|
192
|
+
message StartChildWorkflowExecutionCommandAttributes {
|
193
|
+
string namespace = 1;
|
194
|
+
string workflow_id = 2;
|
195
|
+
temporal.api.common.v1.WorkflowType workflow_type = 3;
|
196
|
+
temporal.api.taskqueue.v1.TaskQueue task_queue = 4;
|
197
|
+
temporal.api.common.v1.Payloads input = 5;
|
198
|
+
// Total workflow execution timeout including retries and continue as new.
|
199
|
+
google.protobuf.Duration workflow_execution_timeout = 6 [(gogoproto.stdduration) = true];
|
200
|
+
// Timeout of a single workflow run.
|
201
|
+
google.protobuf.Duration workflow_run_timeout = 7 [(gogoproto.stdduration) = true];
|
202
|
+
// Timeout of a single workflow task.
|
203
|
+
google.protobuf.Duration workflow_task_timeout = 8 [(gogoproto.stdduration) = true];
|
204
|
+
// Default: PARENT_CLOSE_POLICY_TERMINATE.
|
205
|
+
temporal.api.enums.v1.ParentClosePolicy parent_close_policy = 9;
|
206
|
+
string control = 10;
|
207
|
+
// Default: WORKFLOW_ID_REUSE_POLICY_ALLOW_DUPLICATE.
|
208
|
+
temporal.api.enums.v1.WorkflowIdReusePolicy workflow_id_reuse_policy = 11;
|
209
|
+
temporal.api.common.v1.RetryPolicy retry_policy = 12;
|
210
|
+
// Establish a cron schedule for the child workflow.
|
211
|
+
string cron_schedule = 13;
|
212
|
+
temporal.api.common.v1.Header header = 14;
|
213
|
+
temporal.api.common.v1.Memo memo = 15;
|
214
|
+
temporal.api.common.v1.SearchAttributes search_attributes = 16;
|
215
|
+
}
|
216
|
+
|
217
|
+
message AcceptWorkflowUpdateCommandAttributes {
|
218
|
+
// A unique identifier for an update within a given workflow context
|
219
|
+
string update_id = 1;
|
220
|
+
}
|
221
|
+
|
222
|
+
message CompleteWorkflowUpdateCommandAttributes {
|
223
|
+
// A unique identifier for an update within a given workflow context
|
224
|
+
string update_id = 1;
|
225
|
+
|
226
|
+
// Whether the server should attempt to bypass making this update rejection
|
227
|
+
// durable in history. This field is only consulted when the result field
|
228
|
+
// indicates failure. Leaving this field in its default state (i.e.
|
229
|
+
// UPDATE_WORKFLOW_REJECTION_DURABILITY_PREFERENCE_UNSPECIFIED) will result
|
230
|
+
// in making the rejection durable.
|
231
|
+
temporal.api.enums.v1.WorkflowUpdateDurabilityPreference durability_preference = 2;
|
232
|
+
|
233
|
+
// The success or failure output of the update
|
234
|
+
oneof result {
|
235
|
+
temporal.api.common.v1.Payloads success = 3;
|
236
|
+
temporal.api.failure.v1.Failure failure = 4;
|
237
|
+
}
|
238
|
+
}
|
239
|
+
|
240
|
+
message Command {
|
241
|
+
temporal.api.enums.v1.CommandType command_type = 1;
|
242
|
+
oneof attributes {
|
243
|
+
ScheduleActivityTaskCommandAttributes schedule_activity_task_command_attributes = 2;
|
244
|
+
StartTimerCommandAttributes start_timer_command_attributes = 3;
|
245
|
+
CompleteWorkflowExecutionCommandAttributes complete_workflow_execution_command_attributes = 4;
|
246
|
+
FailWorkflowExecutionCommandAttributes fail_workflow_execution_command_attributes = 5;
|
247
|
+
RequestCancelActivityTaskCommandAttributes request_cancel_activity_task_command_attributes = 6;
|
248
|
+
CancelTimerCommandAttributes cancel_timer_command_attributes = 7;
|
249
|
+
CancelWorkflowExecutionCommandAttributes cancel_workflow_execution_command_attributes = 8;
|
250
|
+
RequestCancelExternalWorkflowExecutionCommandAttributes request_cancel_external_workflow_execution_command_attributes = 9;
|
251
|
+
RecordMarkerCommandAttributes record_marker_command_attributes = 10;
|
252
|
+
ContinueAsNewWorkflowExecutionCommandAttributes continue_as_new_workflow_execution_command_attributes = 11;
|
253
|
+
StartChildWorkflowExecutionCommandAttributes start_child_workflow_execution_command_attributes = 12;
|
254
|
+
SignalExternalWorkflowExecutionCommandAttributes signal_external_workflow_execution_command_attributes = 13;
|
255
|
+
UpsertWorkflowSearchAttributesCommandAttributes upsert_workflow_search_attributes_command_attributes = 14;
|
256
|
+
AcceptWorkflowUpdateCommandAttributes accept_workflow_update_command_attributes = 15;
|
257
|
+
CompleteWorkflowUpdateCommandAttributes complete_workflow_update_command_attributes = 16;
|
258
|
+
}
|
259
|
+
}
|