clara-temporalio 0.4.3-x86_64-darwin

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 (190) hide show
  1. checksums.yaml +7 -0
  2. data/.yardopts +2 -0
  3. data/Gemfile +27 -0
  4. data/Rakefile +101 -0
  5. data/lib/temporalio/activity/cancellation_details.rb +58 -0
  6. data/lib/temporalio/activity/complete_async_error.rb +11 -0
  7. data/lib/temporalio/activity/context.rb +131 -0
  8. data/lib/temporalio/activity/definition.rb +197 -0
  9. data/lib/temporalio/activity/info.rb +70 -0
  10. data/lib/temporalio/activity.rb +14 -0
  11. data/lib/temporalio/api/activity/v1/message.rb +25 -0
  12. data/lib/temporalio/api/batch/v1/message.rb +38 -0
  13. data/lib/temporalio/api/cloud/account/v1/message.rb +28 -0
  14. data/lib/temporalio/api/cloud/cloudservice/v1/request_response.rb +135 -0
  15. data/lib/temporalio/api/cloud/cloudservice/v1/service.rb +25 -0
  16. data/lib/temporalio/api/cloud/cloudservice.rb +3 -0
  17. data/lib/temporalio/api/cloud/identity/v1/message.rb +46 -0
  18. data/lib/temporalio/api/cloud/namespace/v1/message.rb +46 -0
  19. data/lib/temporalio/api/cloud/nexus/v1/message.rb +32 -0
  20. data/lib/temporalio/api/cloud/operation/v1/message.rb +28 -0
  21. data/lib/temporalio/api/cloud/region/v1/message.rb +24 -0
  22. data/lib/temporalio/api/cloud/resource/v1/message.rb +23 -0
  23. data/lib/temporalio/api/cloud/sink/v1/message.rb +24 -0
  24. data/lib/temporalio/api/cloud/usage/v1/message.rb +31 -0
  25. data/lib/temporalio/api/command/v1/message.rb +46 -0
  26. data/lib/temporalio/api/common/v1/grpc_status.rb +23 -0
  27. data/lib/temporalio/api/common/v1/message.rb +49 -0
  28. data/lib/temporalio/api/deployment/v1/message.rb +39 -0
  29. data/lib/temporalio/api/enums/v1/batch_operation.rb +22 -0
  30. data/lib/temporalio/api/enums/v1/command_type.rb +21 -0
  31. data/lib/temporalio/api/enums/v1/common.rb +28 -0
  32. data/lib/temporalio/api/enums/v1/deployment.rb +23 -0
  33. data/lib/temporalio/api/enums/v1/event_type.rb +21 -0
  34. data/lib/temporalio/api/enums/v1/failed_cause.rb +26 -0
  35. data/lib/temporalio/api/enums/v1/namespace.rb +23 -0
  36. data/lib/temporalio/api/enums/v1/nexus.rb +21 -0
  37. data/lib/temporalio/api/enums/v1/query.rb +22 -0
  38. data/lib/temporalio/api/enums/v1/reset.rb +23 -0
  39. data/lib/temporalio/api/enums/v1/schedule.rb +21 -0
  40. data/lib/temporalio/api/enums/v1/task_queue.rb +25 -0
  41. data/lib/temporalio/api/enums/v1/update.rb +22 -0
  42. data/lib/temporalio/api/enums/v1/workflow.rb +31 -0
  43. data/lib/temporalio/api/errordetails/v1/message.rb +44 -0
  44. data/lib/temporalio/api/export/v1/message.rb +24 -0
  45. data/lib/temporalio/api/failure/v1/message.rb +38 -0
  46. data/lib/temporalio/api/filter/v1/message.rb +27 -0
  47. data/lib/temporalio/api/history/v1/message.rb +94 -0
  48. data/lib/temporalio/api/namespace/v1/message.rb +31 -0
  49. data/lib/temporalio/api/nexus/v1/message.rb +41 -0
  50. data/lib/temporalio/api/operatorservice/v1/request_response.rb +49 -0
  51. data/lib/temporalio/api/operatorservice/v1/service.rb +23 -0
  52. data/lib/temporalio/api/operatorservice.rb +3 -0
  53. data/lib/temporalio/api/payload_visitor.rb +1668 -0
  54. data/lib/temporalio/api/protocol/v1/message.rb +23 -0
  55. data/lib/temporalio/api/query/v1/message.rb +28 -0
  56. data/lib/temporalio/api/replication/v1/message.rb +26 -0
  57. data/lib/temporalio/api/rules/v1/message.rb +27 -0
  58. data/lib/temporalio/api/schedule/v1/message.rb +43 -0
  59. data/lib/temporalio/api/sdk/v1/enhanced_stack_trace.rb +25 -0
  60. data/lib/temporalio/api/sdk/v1/task_complete_metadata.rb +21 -0
  61. data/lib/temporalio/api/sdk/v1/user_metadata.rb +23 -0
  62. data/lib/temporalio/api/sdk/v1/workflow_metadata.rb +23 -0
  63. data/lib/temporalio/api/taskqueue/v1/message.rb +48 -0
  64. data/lib/temporalio/api/testservice/v1/request_response.rb +31 -0
  65. data/lib/temporalio/api/testservice/v1/service.rb +23 -0
  66. data/lib/temporalio/api/update/v1/message.rb +33 -0
  67. data/lib/temporalio/api/version/v1/message.rb +26 -0
  68. data/lib/temporalio/api/workflow/v1/message.rb +63 -0
  69. data/lib/temporalio/api/workflowservice/v1/request_response.rb +244 -0
  70. data/lib/temporalio/api/workflowservice/v1/service.rb +23 -0
  71. data/lib/temporalio/api/workflowservice.rb +3 -0
  72. data/lib/temporalio/api.rb +15 -0
  73. data/lib/temporalio/cancellation.rb +170 -0
  74. data/lib/temporalio/client/activity_id_reference.rb +32 -0
  75. data/lib/temporalio/client/async_activity_handle.rb +85 -0
  76. data/lib/temporalio/client/connection/cloud_service.rb +786 -0
  77. data/lib/temporalio/client/connection/operator_service.rb +201 -0
  78. data/lib/temporalio/client/connection/service.rb +42 -0
  79. data/lib/temporalio/client/connection/test_service.rb +111 -0
  80. data/lib/temporalio/client/connection/workflow_service.rb +1326 -0
  81. data/lib/temporalio/client/connection.rb +316 -0
  82. data/lib/temporalio/client/interceptor.rb +457 -0
  83. data/lib/temporalio/client/schedule.rb +991 -0
  84. data/lib/temporalio/client/schedule_handle.rb +126 -0
  85. data/lib/temporalio/client/with_start_workflow_operation.rb +115 -0
  86. data/lib/temporalio/client/workflow_execution.rb +119 -0
  87. data/lib/temporalio/client/workflow_execution_count.rb +36 -0
  88. data/lib/temporalio/client/workflow_execution_status.rb +18 -0
  89. data/lib/temporalio/client/workflow_handle.rb +389 -0
  90. data/lib/temporalio/client/workflow_query_reject_condition.rb +14 -0
  91. data/lib/temporalio/client/workflow_update_handle.rb +65 -0
  92. data/lib/temporalio/client/workflow_update_wait_stage.rb +17 -0
  93. data/lib/temporalio/client.rb +625 -0
  94. data/lib/temporalio/common_enums.rb +55 -0
  95. data/lib/temporalio/contrib/open_telemetry.rb +469 -0
  96. data/lib/temporalio/converters/data_converter.rb +99 -0
  97. data/lib/temporalio/converters/failure_converter.rb +205 -0
  98. data/lib/temporalio/converters/payload_codec.rb +26 -0
  99. data/lib/temporalio/converters/payload_converter/binary_null.rb +34 -0
  100. data/lib/temporalio/converters/payload_converter/binary_plain.rb +35 -0
  101. data/lib/temporalio/converters/payload_converter/binary_protobuf.rb +42 -0
  102. data/lib/temporalio/converters/payload_converter/composite.rb +66 -0
  103. data/lib/temporalio/converters/payload_converter/encoding.rb +35 -0
  104. data/lib/temporalio/converters/payload_converter/json_plain.rb +44 -0
  105. data/lib/temporalio/converters/payload_converter/json_protobuf.rb +41 -0
  106. data/lib/temporalio/converters/payload_converter.rb +71 -0
  107. data/lib/temporalio/converters/raw_value.rb +20 -0
  108. data/lib/temporalio/converters.rb +9 -0
  109. data/lib/temporalio/error/failure.rb +237 -0
  110. data/lib/temporalio/error.rb +156 -0
  111. data/lib/temporalio/internal/bridge/3.2/temporalio_bridge.bundle +0 -0
  112. data/lib/temporalio/internal/bridge/3.3/temporalio_bridge.bundle +0 -0
  113. data/lib/temporalio/internal/bridge/3.4/temporalio_bridge.bundle +0 -0
  114. data/lib/temporalio/internal/bridge/api/activity_result/activity_result.rb +34 -0
  115. data/lib/temporalio/internal/bridge/api/activity_task/activity_task.rb +32 -0
  116. data/lib/temporalio/internal/bridge/api/child_workflow/child_workflow.rb +33 -0
  117. data/lib/temporalio/internal/bridge/api/common/common.rb +27 -0
  118. data/lib/temporalio/internal/bridge/api/core_interface.rb +40 -0
  119. data/lib/temporalio/internal/bridge/api/external_data/external_data.rb +27 -0
  120. data/lib/temporalio/internal/bridge/api/nexus/nexus.rb +34 -0
  121. data/lib/temporalio/internal/bridge/api/workflow_activation/workflow_activation.rb +56 -0
  122. data/lib/temporalio/internal/bridge/api/workflow_commands/workflow_commands.rb +58 -0
  123. data/lib/temporalio/internal/bridge/api/workflow_completion/workflow_completion.rb +31 -0
  124. data/lib/temporalio/internal/bridge/api.rb +3 -0
  125. data/lib/temporalio/internal/bridge/client.rb +95 -0
  126. data/lib/temporalio/internal/bridge/runtime.rb +56 -0
  127. data/lib/temporalio/internal/bridge/testing.rb +69 -0
  128. data/lib/temporalio/internal/bridge/worker.rb +109 -0
  129. data/lib/temporalio/internal/bridge.rb +36 -0
  130. data/lib/temporalio/internal/client/implementation.rb +926 -0
  131. data/lib/temporalio/internal/metric.rb +122 -0
  132. data/lib/temporalio/internal/proto_utils.rb +165 -0
  133. data/lib/temporalio/internal/worker/activity_worker.rb +448 -0
  134. data/lib/temporalio/internal/worker/multi_runner.rb +213 -0
  135. data/lib/temporalio/internal/worker/workflow_instance/child_workflow_handle.rb +54 -0
  136. data/lib/temporalio/internal/worker/workflow_instance/context.rb +391 -0
  137. data/lib/temporalio/internal/worker/workflow_instance/details.rb +49 -0
  138. data/lib/temporalio/internal/worker/workflow_instance/external_workflow_handle.rb +32 -0
  139. data/lib/temporalio/internal/worker/workflow_instance/externally_immutable_hash.rb +22 -0
  140. data/lib/temporalio/internal/worker/workflow_instance/handler_execution.rb +25 -0
  141. data/lib/temporalio/internal/worker/workflow_instance/handler_hash.rb +41 -0
  142. data/lib/temporalio/internal/worker/workflow_instance/illegal_call_tracer.rb +97 -0
  143. data/lib/temporalio/internal/worker/workflow_instance/inbound_implementation.rb +62 -0
  144. data/lib/temporalio/internal/worker/workflow_instance/outbound_implementation.rb +404 -0
  145. data/lib/temporalio/internal/worker/workflow_instance/replay_safe_logger.rb +37 -0
  146. data/lib/temporalio/internal/worker/workflow_instance/replay_safe_metric.rb +40 -0
  147. data/lib/temporalio/internal/worker/workflow_instance/scheduler.rb +183 -0
  148. data/lib/temporalio/internal/worker/workflow_instance.rb +800 -0
  149. data/lib/temporalio/internal/worker/workflow_worker.rb +249 -0
  150. data/lib/temporalio/internal.rb +7 -0
  151. data/lib/temporalio/metric.rb +109 -0
  152. data/lib/temporalio/priority.rb +59 -0
  153. data/lib/temporalio/retry_policy.rb +74 -0
  154. data/lib/temporalio/runtime/metric_buffer.rb +94 -0
  155. data/lib/temporalio/runtime.rb +352 -0
  156. data/lib/temporalio/scoped_logger.rb +96 -0
  157. data/lib/temporalio/search_attributes.rb +356 -0
  158. data/lib/temporalio/testing/activity_environment.rb +175 -0
  159. data/lib/temporalio/testing/workflow_environment.rb +406 -0
  160. data/lib/temporalio/testing.rb +10 -0
  161. data/lib/temporalio/version.rb +5 -0
  162. data/lib/temporalio/versioning_override.rb +55 -0
  163. data/lib/temporalio/worker/activity_executor/fiber.rb +49 -0
  164. data/lib/temporalio/worker/activity_executor/thread_pool.rb +46 -0
  165. data/lib/temporalio/worker/activity_executor.rb +55 -0
  166. data/lib/temporalio/worker/deployment_options.rb +45 -0
  167. data/lib/temporalio/worker/interceptor.rb +367 -0
  168. data/lib/temporalio/worker/poller_behavior.rb +61 -0
  169. data/lib/temporalio/worker/thread_pool.rb +237 -0
  170. data/lib/temporalio/worker/tuner.rb +189 -0
  171. data/lib/temporalio/worker/workflow_executor/thread_pool.rb +236 -0
  172. data/lib/temporalio/worker/workflow_executor.rb +26 -0
  173. data/lib/temporalio/worker/workflow_replayer.rb +349 -0
  174. data/lib/temporalio/worker.rb +633 -0
  175. data/lib/temporalio/worker_deployment_version.rb +67 -0
  176. data/lib/temporalio/workflow/activity_cancellation_type.rb +20 -0
  177. data/lib/temporalio/workflow/child_workflow_cancellation_type.rb +21 -0
  178. data/lib/temporalio/workflow/child_workflow_handle.rb +43 -0
  179. data/lib/temporalio/workflow/definition.rb +680 -0
  180. data/lib/temporalio/workflow/external_workflow_handle.rb +41 -0
  181. data/lib/temporalio/workflow/future.rb +151 -0
  182. data/lib/temporalio/workflow/handler_unfinished_policy.rb +13 -0
  183. data/lib/temporalio/workflow/info.rb +107 -0
  184. data/lib/temporalio/workflow/parent_close_policy.rb +19 -0
  185. data/lib/temporalio/workflow/update_info.rb +20 -0
  186. data/lib/temporalio/workflow.rb +594 -0
  187. data/lib/temporalio/workflow_history.rb +47 -0
  188. data/lib/temporalio.rb +12 -0
  189. data/temporalio.gemspec +31 -0
  190. metadata +267 -0
