temporalio 0.0.2 → 0.1.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.
Files changed (320) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +25 -23
  3. data/bridge/Cargo.lock +185 -76
  4. data/bridge/Cargo.toml +6 -4
  5. data/bridge/sdk-core/README.md +19 -6
  6. data/bridge/sdk-core/client/src/lib.rs +215 -39
  7. data/bridge/sdk-core/client/src/metrics.rs +17 -8
  8. data/bridge/sdk-core/client/src/raw.rs +4 -4
  9. data/bridge/sdk-core/client/src/retry.rs +32 -20
  10. data/bridge/sdk-core/core/Cargo.toml +22 -9
  11. data/bridge/sdk-core/core/src/abstractions.rs +203 -14
  12. data/bridge/sdk-core/core/src/core_tests/activity_tasks.rs +76 -41
  13. data/bridge/sdk-core/core/src/core_tests/determinism.rs +165 -2
  14. data/bridge/sdk-core/core/src/core_tests/local_activities.rs +204 -83
  15. data/bridge/sdk-core/core/src/core_tests/queries.rs +3 -4
  16. data/bridge/sdk-core/core/src/core_tests/workers.rs +1 -3
  17. data/bridge/sdk-core/core/src/core_tests/workflow_tasks.rs +397 -54
  18. data/bridge/sdk-core/core/src/ephemeral_server/mod.rs +106 -12
  19. data/bridge/sdk-core/core/src/internal_flags.rs +136 -0
  20. data/bridge/sdk-core/core/src/lib.rs +16 -9
  21. data/bridge/sdk-core/core/src/telemetry/log_export.rs +1 -1
  22. data/bridge/sdk-core/core/src/telemetry/metrics.rs +69 -35
  23. data/bridge/sdk-core/core/src/telemetry/mod.rs +29 -13
  24. data/bridge/sdk-core/core/src/telemetry/prometheus_server.rs +17 -12
  25. data/bridge/sdk-core/core/src/test_help/mod.rs +62 -12
  26. data/bridge/sdk-core/core/src/worker/activities/activity_heartbeat_manager.rs +112 -156
  27. data/bridge/sdk-core/core/src/worker/activities/activity_task_poller_stream.rs +89 -0
  28. data/bridge/sdk-core/core/src/worker/activities/local_activities.rs +352 -122
  29. data/bridge/sdk-core/core/src/worker/activities.rs +233 -157
  30. data/bridge/sdk-core/core/src/worker/client/mocks.rs +22 -2
  31. data/bridge/sdk-core/core/src/worker/client.rs +18 -2
  32. data/bridge/sdk-core/core/src/worker/mod.rs +165 -58
  33. data/bridge/sdk-core/core/src/worker/workflow/bridge.rs +1 -3
  34. data/bridge/sdk-core/core/src/worker/workflow/driven_workflow.rs +3 -5
  35. data/bridge/sdk-core/core/src/worker/workflow/history_update.rs +856 -277
  36. data/bridge/sdk-core/core/src/worker/workflow/machines/activity_state_machine.rs +100 -43
  37. data/bridge/sdk-core/core/src/worker/workflow/machines/cancel_external_state_machine.rs +7 -7
  38. data/bridge/sdk-core/core/src/worker/workflow/machines/cancel_workflow_state_machine.rs +5 -4
  39. data/bridge/sdk-core/core/src/worker/workflow/machines/child_workflow_state_machine.rs +87 -27
  40. data/bridge/sdk-core/core/src/worker/workflow/machines/complete_workflow_state_machine.rs +5 -4
  41. data/bridge/sdk-core/core/src/worker/workflow/machines/continue_as_new_workflow_state_machine.rs +5 -4
  42. data/bridge/sdk-core/core/src/worker/workflow/machines/fail_workflow_state_machine.rs +5 -4
  43. data/bridge/sdk-core/core/src/worker/workflow/machines/local_activity_state_machine.rs +137 -62
  44. data/bridge/sdk-core/core/src/worker/workflow/machines/mod.rs +25 -17
  45. data/bridge/sdk-core/core/src/worker/workflow/machines/modify_workflow_properties_state_machine.rs +7 -6
  46. data/bridge/sdk-core/core/src/worker/workflow/machines/patch_state_machine.rs +103 -152
  47. data/bridge/sdk-core/core/src/worker/workflow/machines/signal_external_state_machine.rs +7 -7
  48. data/bridge/sdk-core/core/src/worker/workflow/machines/timer_state_machine.rs +9 -9
  49. data/bridge/sdk-core/core/src/worker/workflow/machines/transition_coverage.rs +2 -2
  50. data/bridge/sdk-core/core/src/worker/workflow/machines/upsert_search_attributes_state_machine.rs +14 -7
  51. data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_machines/local_acts.rs +5 -16
  52. data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_machines.rs +201 -121
  53. data/bridge/sdk-core/core/src/worker/workflow/machines/workflow_task_state_machine.rs +11 -14
  54. data/bridge/sdk-core/core/src/worker/workflow/managed_run/managed_wf_test.rs +30 -15
  55. data/bridge/sdk-core/core/src/worker/workflow/managed_run.rs +1026 -376
  56. data/bridge/sdk-core/core/src/worker/workflow/mod.rs +460 -384
  57. data/bridge/sdk-core/core/src/worker/workflow/run_cache.rs +40 -57
  58. data/bridge/sdk-core/core/src/worker/workflow/wft_extraction.rs +125 -0
  59. data/bridge/sdk-core/core/src/worker/workflow/wft_poller.rs +1 -4
  60. data/bridge/sdk-core/core/src/worker/workflow/workflow_stream/saved_wf_inputs.rs +117 -0
  61. data/bridge/sdk-core/core/src/worker/workflow/workflow_stream/tonic_status_serde.rs +24 -0
  62. data/bridge/sdk-core/core/src/worker/workflow/workflow_stream.rs +448 -718
  63. data/bridge/sdk-core/core-api/Cargo.toml +2 -1
  64. data/bridge/sdk-core/core-api/src/errors.rs +1 -34
  65. data/bridge/sdk-core/core-api/src/lib.rs +6 -2
  66. data/bridge/sdk-core/core-api/src/telemetry.rs +0 -6
  67. data/bridge/sdk-core/core-api/src/worker.rs +14 -1
  68. data/bridge/sdk-core/fsm/rustfsm_procmacro/src/lib.rs +18 -15
  69. data/bridge/sdk-core/fsm/rustfsm_trait/src/lib.rs +8 -3
  70. data/bridge/sdk-core/histories/evict_while_la_running_no_interference-16_history.bin +0 -0
  71. data/bridge/sdk-core/protos/api_upstream/temporal/api/command/v1/message.proto +5 -17
  72. data/bridge/sdk-core/protos/api_upstream/temporal/api/common/v1/message.proto +11 -0
  73. data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/command_type.proto +1 -6
  74. data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/event_type.proto +6 -6
  75. data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/failed_cause.proto +5 -0
  76. data/bridge/sdk-core/protos/api_upstream/temporal/api/enums/v1/update.proto +22 -6
  77. data/bridge/sdk-core/protos/api_upstream/temporal/api/history/v1/message.proto +48 -19
  78. data/bridge/sdk-core/protos/api_upstream/temporal/api/namespace/v1/message.proto +2 -0
  79. data/bridge/sdk-core/protos/api_upstream/temporal/api/operatorservice/v1/request_response.proto +3 -0
  80. data/bridge/sdk-core/protos/api_upstream/temporal/api/{enums/v1/interaction_type.proto → protocol/v1/message.proto} +29 -11
  81. data/bridge/sdk-core/protos/api_upstream/temporal/api/sdk/v1/task_complete_metadata.proto +63 -0
  82. data/bridge/sdk-core/protos/api_upstream/temporal/api/update/v1/message.proto +111 -0
  83. data/bridge/sdk-core/protos/api_upstream/temporal/api/workflowservice/v1/request_response.proto +59 -28
  84. data/bridge/sdk-core/protos/api_upstream/temporal/api/workflowservice/v1/service.proto +2 -2
  85. data/bridge/sdk-core/protos/local/temporal/sdk/core/activity_result/activity_result.proto +1 -0
  86. data/bridge/sdk-core/protos/local/temporal/sdk/core/activity_task/activity_task.proto +1 -0
  87. data/bridge/sdk-core/protos/local/temporal/sdk/core/child_workflow/child_workflow.proto +1 -0
  88. data/bridge/sdk-core/protos/local/temporal/sdk/core/common/common.proto +1 -0
  89. data/bridge/sdk-core/protos/local/temporal/sdk/core/core_interface.proto +1 -0
  90. data/bridge/sdk-core/protos/local/temporal/sdk/core/external_data/external_data.proto +1 -0
  91. data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_activation/workflow_activation.proto +7 -0
  92. data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_commands/workflow_commands.proto +1 -0
  93. data/bridge/sdk-core/protos/local/temporal/sdk/core/workflow_completion/workflow_completion.proto +6 -0
  94. data/bridge/sdk-core/sdk/Cargo.toml +3 -2
  95. data/bridge/sdk-core/sdk/src/lib.rs +87 -20
  96. data/bridge/sdk-core/sdk/src/workflow_future.rs +9 -8
  97. data/bridge/sdk-core/sdk-core-protos/Cargo.toml +5 -2
  98. data/bridge/sdk-core/sdk-core-protos/build.rs +36 -1
  99. data/bridge/sdk-core/sdk-core-protos/src/history_builder.rs +100 -87
  100. data/bridge/sdk-core/sdk-core-protos/src/history_info.rs +5 -1
  101. data/bridge/sdk-core/sdk-core-protos/src/lib.rs +175 -57
  102. data/bridge/sdk-core/sdk-core-protos/src/task_token.rs +12 -2
  103. data/bridge/sdk-core/test-utils/Cargo.toml +3 -1
  104. data/bridge/sdk-core/test-utils/src/canned_histories.rs +106 -296
  105. data/bridge/sdk-core/test-utils/src/histfetch.rs +1 -1
  106. data/bridge/sdk-core/test-utils/src/lib.rs +82 -23
  107. data/bridge/sdk-core/test-utils/src/wf_input_saver.rs +50 -0
  108. data/bridge/sdk-core/test-utils/src/workflows.rs +29 -0
  109. data/bridge/sdk-core/tests/fuzzy_workflow.rs +130 -0
  110. data/bridge/sdk-core/tests/{load_tests.rs → heavy_tests.rs} +125 -51
  111. data/bridge/sdk-core/tests/integ_tests/ephemeral_server_tests.rs +25 -3
  112. data/bridge/sdk-core/tests/integ_tests/heartbeat_tests.rs +5 -3
  113. data/bridge/sdk-core/tests/integ_tests/metrics_tests.rs +218 -16
  114. data/bridge/sdk-core/tests/integ_tests/polling_tests.rs +4 -47
  115. data/bridge/sdk-core/tests/integ_tests/queries_tests.rs +5 -128
  116. data/bridge/sdk-core/tests/integ_tests/visibility_tests.rs +83 -25
  117. data/bridge/sdk-core/tests/integ_tests/workflow_tests/activities.rs +93 -69
  118. data/bridge/sdk-core/tests/integ_tests/workflow_tests/cancel_external.rs +1 -0
  119. data/bridge/sdk-core/tests/integ_tests/workflow_tests/cancel_wf.rs +6 -13
  120. data/bridge/sdk-core/tests/integ_tests/workflow_tests/child_workflows.rs +1 -0
  121. data/bridge/sdk-core/tests/integ_tests/workflow_tests/continue_as_new.rs +6 -2
  122. data/bridge/sdk-core/tests/integ_tests/workflow_tests/determinism.rs +3 -10
  123. data/bridge/sdk-core/tests/integ_tests/workflow_tests/local_activities.rs +72 -191
  124. data/bridge/sdk-core/tests/integ_tests/workflow_tests/modify_wf_properties.rs +1 -0
  125. data/bridge/sdk-core/tests/integ_tests/workflow_tests/patches.rs +7 -28
  126. data/bridge/sdk-core/tests/integ_tests/workflow_tests/replay.rs +12 -7
  127. data/bridge/sdk-core/tests/integ_tests/workflow_tests/resets.rs +1 -0
  128. data/bridge/sdk-core/tests/integ_tests/workflow_tests/signals.rs +18 -14
  129. data/bridge/sdk-core/tests/integ_tests/workflow_tests/stickyness.rs +6 -20
  130. data/bridge/sdk-core/tests/integ_tests/workflow_tests/timers.rs +10 -21
  131. data/bridge/sdk-core/tests/integ_tests/workflow_tests/upsert_search_attrs.rs +6 -4
  132. data/bridge/sdk-core/tests/integ_tests/workflow_tests.rs +10 -11
  133. data/bridge/sdk-core/tests/main.rs +3 -13
  134. data/bridge/sdk-core/tests/runner.rs +75 -36
  135. data/bridge/sdk-core/tests/wf_input_replay.rs +32 -0
  136. data/bridge/src/connection.rs +41 -25
  137. data/bridge/src/lib.rs +269 -14
  138. data/bridge/src/runtime.rs +1 -1
  139. data/bridge/src/test_server.rs +153 -0
  140. data/bridge/src/worker.rs +89 -16
  141. data/lib/gen/temporal/api/command/v1/message_pb.rb +4 -18
  142. data/lib/gen/temporal/api/common/v1/message_pb.rb +4 -0
  143. data/lib/gen/temporal/api/enums/v1/command_type_pb.rb +1 -3
  144. data/lib/gen/temporal/api/enums/v1/event_type_pb.rb +3 -3
  145. data/lib/gen/temporal/api/enums/v1/failed_cause_pb.rb +2 -0
  146. data/lib/gen/temporal/api/enums/v1/update_pb.rb +6 -4
  147. data/lib/gen/temporal/api/history/v1/message_pb.rb +27 -19
  148. data/lib/gen/temporal/api/namespace/v1/message_pb.rb +1 -0
  149. data/lib/gen/temporal/api/operatorservice/v1/request_response_pb.rb +3 -0
  150. data/lib/gen/temporal/api/protocol/v1/message_pb.rb +30 -0
  151. data/lib/gen/temporal/api/sdk/v1/task_complete_metadata_pb.rb +23 -0
  152. data/lib/gen/temporal/api/testservice/v1/request_response_pb.rb +49 -0
  153. data/lib/gen/temporal/api/testservice/v1/service_pb.rb +21 -0
  154. data/lib/gen/temporal/api/update/v1/message_pb.rb +72 -0
  155. data/lib/gen/temporal/api/workflowservice/v1/request_response_pb.rb +26 -16
  156. data/lib/gen/temporal/sdk/core/activity_result/activity_result_pb.rb +13 -9
  157. data/lib/gen/temporal/sdk/core/activity_task/activity_task_pb.rb +10 -6
  158. data/lib/gen/temporal/sdk/core/child_workflow/child_workflow_pb.rb +13 -9
  159. data/lib/gen/temporal/sdk/core/common/common_pb.rb +7 -3
  160. data/lib/gen/temporal/sdk/core/core_interface_pb.rb +9 -3
  161. data/lib/gen/temporal/sdk/core/external_data/external_data_pb.rb +7 -3
  162. data/lib/gen/temporal/sdk/core/workflow_activation/workflow_activation_pb.rb +27 -21
  163. data/lib/gen/temporal/sdk/core/workflow_commands/workflow_commands_pb.rb +28 -24
  164. data/lib/gen/temporal/sdk/core/workflow_completion/workflow_completion_pb.rb +12 -5
  165. data/lib/temporalio/activity/context.rb +13 -8
  166. data/lib/temporalio/activity/info.rb +1 -1
  167. data/lib/temporalio/bridge/connect_options.rb +15 -0
  168. data/lib/temporalio/bridge/retry_config.rb +24 -0
  169. data/lib/temporalio/bridge/tls_options.rb +19 -0
  170. data/lib/temporalio/bridge.rb +1 -1
  171. data/lib/temporalio/client/implementation.rb +8 -8
  172. data/lib/temporalio/connection/retry_config.rb +44 -0
  173. data/lib/temporalio/connection/service.rb +20 -0
  174. data/lib/temporalio/connection/test_service.rb +92 -0
  175. data/lib/temporalio/connection/tls_options.rb +51 -0
  176. data/lib/temporalio/connection/workflow_service.rb +731 -0
  177. data/lib/temporalio/connection.rb +55 -720
  178. data/lib/temporalio/interceptor/activity_inbound.rb +22 -0
  179. data/lib/temporalio/interceptor/activity_outbound.rb +24 -0
  180. data/lib/temporalio/interceptor/chain.rb +5 -5
  181. data/lib/temporalio/interceptor/client.rb +8 -4
  182. data/lib/temporalio/interceptor.rb +22 -0
  183. data/lib/temporalio/retry_policy.rb +13 -3
  184. data/lib/temporalio/testing/time_skipping_handle.rb +32 -0
  185. data/lib/temporalio/testing/time_skipping_interceptor.rb +23 -0
  186. data/lib/temporalio/testing/workflow_environment.rb +112 -0
  187. data/lib/temporalio/testing.rb +175 -0
  188. data/lib/temporalio/version.rb +1 -1
  189. data/lib/temporalio/worker/activity_runner.rb +26 -4
  190. data/lib/temporalio/worker/activity_worker.rb +44 -18
  191. data/lib/temporalio/worker/sync_worker.rb +47 -11
  192. data/lib/temporalio/worker.rb +27 -21
  193. data/lib/temporalio/workflow/async.rb +46 -0
  194. data/lib/temporalio/workflow/future.rb +138 -0
  195. data/lib/temporalio/workflow/info.rb +76 -0
  196. data/lib/thermite_patch.rb +10 -0
  197. data/sig/async.rbs +17 -0
  198. data/sig/protobuf.rbs +16 -0
  199. data/sig/protos/dependencies/gogoproto/gogo.rbs +914 -0
  200. data/sig/protos/google/protobuf/any.rbs +157 -0
  201. data/sig/protos/google/protobuf/descriptor.rbs +2825 -0
  202. data/sig/protos/google/protobuf/duration.rbs +114 -0
  203. data/sig/protos/google/protobuf/empty.rbs +36 -0
  204. data/sig/protos/google/protobuf/timestamp.rbs +145 -0
  205. data/sig/protos/google/protobuf/wrappers.rbs +358 -0
  206. data/sig/protos/temporal/api/batch/v1/message.rbs +300 -0
  207. data/sig/protos/temporal/api/command/v1/message.rbs +1399 -0
  208. data/sig/protos/temporal/api/common/v1/message.rbs +528 -0
  209. data/sig/protos/temporal/api/enums/v1/batch_operation.rbs +79 -0
  210. data/sig/protos/temporal/api/enums/v1/command_type.rbs +68 -0
  211. data/sig/protos/temporal/api/enums/v1/common.rbs +118 -0
  212. data/sig/protos/temporal/api/enums/v1/event_type.rbs +264 -0
  213. data/sig/protos/temporal/api/enums/v1/failed_cause.rbs +277 -0
  214. data/sig/protos/temporal/api/enums/v1/namespace.rbs +108 -0
  215. data/sig/protos/temporal/api/enums/v1/query.rbs +81 -0
  216. data/sig/protos/temporal/api/enums/v1/reset.rbs +44 -0
  217. data/sig/protos/temporal/api/enums/v1/schedule.rbs +72 -0
  218. data/sig/protos/temporal/api/enums/v1/task_queue.rbs +92 -0
  219. data/sig/protos/temporal/api/enums/v1/update.rbs +64 -0
  220. data/sig/protos/temporal/api/enums/v1/workflow.rbs +371 -0
  221. data/sig/protos/temporal/api/errordetails/v1/message.rbs +551 -0
  222. data/sig/protos/temporal/api/failure/v1/message.rbs +581 -0
  223. data/sig/protos/temporal/api/filter/v1/message.rbs +171 -0
  224. data/sig/protos/temporal/api/history/v1/message.rbs +4609 -0
  225. data/sig/protos/temporal/api/namespace/v1/message.rbs +410 -0
  226. data/sig/protos/temporal/api/operatorservice/v1/request_response.rbs +643 -0
  227. data/sig/protos/temporal/api/operatorservice/v1/service.rbs +17 -0
  228. data/sig/protos/temporal/api/protocol/v1/message.rbs +84 -0
  229. data/sig/protos/temporal/api/query/v1/message.rbs +182 -0
  230. data/sig/protos/temporal/api/replication/v1/message.rbs +148 -0
  231. data/sig/protos/temporal/api/schedule/v1/message.rbs +1488 -0
  232. data/sig/protos/temporal/api/sdk/v1/task_complete_metadata.rbs +110 -0
  233. data/sig/protos/temporal/api/taskqueue/v1/message.rbs +486 -0
  234. data/sig/protos/temporal/api/testservice/v1/request_response.rbs +249 -0
  235. data/sig/protos/temporal/api/testservice/v1/service.rbs +15 -0
  236. data/sig/protos/temporal/api/update/v1/message.rbs +489 -0
  237. data/sig/protos/temporal/api/version/v1/message.rbs +184 -0
  238. data/sig/protos/temporal/api/workflow/v1/message.rbs +824 -0
  239. data/sig/protos/temporal/api/workflowservice/v1/request_response.rbs +7250 -0
  240. data/sig/protos/temporal/api/workflowservice/v1/service.rbs +22 -0
  241. data/sig/protos/temporal/sdk/core/activity_result/activity_result.rbs +380 -0
  242. data/sig/protos/temporal/sdk/core/activity_task/activity_task.rbs +386 -0
  243. data/sig/protos/temporal/sdk/core/child_workflow/child_workflow.rbs +323 -0
  244. data/sig/protos/temporal/sdk/core/common/common.rbs +62 -0
  245. data/sig/protos/temporal/sdk/core/core_interface.rbs +101 -0
  246. data/sig/protos/temporal/sdk/core/external_data/external_data.rbs +119 -0
  247. data/sig/protos/temporal/sdk/core/workflow_activation/workflow_activation.rbs +1473 -0
  248. data/sig/protos/temporal/sdk/core/workflow_commands/workflow_commands.rbs +1784 -0
  249. data/sig/protos/temporal/sdk/core/workflow_completion/workflow_completion.rbs +180 -0
  250. data/sig/ruby.rbs +12 -0
  251. data/sig/temporalio/activity/context.rbs +29 -0
  252. data/sig/temporalio/activity/info.rbs +43 -0
  253. data/sig/temporalio/activity.rbs +19 -0
  254. data/sig/temporalio/bridge/connect_options.rbs +19 -0
  255. data/sig/temporalio/bridge/error.rbs +8 -0
  256. data/sig/temporalio/bridge/retry_config.rbs +21 -0
  257. data/sig/temporalio/bridge/tls_options.rbs +17 -0
  258. data/sig/temporalio/bridge.rbs +71 -0
  259. data/sig/temporalio/client/implementation.rbs +38 -0
  260. data/sig/temporalio/client/workflow_handle.rbs +41 -0
  261. data/sig/temporalio/client.rbs +35 -0
  262. data/sig/temporalio/connection/retry_config.rbs +37 -0
  263. data/sig/temporalio/connection/service.rbs +14 -0
  264. data/sig/temporalio/connection/test_service.rbs +13 -0
  265. data/sig/temporalio/connection/tls_options.rbs +43 -0
  266. data/sig/temporalio/connection/workflow_service.rbs +48 -0
  267. data/sig/temporalio/connection.rbs +30 -0
  268. data/sig/temporalio/data_converter.rbs +35 -0
  269. data/sig/temporalio/error/failure.rbs +121 -0
  270. data/sig/temporalio/error/workflow_failure.rbs +9 -0
  271. data/sig/temporalio/errors.rbs +36 -0
  272. data/sig/temporalio/failure_converter/base.rbs +12 -0
  273. data/sig/temporalio/failure_converter/basic.rbs +86 -0
  274. data/sig/temporalio/failure_converter.rbs +5 -0
  275. data/sig/temporalio/interceptor/activity_inbound.rbs +21 -0
  276. data/sig/temporalio/interceptor/activity_outbound.rbs +10 -0
  277. data/sig/temporalio/interceptor/chain.rbs +24 -0
  278. data/sig/temporalio/interceptor/client.rbs +148 -0
  279. data/sig/temporalio/interceptor.rbs +6 -0
  280. data/sig/temporalio/payload_codec/base.rbs +12 -0
  281. data/sig/temporalio/payload_converter/base.rbs +12 -0
  282. data/sig/temporalio/payload_converter/bytes.rbs +9 -0
  283. data/sig/temporalio/payload_converter/composite.rbs +19 -0
  284. data/sig/temporalio/payload_converter/encoding_base.rbs +14 -0
  285. data/sig/temporalio/payload_converter/json.rbs +9 -0
  286. data/sig/temporalio/payload_converter/nil.rbs +9 -0
  287. data/sig/temporalio/payload_converter.rbs +5 -0
  288. data/sig/temporalio/retry_policy.rbs +25 -0
  289. data/sig/temporalio/retry_state.rbs +20 -0
  290. data/sig/temporalio/runtime.rbs +12 -0
  291. data/sig/temporalio/testing/time_skipping_handle.rbs +15 -0
  292. data/sig/temporalio/testing/time_skipping_interceptor.rbs +13 -0
  293. data/sig/temporalio/testing/workflow_environment.rbs +22 -0
  294. data/sig/temporalio/testing.rbs +35 -0
  295. data/sig/temporalio/timeout_type.rbs +15 -0
  296. data/sig/temporalio/version.rbs +3 -0
  297. data/sig/temporalio/worker/activity_runner.rbs +35 -0
  298. data/sig/temporalio/worker/activity_worker.rbs +44 -0
  299. data/sig/temporalio/worker/reactor.rbs +22 -0
  300. data/sig/temporalio/worker/runner.rbs +21 -0
  301. data/sig/temporalio/worker/sync_worker.rbs +23 -0
  302. data/sig/temporalio/worker/thread_pool_executor.rbs +23 -0
  303. data/sig/temporalio/worker.rbs +46 -0
  304. data/sig/temporalio/workflow/async.rbs +9 -0
  305. data/sig/temporalio/workflow/execution_info.rbs +55 -0
  306. data/sig/temporalio/workflow/execution_status.rbs +21 -0
  307. data/sig/temporalio/workflow/future.rbs +40 -0
  308. data/sig/temporalio/workflow/id_reuse_policy.rbs +15 -0
  309. data/sig/temporalio/workflow/info.rbs +55 -0
  310. data/sig/temporalio/workflow/query_reject_condition.rbs +14 -0
  311. data/sig/temporalio.rbs +2 -0
  312. data/sig/thermite_patch.rbs +15 -0
  313. data/temporalio.gemspec +6 -4
  314. metadata +183 -17
  315. data/bridge/sdk-core/Cargo.lock +0 -2606
  316. data/bridge/sdk-core/protos/api_upstream/temporal/api/interaction/v1/message.proto +0 -87
  317. data/lib/bridge.so +0 -0
  318. data/lib/gen/temporal/api/enums/v1/interaction_type_pb.rb +0 -25
  319. data/lib/gen/temporal/api/interaction/v1/message_pb.rb +0 -49
  320. data/lib/gen/temporal/sdk/core/bridge/bridge_pb.rb +0 -222