@@ -0,0 +1,457 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Temporalio
4
+ class Client
5
+ # Mixin for intercepting clients. Classes that +include+ this should implement their own {intercept_client} that
6
+ # returns their own instance of {Outbound}.
7
+ #
8
+ # @note Input classes herein may get new required fields added and therefore the constructors of the Input classes
9
+ # may change in backwards incompatible ways. Users should not try to construct Input classes themselves.
10
+ module Interceptor
11
+ # Method called when intercepting a client. This is called upon client creation.
12
+ #
13
+ # @param next_interceptor [Outbound] Next interceptor in the chain that should be called. This is usually passed
14
+ # to {Outbound} constructor.
15
+ # @return [Outbound] Interceptor to be called for client calls.
16
+ def intercept_client(next_interceptor)
17
+ next_interceptor
18
+ end
19
+
20
+ # Input for {Outbound.start_workflow}.
21
+ StartWorkflowInput = Data.define(
22
+ :workflow,
23
+ :args,
24
+ :workflow_id,
25
+ :task_queue,
26
+ :static_summary,
27
+ :static_details,
28
+ :execution_timeout,
29
+ :run_timeout,
30
+ :task_timeout,
31
+ :id_reuse_policy,
32
+ :id_conflict_policy,
33
+ :retry_policy,
34
+ :cron_schedule,
35
+ :memo,
36
+ :search_attributes,
37
+ :start_delay,
38
+ :request_eager_start,
39
+ :headers,
40
+ :versioning_override,
41
+ :priority,
42
+ :rpc_options
43
+ )
44
+
45
+ # Input for {Outbound.start_update_with_start_workflow}.
46
+ StartUpdateWithStartWorkflowInput = Data.define(
47
+ :update_id,
48
+ :update,
49
+ :args,
50
+ :wait_for_stage,
51
+ :start_workflow_operation,
52
+ :headers,
53
+ :rpc_options
54
+ )
55
+
56
+ # Input for {Outbound.signal_with_start_workflow}.
57
+ SignalWithStartWorkflowInput = Data.define(
58
+ :signal,
59
+ :args,
60
+ :start_workflow_operation,
61
+ # Headers intentionally not defined here, because they are not separate from start_workflow_operation
62
+ :rpc_options
63
+ )
64
+
65
+ # Input for {Outbound.list_workflows}.
66
+ ListWorkflowsInput = Data.define(
67
+ :query,
68
+ :rpc_options
69
+ )
70
+
71
+ # Input for {Outbound.count_workflows}.
72
+ CountWorkflowsInput = Data.define(
73
+ :query,
74
+ :rpc_options
75
+ )
76
+
77
+ # Input for {Outbound.describe_workflow}.
78
+ DescribeWorkflowInput = Data.define(
79
+ :workflow_id,
80
+ :run_id,
81
+ :rpc_options
82
+ )
83
+
84
+ # Input for {Outbound.fetch_workflow_history_events}.
85
+ FetchWorkflowHistoryEventsInput = Data.define(
86
+ :workflow_id,
87
+ :run_id,
88
+ :wait_new_event,
89
+ :event_filter_type,
90
+ :skip_archival,
91
+ :rpc_options
92
+ )
93
+
94
+ # Input for {Outbound.signal_workflow}.
95
+ SignalWorkflowInput = Data.define(
96
+ :workflow_id,
97
+ :run_id,
98
+ :signal,
99
+ :args,
100
+ :headers,
101
+ :rpc_options
102
+ )
103
+
104
+ # Input for {Outbound.query_workflow}.
105
+ QueryWorkflowInput = Data.define(
106
+ :workflow_id,
107
+ :run_id,
108
+ :query,
109
+ :args,
110
+ :reject_condition,
111
+ :headers,
112
+ :rpc_options
113
+ )
114
+
115
+ # Input for {Outbound.start_workflow_update}.
116
+ StartWorkflowUpdateInput = Data.define(
117
+ :workflow_id,
118
+ :run_id,
119
+ :update_id,
120
+ :update,
121
+ :args,
122
+ :wait_for_stage,
123
+ :headers,
124
+ :rpc_options
125
+ )
126
+
127
+ # Input for {Outbound.poll_workflow_update}.
128
+ PollWorkflowUpdateInput = Data.define(
129
+ :workflow_id,
130
+ :run_id,
131
+ :update_id,
132
+ :rpc_options
133
+ )
134
+
135
+ # Input for {Outbound.cancel_workflow}.
136
+ CancelWorkflowInput = Data.define(
137
+ :workflow_id,
138
+ :run_id,
139
+ :first_execution_run_id,
140
+ :rpc_options
141
+ )
142
+
143
+ # Input for {Outbound.terminate_workflow}.
144
+ TerminateWorkflowInput = Data.define(
145
+ :workflow_id,
146
+ :run_id,
147
+ :first_execution_run_id,
148
+ :reason,
149
+ :details,
150
+ :rpc_options
151
+ )
152
+
153
+ # Input for {Outbound.create_schedule}.
154
+ CreateScheduleInput = Data.define(
155
+ :id,
156
+ :schedule,
157
+ :trigger_immediately,
158
+ :backfills,
159
+ :memo,
160
+ :search_attributes,
161
+ :rpc_options
162
+ )
163
+
164
+ # Input for {Outbound.list_schedules}.
165
+ ListSchedulesInput = Data.define(
166
+ :query,
167
+ :rpc_options
168
+ )
169
+
170
+ # Input for {Outbound.backfill_schedule}.
171
+ BackfillScheduleInput = Data.define(
172
+ :id,
173
+ :backfills,
174
+ :rpc_options
175
+ )
176
+
177
+ # Input for {Outbound.delete_schedule}.
178
+ DeleteScheduleInput = Data.define(
179
+ :id,
180
+ :rpc_options
181
+ )
182
+
183
+ # Input for {Outbound.describe_schedule}.
184
+ DescribeScheduleInput = Data.define(
185
+ :id,
186
+ :rpc_options
187
+ )
188
+
189
+ # Input for {Outbound.pause_schedule}.
190
+ PauseScheduleInput = Data.define(
191
+ :id,
192
+ :note,
193
+ :rpc_options
194
+ )
195
+
196
+ # Input for {Outbound.trigger_schedule}.
197
+ TriggerScheduleInput = Data.define(
198
+ :id,
199
+ :overlap,
200
+ :rpc_options
201
+ )
202
+
203
+ # Input for {Outbound.unpause_schedule}.
204
+ UnpauseScheduleInput = Data.define(
205
+ :id,
206
+ :note,
207
+ :rpc_options
208
+ )
209
+
210
+ # Input for {Outbound.update_schedule}.
211
+ UpdateScheduleInput = Data.define(
212
+ :id,
213
+ :updater,
214
+ :rpc_options
215
+ )
216
+
217
+ # Input for {Outbound.heartbeat_async_activity}.
218
+ HeartbeatAsyncActivityInput = Data.define(
219
+ :task_token_or_id_reference,
220
+ :details,
221
+ :rpc_options
222
+ )
223
+
224
+ # Input for {Outbound.complete_async_activity}.
225
+ CompleteAsyncActivityInput = Data.define(
226
+ :task_token_or_id_reference,
227
+ :result,
228
+ :rpc_options
229
+ )
230
+
231
+ # Input for {Outbound.fail_async_activity}.
232
+ FailAsyncActivityInput = Data.define(
233
+ :task_token_or_id_reference,
234
+ :error,
235
+ :last_heartbeat_details,
236
+ :rpc_options
237
+ )
238
+
239
+ # Input for {Outbound.report_cancellation_async_activity}.
240
+ ReportCancellationAsyncActivityInput = Data.define(
241
+ :task_token_or_id_reference,
242
+ :details,
243
+ :rpc_options
244
+ )
245
+
246
+ # Outbound interceptor for intercepting client calls. This should be extended by users needing to intercept client
247
+ # actions.
248
+ class Outbound
249
+ # @return [Outbound] Next interceptor in the chain.
250
+ attr_reader :next_interceptor
251
+
252
+ # Initialize outbound with the next interceptor in the chain.
253
+ #
254
+ # @param next_interceptor [Outbound] Next interceptor in the chain.
255
+ def initialize(next_interceptor)
256
+ @next_interceptor = next_interceptor
257
+ end
258
+
259
+ # Called for every {Client.start_workflow} and {Client.execute_workflow} call.
260
+ #
261
+ # @param input [StartWorkflowInput] Input.
262
+ # @return [WorkflowHandle] Workflow handle.
263
+ def start_workflow(input)
264
+ next_interceptor.start_workflow(input)
265
+ end
266
+
267
+ # Called for every {Client.start_update_with_start_workflow} and {Client.execute_update_with_start_workflow}
268
+ # call.
269
+ #
270
+ # @param input [StartUpdateWithStartWorkflowInput] Input.
271
+ # @return [WorkflowUpdateHandle] Workflow update handle.
272
+ def start_update_with_start_workflow(input)
273
+ next_interceptor.start_update_with_start_workflow(input)
274
+ end
275
+
276
+ # Called for every {Client.signal_with_start_workflow}.
277
+ #
278
+ # @param input [SignalWithStartWorkflowInput] Input.
279
+ # @return [WorkflowHandle] Workflow handle.
280
+ def signal_with_start_workflow(input)
281
+ next_interceptor.signal_with_start_workflow(input)
282
+ end
283
+
284
+ # Called for every {Client.list_workflows} call.
285
+ #
286
+ # @param input [ListWorkflowsInput] Input.
287
+ # @return [Enumerator<WorkflowExecution>] Enumerable workflow executions.
288
+ def list_workflows(input)
289
+ next_interceptor.list_workflows(input)
290
+ end
291
+
292
+ # Called for every {Client.count_workflows} call.
293
+ #
294
+ # @param input [CountWorkflowsInput] Input.
295
+ # @return [WorkflowExecutionCount] Workflow count.
296
+ def count_workflows(input)
297
+ next_interceptor.count_workflows(input)
298
+ end
299
+
300
+ # Called for every {WorkflowHandle.describe} call.
301
+ #
302
+ # @param input [DescribeWorkflowInput] Input.
303
+ # @return [WorkflowExecution::Description] Workflow description.
304
+ def describe_workflow(input)
305
+ next_interceptor.describe_workflow(input)
306
+ end
307
+
308
+ # Called everytime the client needs workflow history. This includes getting the result.
309
+ #
310
+ # @param input [FetchWorkflowHistoryEventsInput] Input.
311
+ # @return [Enumerator<Api::History::V1::HistoryEvent>] Event enumerator.
312
+ def fetch_workflow_history_events(input)
313
+ next_interceptor.fetch_workflow_history_events(input)
314
+ end
315
+
316
+ # Called for every {WorkflowHandle.signal} call.
317
+ #
318
+ # @param input [SignalWorkflowInput] Input.
319
+ def signal_workflow(input)
320
+ next_interceptor.signal_workflow(input)
321
+ end
322
+
323
+ # Called for every {WorkflowHandle.query} call.
324
+ #
325
+ # @param input [QueryWorkflowInput] Input.
326
+ # @return [Object, nil] Query result.
327
+ def query_workflow(input)
328
+ next_interceptor.query_workflow(input)
329
+ end
330
+
331
+ # Called for every {WorkflowHandle.start_update} call.
332
+ #
333
+ # @param input [StartWorkflowUpdateInput] Input.
334
+ # @return [WorkflowUpdateHandle] Update handle.
335
+ def start_workflow_update(input)
336
+ next_interceptor.start_workflow_update(input)
337
+ end
338
+
339
+ # Called when polling for update result.
340
+ #
341
+ # @param input [PollWorkflowUpdateInput] Input.
342
+ # @return [Api::Update::V1::Outcome] Update outcome.
343
+ def poll_workflow_update(input)
344
+ next_interceptor.poll_workflow_update(input)
345
+ end
346
+
347
+ # Called for every {WorkflowHandle.cancel} call.
348
+ #
349
+ # @param input [CancelWorkflowInput] Input.
350
+ def cancel_workflow(input)
351
+ next_interceptor.cancel_workflow(input)
352
+ end
353
+
354
+ # Called for every {WorkflowHandle.terminate} call.
355
+ #
356
+ # @param input [TerminateWorkflowInput] Input.
357
+ def terminate_workflow(input)
358
+ next_interceptor.terminate_workflow(input)
359
+ end
360
+
361
+ # Called for every {Client.create_schedule} call.
362
+ #
363
+ # @param input [CreateScheduleInput] Input.
364
+ # @return [ScheduleHandle] Schedule handle.
365
+ def create_schedule(input)
366
+ next_interceptor.create_schedule(input)
367
+ end
368
+
369
+ # Called for every {Client.list_schedules} call.
370
+ #
371
+ # @param input [ListSchedulesInput] Input.
372
+ # @return [Enumerator<Schedule::List::Description>] Enumerable schedules.
373
+ def list_schedules(input)
374
+ next_interceptor.list_schedules(input)
375
+ end
376
+
377
+ # Called for every {ScheduleHandle.backfill} call.
378
+ #
379
+ # @param input [BackfillScheduleInput] Input.
380
+ def backfill_schedule(input)
381
+ next_interceptor.backfill_schedule(input)
382
+ end
383
+
384
+ # Called for every {ScheduleHandle.delete} call.
385
+ #
386
+ # @param input [DeleteScheduleInput] Input.
387
+ def delete_schedule(input)
388
+ next_interceptor.delete_schedule(input)
389
+ end
390
+
391
+ # Called for every {ScheduleHandle.describe} call.
392
+ #
393
+ # @param input [DescribeScheduleInput] Input.
394
+ # @return [Schedule::Description] Schedule description.
395
+ def describe_schedule(input)
396
+ next_interceptor.describe_schedule(input)
397
+ end
398
+
399
+ # Called for every {ScheduleHandle.pause} call.
400
+ #
401
+ # @param input [PauseScheduleInput] Input.
402
+ def pause_schedule(input)
403
+ next_interceptor.pause_schedule(input)
404
+ end
405
+
406
+ # Called for every {ScheduleHandle.trigger} call.
407
+ #
408
+ # @param input [TriggerScheduleInput] Input.
409
+ def trigger_schedule(input)
410
+ next_interceptor.trigger_schedule(input)
411
+ end
412
+
413
+ # Called for every {ScheduleHandle.unpause} call.
414
+ #
415
+ # @param input [UnpauseScheduleInput] Input.
416
+ def unpause_schedule(input)
417
+ next_interceptor.unpause_schedule(input)
418
+ end
419
+
420
+ # Called for every {ScheduleHandle.update} call.
421
+ #
422
+ # @param input [UpdateScheduleInput] Input.
423
+ def update_schedule(input)
424
+ next_interceptor.update_schedule(input)
425
+ end
426
+
427
+ # Called for every {AsyncActivityHandle.heartbeat} call.
428
+ #
429
+ # @param input [HeartbeatAsyncActivityInput] Input.
430
+ def heartbeat_async_activity(input)
431
+ next_interceptor.heartbeat_async_activity(input)
432
+ end
433
+
434
+ # Called for every {AsyncActivityHandle.complete} call.
435
+ #
436
+ # @param input [CompleteAsyncActivityInput] Input.
437
+ def complete_async_activity(input)
438
+ next_interceptor.complete_async_activity(input)
439
+ end
440
+
441
+ # Called for every {AsyncActivityHandle.fail} call.
442
+ #
443
+ # @param input [FailAsyncActivityInput] Input.
444
+ def fail_async_activity(input)
445
+ next_interceptor.fail_async_activity(input)
446
+ end
447
+
448
+ # Called for every {AsyncActivityHandle.report_cancellation} call.
449
+ #
450
+ # @param input [ReportCancellationAsyncActivityInput] Input.
451
+ def report_cancellation_async_activity(input)
452
+ next_interceptor.report_cancellation_async_activity(input)
453
+ end
454
+ end
455
+ end
456
+ end
457
+ end