@@ -0,0 +1,581 @@
1
+ module Temporalio
2
+ module Api
3
+ module Failure
4
+ module V1
5
+ class ApplicationFailureInfo < ::Protobuf::Message
6
+ # Encode the message to a binary string
7
+ #
8
+ def self.encode: (ApplicationFailureInfo) -> String
9
+
10
+ attr_accessor type(): ::String
11
+
12
+ def type!: () -> ::String?
13
+
14
+ attr_accessor non_retryable(): bool
15
+
16
+ def non_retryable!: () -> bool?
17
+
18
+ attr_accessor details(): ::Temporalio::Api::Common::V1::Payloads?
19
+
20
+ def details=: [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (M?) -> M?
21
+ | ...
22
+
23
+ def details!: () -> ::Temporalio::Api::Common::V1::Payloads?
24
+
25
+ def initialize: (?type: ::String, ?non_retryable: bool, ?details: ::Temporalio::Api::Common::V1::Payloads::init?) -> void
26
+
27
+ def []: (:type) -> ::String
28
+ | (:non_retryable) -> bool
29
+ | (:details) -> ::Temporalio::Api::Common::V1::Payloads?
30
+ | (::Symbol) -> untyped
31
+
32
+ def []=: (:type, ::String) -> ::String
33
+ | (:non_retryable, bool) -> bool
34
+ | (:details, ::Temporalio::Api::Common::V1::Payloads?) -> ::Temporalio::Api::Common::V1::Payloads?
35
+ | [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (:details, M?) -> M?
36
+ | (::Symbol, untyped) -> untyped
37
+
38
+ def non_retryable?: () -> bool
39
+
40
+ interface _ToProto
41
+ def to_proto: () -> ApplicationFailureInfo
42
+ end
43
+
44
+ # The type of `#initialize` parameter.
45
+ type init = ApplicationFailureInfo | _ToProto
46
+
47
+ # The type of `repeated` field.
48
+ type field_array = ::Protobuf::Field::FieldArray[ApplicationFailureInfo, ApplicationFailureInfo | _ToProto]
49
+
50
+ # The type of `map` field.
51
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, ApplicationFailureInfo, ApplicationFailureInfo | _ToProto]
52
+
53
+ type array = ::Array[ApplicationFailureInfo | _ToProto]
54
+
55
+ type hash[KEY] = ::Hash[KEY, ApplicationFailureInfo | _ToProto]
56
+ end
57
+
58
+ class TimeoutFailureInfo < ::Protobuf::Message
59
+ # Encode the message to a binary string
60
+ #
61
+ def self.encode: (TimeoutFailureInfo) -> String
62
+
63
+ attr_accessor timeout_type(): ::Temporalio::Api::Enums::V1::TimeoutType
64
+
65
+ def timeout_type=: (::Temporalio::Api::Enums::V1::TimeoutType::values) -> ::Temporalio::Api::Enums::V1::TimeoutType::values
66
+ | ...
67
+
68
+ def timeout_type!: () -> ::Temporalio::Api::Enums::V1::TimeoutType?
69
+
70
+ attr_accessor last_heartbeat_details(): ::Temporalio::Api::Common::V1::Payloads?
71
+
72
+ def last_heartbeat_details=: [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (M?) -> M?
73
+ | ...
74
+
75
+ def last_heartbeat_details!: () -> ::Temporalio::Api::Common::V1::Payloads?
76
+
77
+ def initialize: (?timeout_type: ::Temporalio::Api::Enums::V1::TimeoutType::init, ?last_heartbeat_details: ::Temporalio::Api::Common::V1::Payloads::init?) -> void
78
+
79
+ def []: (:timeout_type) -> ::Temporalio::Api::Enums::V1::TimeoutType
80
+ | (:last_heartbeat_details) -> ::Temporalio::Api::Common::V1::Payloads?
81
+ | (::Symbol) -> untyped
82
+
83
+ def []=: (:timeout_type, ::Temporalio::Api::Enums::V1::TimeoutType) -> ::Temporalio::Api::Enums::V1::TimeoutType
84
+ | (:timeout_type, ::Temporalio::Api::Enums::V1::TimeoutType::values) -> ::Temporalio::Api::Enums::V1::TimeoutType::values
85
+ | (:last_heartbeat_details, ::Temporalio::Api::Common::V1::Payloads?) -> ::Temporalio::Api::Common::V1::Payloads?
86
+ | [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (:last_heartbeat_details, M?) -> M?
87
+ | (::Symbol, untyped) -> untyped
88
+
89
+ interface _ToProto
90
+ def to_proto: () -> TimeoutFailureInfo
91
+ end
92
+
93
+ # The type of `#initialize` parameter.
94
+ type init = TimeoutFailureInfo | _ToProto
95
+
96
+ # The type of `repeated` field.
97
+ type field_array = ::Protobuf::Field::FieldArray[TimeoutFailureInfo, TimeoutFailureInfo | _ToProto]
98
+
99
+ # The type of `map` field.
100
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, TimeoutFailureInfo, TimeoutFailureInfo | _ToProto]
101
+
102
+ type array = ::Array[TimeoutFailureInfo | _ToProto]
103
+
104
+ type hash[KEY] = ::Hash[KEY, TimeoutFailureInfo | _ToProto]
105
+ end
106
+
107
+ class CanceledFailureInfo < ::Protobuf::Message
108
+ # Encode the message to a binary string
109
+ #
110
+ def self.encode: (CanceledFailureInfo) -> String
111
+
112
+ attr_accessor details(): ::Temporalio::Api::Common::V1::Payloads?
113
+
114
+ def details=: [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (M?) -> M?
115
+ | ...
116
+
117
+ def details!: () -> ::Temporalio::Api::Common::V1::Payloads?
118
+
119
+ def initialize: (?details: ::Temporalio::Api::Common::V1::Payloads::init?) -> void
120
+
121
+ def []: (:details) -> ::Temporalio::Api::Common::V1::Payloads?
122
+ | (::Symbol) -> untyped
123
+
124
+ def []=: (:details, ::Temporalio::Api::Common::V1::Payloads?) -> ::Temporalio::Api::Common::V1::Payloads?
125
+ | [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (:details, M?) -> M?
126
+ | (::Symbol, untyped) -> untyped
127
+
128
+ interface _ToProto
129
+ def to_proto: () -> CanceledFailureInfo
130
+ end
131
+
132
+ # The type of `#initialize` parameter.
133
+ type init = CanceledFailureInfo | _ToProto
134
+
135
+ # The type of `repeated` field.
136
+ type field_array = ::Protobuf::Field::FieldArray[CanceledFailureInfo, CanceledFailureInfo | _ToProto]
137
+
138
+ # The type of `map` field.
139
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, CanceledFailureInfo, CanceledFailureInfo | _ToProto]
140
+
141
+ type array = ::Array[CanceledFailureInfo | _ToProto]
142
+
143
+ type hash[KEY] = ::Hash[KEY, CanceledFailureInfo | _ToProto]
144
+ end
145
+
146
+ class TerminatedFailureInfo < ::Protobuf::Message
147
+ # Encode the message to a binary string
148
+ #
149
+ def self.encode: (TerminatedFailureInfo) -> String
150
+
151
+ def initialize: () -> void
152
+
153
+ interface _ToProto
154
+ def to_proto: () -> TerminatedFailureInfo
155
+ end
156
+
157
+ # The type of `#initialize` parameter.
158
+ type init = TerminatedFailureInfo | _ToProto
159
+
160
+ # The type of `repeated` field.
161
+ type field_array = ::Protobuf::Field::FieldArray[TerminatedFailureInfo, TerminatedFailureInfo | _ToProto]
162
+
163
+ # The type of `map` field.
164
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, TerminatedFailureInfo, TerminatedFailureInfo | _ToProto]
165
+
166
+ type array = ::Array[TerminatedFailureInfo | _ToProto]
167
+
168
+ type hash[KEY] = ::Hash[KEY, TerminatedFailureInfo | _ToProto]
169
+ end
170
+
171
+ class ServerFailureInfo < ::Protobuf::Message
172
+ # Encode the message to a binary string
173
+ #
174
+ def self.encode: (ServerFailureInfo) -> String
175
+
176
+ attr_accessor non_retryable(): bool
177
+
178
+ def non_retryable!: () -> bool?
179
+
180
+ def initialize: (?non_retryable: bool) -> void
181
+
182
+ def []: (:non_retryable) -> bool
183
+ | (::Symbol) -> untyped
184
+
185
+ def []=: (:non_retryable, bool) -> bool
186
+ | (::Symbol, untyped) -> untyped
187
+
188
+ def non_retryable?: () -> bool
189
+
190
+ interface _ToProto
191
+ def to_proto: () -> ServerFailureInfo
192
+ end
193
+
194
+ # The type of `#initialize` parameter.
195
+ type init = ServerFailureInfo | _ToProto
196
+
197
+ # The type of `repeated` field.
198
+ type field_array = ::Protobuf::Field::FieldArray[ServerFailureInfo, ServerFailureInfo | _ToProto]
199
+
200
+ # The type of `map` field.
201
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, ServerFailureInfo, ServerFailureInfo | _ToProto]
202
+
203
+ type array = ::Array[ServerFailureInfo | _ToProto]
204
+
205
+ type hash[KEY] = ::Hash[KEY, ServerFailureInfo | _ToProto]
206
+ end
207
+
208
+ class ResetWorkflowFailureInfo < ::Protobuf::Message
209
+ # Encode the message to a binary string
210
+ #
211
+ def self.encode: (ResetWorkflowFailureInfo) -> String
212
+
213
+ attr_accessor last_heartbeat_details(): ::Temporalio::Api::Common::V1::Payloads?
214
+
215
+ def last_heartbeat_details=: [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (M?) -> M?
216
+ | ...
217
+
218
+ def last_heartbeat_details!: () -> ::Temporalio::Api::Common::V1::Payloads?
219
+
220
+ def initialize: (?last_heartbeat_details: ::Temporalio::Api::Common::V1::Payloads::init?) -> void
221
+
222
+ def []: (:last_heartbeat_details) -> ::Temporalio::Api::Common::V1::Payloads?
223
+ | (::Symbol) -> untyped
224
+
225
+ def []=: (:last_heartbeat_details, ::Temporalio::Api::Common::V1::Payloads?) -> ::Temporalio::Api::Common::V1::Payloads?
226
+ | [M < ::Temporalio::Api::Common::V1::Payloads::_ToProto] (:last_heartbeat_details, M?) -> M?
227
+ | (::Symbol, untyped) -> untyped
228
+
229
+ interface _ToProto
230
+ def to_proto: () -> ResetWorkflowFailureInfo
231
+ end
232
+
233
+ # The type of `#initialize` parameter.
234
+ type init = ResetWorkflowFailureInfo | _ToProto
235
+
236
+ # The type of `repeated` field.
237
+ type field_array = ::Protobuf::Field::FieldArray[ResetWorkflowFailureInfo, ResetWorkflowFailureInfo | _ToProto]
238
+
239
+ # The type of `map` field.
240
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, ResetWorkflowFailureInfo, ResetWorkflowFailureInfo | _ToProto]
241
+
242
+ type array = ::Array[ResetWorkflowFailureInfo | _ToProto]
243
+
244
+ type hash[KEY] = ::Hash[KEY, ResetWorkflowFailureInfo | _ToProto]
245
+ end
246
+
247
+ class ActivityFailureInfo < ::Protobuf::Message
248
+ # Encode the message to a binary string
249
+ #
250
+ def self.encode: (ActivityFailureInfo) -> String
251
+
252
+ attr_accessor scheduled_event_id(): ::Integer
253
+
254
+ def scheduled_event_id!: () -> ::Integer?
255
+
256
+ attr_accessor started_event_id(): ::Integer
257
+
258
+ def started_event_id!: () -> ::Integer?
259
+
260
+ attr_accessor identity(): ::String
261
+
262
+ def identity!: () -> ::String?
263
+
264
+ attr_accessor activity_type(): ::Temporalio::Api::Common::V1::ActivityType?
265
+
266
+ def activity_type=: [M < ::Temporalio::Api::Common::V1::ActivityType::_ToProto] (M?) -> M?
267
+ | ...
268
+
269
+ def activity_type!: () -> ::Temporalio::Api::Common::V1::ActivityType?
270
+
271
+ attr_accessor activity_id(): ::String
272
+
273
+ def activity_id!: () -> ::String?
274
+
275
+ attr_accessor retry_state(): ::Temporalio::Api::Enums::V1::RetryState
276
+
277
+ def retry_state=: (::Temporalio::Api::Enums::V1::RetryState::values) -> ::Temporalio::Api::Enums::V1::RetryState::values
278
+ | ...
279
+
280
+ def retry_state!: () -> ::Temporalio::Api::Enums::V1::RetryState?
281
+
282
+ def initialize: (?scheduled_event_id: ::Integer, ?started_event_id: ::Integer, ?identity: ::String, ?activity_type: ::Temporalio::Api::Common::V1::ActivityType::init?, ?activity_id: ::String, ?retry_state: ::Temporalio::Api::Enums::V1::RetryState::init) -> void
283
+
284
+ def []: (:scheduled_event_id) -> ::Integer
285
+ | (:started_event_id) -> ::Integer
286
+ | (:identity) -> ::String
287
+ | (:activity_type) -> ::Temporalio::Api::Common::V1::ActivityType?
288
+ | (:activity_id) -> ::String
289
+ | (:retry_state) -> ::Temporalio::Api::Enums::V1::RetryState
290
+ | (::Symbol) -> untyped
291
+
292
+ def []=: (:scheduled_event_id, ::Integer) -> ::Integer
293
+ | (:started_event_id, ::Integer) -> ::Integer
294
+ | (:identity, ::String) -> ::String
295
+ | (:activity_type, ::Temporalio::Api::Common::V1::ActivityType?) -> ::Temporalio::Api::Common::V1::ActivityType?
296
+ | [M < ::Temporalio::Api::Common::V1::ActivityType::_ToProto] (:activity_type, M?) -> M?
297
+ | (:activity_id, ::String) -> ::String
298
+ | (:retry_state, ::Temporalio::Api::Enums::V1::RetryState) -> ::Temporalio::Api::Enums::V1::RetryState
299
+ | (:retry_state, ::Temporalio::Api::Enums::V1::RetryState::values) -> ::Temporalio::Api::Enums::V1::RetryState::values
300
+ | (::Symbol, untyped) -> untyped
301
+
302
+ interface _ToProto
303
+ def to_proto: () -> ActivityFailureInfo
304
+ end
305
+
306
+ # The type of `#initialize` parameter.
307
+ type init = ActivityFailureInfo | _ToProto
308
+
309
+ # The type of `repeated` field.
310
+ type field_array = ::Protobuf::Field::FieldArray[ActivityFailureInfo, ActivityFailureInfo | _ToProto]
311
+
312
+ # The type of `map` field.
313
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, ActivityFailureInfo, ActivityFailureInfo | _ToProto]
314
+
315
+ type array = ::Array[ActivityFailureInfo | _ToProto]
316
+
317
+ type hash[KEY] = ::Hash[KEY, ActivityFailureInfo | _ToProto]
318
+ end
319
+
320
+ class ChildWorkflowExecutionFailureInfo < ::Protobuf::Message
321
+ # Encode the message to a binary string
322
+ #
323
+ def self.encode: (ChildWorkflowExecutionFailureInfo) -> String
324
+
325
+ attr_accessor namespace(): ::String
326
+
327
+ def namespace!: () -> ::String?
328
+
329
+ attr_accessor workflow_execution(): ::Temporalio::Api::Common::V1::WorkflowExecution?
330
+
331
+ def workflow_execution=: [M < ::Temporalio::Api::Common::V1::WorkflowExecution::_ToProto] (M?) -> M?
332
+ | ...
333
+
334
+ def workflow_execution!: () -> ::Temporalio::Api::Common::V1::WorkflowExecution?
335
+
336
+ attr_accessor workflow_type(): ::Temporalio::Api::Common::V1::WorkflowType?
337
+
338
+ def workflow_type=: [M < ::Temporalio::Api::Common::V1::WorkflowType::_ToProto] (M?) -> M?
339
+ | ...
340
+
341
+ def workflow_type!: () -> ::Temporalio::Api::Common::V1::WorkflowType?
342
+
343
+ attr_accessor initiated_event_id(): ::Integer
344
+
345
+ def initiated_event_id!: () -> ::Integer?
346
+
347
+ attr_accessor started_event_id(): ::Integer
348
+
349
+ def started_event_id!: () -> ::Integer?
350
+
351
+ attr_accessor retry_state(): ::Temporalio::Api::Enums::V1::RetryState
352
+
353
+ def retry_state=: (::Temporalio::Api::Enums::V1::RetryState::values) -> ::Temporalio::Api::Enums::V1::RetryState::values
354
+ | ...
355
+
356
+ def retry_state!: () -> ::Temporalio::Api::Enums::V1::RetryState?
357
+
358
+ def initialize: (?namespace: ::String, ?workflow_execution: ::Temporalio::Api::Common::V1::WorkflowExecution::init?, ?workflow_type: ::Temporalio::Api::Common::V1::WorkflowType::init?, ?initiated_event_id: ::Integer, ?started_event_id: ::Integer, ?retry_state: ::Temporalio::Api::Enums::V1::RetryState::init) -> void
359
+
360
+ def []: (:namespace) -> ::String
361
+ | (:workflow_execution) -> ::Temporalio::Api::Common::V1::WorkflowExecution?
362
+ | (:workflow_type) -> ::Temporalio::Api::Common::V1::WorkflowType?
363
+ | (:initiated_event_id) -> ::Integer
364
+ | (:started_event_id) -> ::Integer
365
+ | (:retry_state) -> ::Temporalio::Api::Enums::V1::RetryState
366
+ | (::Symbol) -> untyped
367
+
368
+ def []=: (:namespace, ::String) -> ::String
369
+ | (:workflow_execution, ::Temporalio::Api::Common::V1::WorkflowExecution?) -> ::Temporalio::Api::Common::V1::WorkflowExecution?
370
+ | [M < ::Temporalio::Api::Common::V1::WorkflowExecution::_ToProto] (:workflow_execution, M?) -> M?
371
+ | (:workflow_type, ::Temporalio::Api::Common::V1::WorkflowType?) -> ::Temporalio::Api::Common::V1::WorkflowType?
372
+ | [M < ::Temporalio::Api::Common::V1::WorkflowType::_ToProto] (:workflow_type, M?) -> M?
373
+ | (:initiated_event_id, ::Integer) -> ::Integer
374
+ | (:started_event_id, ::Integer) -> ::Integer
375
+ | (:retry_state, ::Temporalio::Api::Enums::V1::RetryState) -> ::Temporalio::Api::Enums::V1::RetryState
376
+ | (:retry_state, ::Temporalio::Api::Enums::V1::RetryState::values) -> ::Temporalio::Api::Enums::V1::RetryState::values
377
+ | (::Symbol, untyped) -> untyped
378
+
379
+ interface _ToProto
380
+ def to_proto: () -> ChildWorkflowExecutionFailureInfo
381
+ end
382
+
383
+ # The type of `#initialize` parameter.
384
+ type init = ChildWorkflowExecutionFailureInfo | _ToProto
385
+
386
+ # The type of `repeated` field.
387
+ type field_array = ::Protobuf::Field::FieldArray[ChildWorkflowExecutionFailureInfo, ChildWorkflowExecutionFailureInfo | _ToProto]
388
+
389
+ # The type of `map` field.
390
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, ChildWorkflowExecutionFailureInfo, ChildWorkflowExecutionFailureInfo | _ToProto]
391
+
392
+ type array = ::Array[ChildWorkflowExecutionFailureInfo | _ToProto]
393
+
394
+ type hash[KEY] = ::Hash[KEY, ChildWorkflowExecutionFailureInfo | _ToProto]
395
+ end
396
+
397
+ class Failure < ::Protobuf::Message
398
+ # Encode the message to a binary string
399
+ #
400
+ def self.encode: (Failure) -> String
401
+
402
+ attr_accessor message(): ::String
403
+
404
+ def message!: () -> ::String?
405
+
406
+ # The source this Failure originated in, e.g. TypeScriptSDK / JavaSDK
407
+ # In some SDKs this is used to rehydrate the stack trace into an exception object.
408
+ #
409
+ attr_accessor source(): ::String
410
+
411
+ def source!: () -> ::String?
412
+
413
+ attr_accessor stack_trace(): ::String
414
+
415
+ def stack_trace!: () -> ::String?
416
+
417
+ # Alternative way to supply `message` and `stack_trace` and possibly other attributes, used for encryption of
418
+ # errors originating in user code which might contain sensitive information.
419
+ # The `encoded_attributes` Payload could represent any serializable object, e.g. JSON object or a `Failure` proto
420
+ # message.
421
+ #
422
+ # SDK authors:
423
+ # - The SDK should provide a default `encodeFailureAttributes` and `decodeFailureAttributes` implementation that:
424
+ # - Uses a JSON object to represent `{ message, stack_trace }`.
425
+ # - Overwrites the original message with "Encoded failure" to indicate that more information could be extracted.
426
+ # - Overwrites the original stack_trace with an empty string.
427
+ # - The resulting JSON object is converted to Payload using the default PayloadConverter and should be processed
428
+ # by the user-provided PayloadCodec
429
+ #
430
+ # - If there's demand, we could allow overriding the default SDK implementation to encode other opaque Failure attributes.
431
+ # (-- api-linter: core::0203::optional=disabled --)
432
+ #
433
+ attr_accessor encoded_attributes(): ::Temporalio::Api::Common::V1::Payload?
434
+
435
+ # Alternative way to supply `message` and `stack_trace` and possibly other attributes, used for encryption of
436
+ # errors originating in user code which might contain sensitive information.
437
+ # The `encoded_attributes` Payload could represent any serializable object, e.g. JSON object or a `Failure` proto
438
+ # message.
439
+ #
440
+ # SDK authors:
441
+ # - The SDK should provide a default `encodeFailureAttributes` and `decodeFailureAttributes` implementation that:
442
+ # - Uses a JSON object to represent `{ message, stack_trace }`.
443
+ # - Overwrites the original message with "Encoded failure" to indicate that more information could be extracted.
444
+ # - Overwrites the original stack_trace with an empty string.
445
+ # - The resulting JSON object is converted to Payload using the default PayloadConverter and should be processed
446
+ # by the user-provided PayloadCodec
447
+ #
448
+ # - If there's demand, we could allow overriding the default SDK implementation to encode other opaque Failure attributes.
449
+ # (-- api-linter: core::0203::optional=disabled --)
450
+ #
451
+ def encoded_attributes=: [M < ::Temporalio::Api::Common::V1::Payload::_ToProto] (M?) -> M?
452
+ | ...
453
+
454
+ def encoded_attributes!: () -> ::Temporalio::Api::Common::V1::Payload?
455
+
456
+ attr_accessor cause(): ::Temporalio::Api::Failure::V1::Failure?
457
+
458
+ def cause=: [M < ::Temporalio::Api::Failure::V1::Failure::_ToProto] (M?) -> M?
459
+ | ...
460
+
461
+ def cause!: () -> ::Temporalio::Api::Failure::V1::Failure?
462
+
463
+ attr_accessor application_failure_info(): ::Temporalio::Api::Failure::V1::ApplicationFailureInfo?
464
+
465
+ def application_failure_info=: [M < ::Temporalio::Api::Failure::V1::ApplicationFailureInfo::_ToProto] (M?) -> M?
466
+ | ...
467
+
468
+ def application_failure_info!: () -> ::Temporalio::Api::Failure::V1::ApplicationFailureInfo?
469
+
470
+ attr_accessor timeout_failure_info(): ::Temporalio::Api::Failure::V1::TimeoutFailureInfo?
471
+
472
+ def timeout_failure_info=: [M < ::Temporalio::Api::Failure::V1::TimeoutFailureInfo::_ToProto] (M?) -> M?
473
+ | ...
474
+
475
+ def timeout_failure_info!: () -> ::Temporalio::Api::Failure::V1::TimeoutFailureInfo?
476
+
477
+ attr_accessor canceled_failure_info(): ::Temporalio::Api::Failure::V1::CanceledFailureInfo?
478
+
479
+ def canceled_failure_info=: [M < ::Temporalio::Api::Failure::V1::CanceledFailureInfo::_ToProto] (M?) -> M?
480
+ | ...
481
+
482
+ def canceled_failure_info!: () -> ::Temporalio::Api::Failure::V1::CanceledFailureInfo?
483
+
484
+ attr_accessor terminated_failure_info(): ::Temporalio::Api::Failure::V1::TerminatedFailureInfo?
485
+
486
+ def terminated_failure_info=: [M < ::Temporalio::Api::Failure::V1::TerminatedFailureInfo::_ToProto] (M?) -> M?
487
+ | ...
488
+
489
+ def terminated_failure_info!: () -> ::Temporalio::Api::Failure::V1::TerminatedFailureInfo?
490
+
491
+ attr_accessor server_failure_info(): ::Temporalio::Api::Failure::V1::ServerFailureInfo?
492
+
493
+ def server_failure_info=: [M < ::Temporalio::Api::Failure::V1::ServerFailureInfo::_ToProto] (M?) -> M?
494
+ | ...
495
+
496
+ def server_failure_info!: () -> ::Temporalio::Api::Failure::V1::ServerFailureInfo?
497
+
498
+ attr_accessor reset_workflow_failure_info(): ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo?
499
+
500
+ def reset_workflow_failure_info=: [M < ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo::_ToProto] (M?) -> M?
501
+ | ...
502
+
503
+ def reset_workflow_failure_info!: () -> ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo?
504
+
505
+ attr_accessor activity_failure_info(): ::Temporalio::Api::Failure::V1::ActivityFailureInfo?
506
+
507
+ def activity_failure_info=: [M < ::Temporalio::Api::Failure::V1::ActivityFailureInfo::_ToProto] (M?) -> M?
508
+ | ...
509
+
510
+ def activity_failure_info!: () -> ::Temporalio::Api::Failure::V1::ActivityFailureInfo?
511
+
512
+ attr_accessor child_workflow_execution_failure_info(): ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo?
513
+
514
+ def child_workflow_execution_failure_info=: [M < ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo::_ToProto] (M?) -> M?
515
+ | ...
516
+
517
+ def child_workflow_execution_failure_info!: () -> ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo?
518
+
519
+ def initialize: (?message: ::String, ?source: ::String, ?stack_trace: ::String, ?encoded_attributes: ::Temporalio::Api::Common::V1::Payload::init?, ?cause: ::Temporalio::Api::Failure::V1::Failure::init?, ?application_failure_info: ::Temporalio::Api::Failure::V1::ApplicationFailureInfo::init?, ?timeout_failure_info: ::Temporalio::Api::Failure::V1::TimeoutFailureInfo::init?, ?canceled_failure_info: ::Temporalio::Api::Failure::V1::CanceledFailureInfo::init?, ?terminated_failure_info: ::Temporalio::Api::Failure::V1::TerminatedFailureInfo::init?, ?server_failure_info: ::Temporalio::Api::Failure::V1::ServerFailureInfo::init?, ?reset_workflow_failure_info: ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo::init?, ?activity_failure_info: ::Temporalio::Api::Failure::V1::ActivityFailureInfo::init?, ?child_workflow_execution_failure_info: ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo::init?) -> void
520
+
521
+ def []: (:message) -> ::String
522
+ | (:source) -> ::String
523
+ | (:stack_trace) -> ::String
524
+ | (:encoded_attributes) -> ::Temporalio::Api::Common::V1::Payload?
525
+ | (:cause) -> ::Temporalio::Api::Failure::V1::Failure?
526
+ | (:application_failure_info) -> ::Temporalio::Api::Failure::V1::ApplicationFailureInfo?
527
+ | (:timeout_failure_info) -> ::Temporalio::Api::Failure::V1::TimeoutFailureInfo?
528
+ | (:canceled_failure_info) -> ::Temporalio::Api::Failure::V1::CanceledFailureInfo?
529
+ | (:terminated_failure_info) -> ::Temporalio::Api::Failure::V1::TerminatedFailureInfo?
530
+ | (:server_failure_info) -> ::Temporalio::Api::Failure::V1::ServerFailureInfo?
531
+ | (:reset_workflow_failure_info) -> ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo?
532
+ | (:activity_failure_info) -> ::Temporalio::Api::Failure::V1::ActivityFailureInfo?
533
+ | (:child_workflow_execution_failure_info) -> ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo?
534
+ | (::Symbol) -> untyped
535
+
536
+ def []=: (:message, ::String) -> ::String
537
+ | (:source, ::String) -> ::String
538
+ | (:stack_trace, ::String) -> ::String
539
+ | (:encoded_attributes, ::Temporalio::Api::Common::V1::Payload?) -> ::Temporalio::Api::Common::V1::Payload?
540
+ | [M < ::Temporalio::Api::Common::V1::Payload::_ToProto] (:encoded_attributes, M?) -> M?
541
+ | (:cause, ::Temporalio::Api::Failure::V1::Failure?) -> ::Temporalio::Api::Failure::V1::Failure?
542
+ | [M < ::Temporalio::Api::Failure::V1::Failure::_ToProto] (:cause, M?) -> M?
543
+ | (:application_failure_info, ::Temporalio::Api::Failure::V1::ApplicationFailureInfo?) -> ::Temporalio::Api::Failure::V1::ApplicationFailureInfo?
544
+ | [M < ::Temporalio::Api::Failure::V1::ApplicationFailureInfo::_ToProto] (:application_failure_info, M?) -> M?
545
+ | (:timeout_failure_info, ::Temporalio::Api::Failure::V1::TimeoutFailureInfo?) -> ::Temporalio::Api::Failure::V1::TimeoutFailureInfo?
546
+ | [M < ::Temporalio::Api::Failure::V1::TimeoutFailureInfo::_ToProto] (:timeout_failure_info, M?) -> M?
547
+ | (:canceled_failure_info, ::Temporalio::Api::Failure::V1::CanceledFailureInfo?) -> ::Temporalio::Api::Failure::V1::CanceledFailureInfo?
548
+ | [M < ::Temporalio::Api::Failure::V1::CanceledFailureInfo::_ToProto] (:canceled_failure_info, M?) -> M?
549
+ | (:terminated_failure_info, ::Temporalio::Api::Failure::V1::TerminatedFailureInfo?) -> ::Temporalio::Api::Failure::V1::TerminatedFailureInfo?
550
+ | [M < ::Temporalio::Api::Failure::V1::TerminatedFailureInfo::_ToProto] (:terminated_failure_info, M?) -> M?
551
+ | (:server_failure_info, ::Temporalio::Api::Failure::V1::ServerFailureInfo?) -> ::Temporalio::Api::Failure::V1::ServerFailureInfo?
552
+ | [M < ::Temporalio::Api::Failure::V1::ServerFailureInfo::_ToProto] (:server_failure_info, M?) -> M?
553
+ | (:reset_workflow_failure_info, ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo?) -> ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo?
554
+ | [M < ::Temporalio::Api::Failure::V1::ResetWorkflowFailureInfo::_ToProto] (:reset_workflow_failure_info, M?) -> M?
555
+ | (:activity_failure_info, ::Temporalio::Api::Failure::V1::ActivityFailureInfo?) -> ::Temporalio::Api::Failure::V1::ActivityFailureInfo?
556
+ | [M < ::Temporalio::Api::Failure::V1::ActivityFailureInfo::_ToProto] (:activity_failure_info, M?) -> M?
557
+ | (:child_workflow_execution_failure_info, ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo?) -> ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo?
558
+ | [M < ::Temporalio::Api::Failure::V1::ChildWorkflowExecutionFailureInfo::_ToProto] (:child_workflow_execution_failure_info, M?) -> M?
559
+ | (::Symbol, untyped) -> untyped
560
+
561
+ interface _ToProto
562
+ def to_proto: () -> Failure
563
+ end
564
+
565
+ # The type of `#initialize` parameter.
566
+ type init = Failure | _ToProto
567
+
568
+ # The type of `repeated` field.
569
+ type field_array = ::Protobuf::Field::FieldArray[Failure, Failure | _ToProto]
570
+
571
+ # The type of `map` field.
572
+ type field_hash[KEY] = ::Protobuf::Field::FieldHash[KEY, Failure, Failure | _ToProto]
573
+
574
+ type array = ::Array[Failure | _ToProto]
575
+
576
+ type hash[KEY] = ::Hash[KEY, Failure | _ToProto]
577
+ end
578
+ end
579
+ end
580
+ end
581
+ end