Class: Temporalio::Activity::Definition::Info
- Inherits:
-
Object
- Object
- Temporalio::Activity::Definition::Info
- Defined in:
- lib/temporalio/activity/definition.rb
Overview
Definition info of an activity. Activities are usually classes/instances that extend Temporalio::Activity::Definition, but definitions can also be manually created with a block via #initialize here.
Instance Attribute Summary collapse
-
#cancel_raise ⇒ Boolean
readonly
Whether to raise in thread/fiber on cancellation.
-
#executor ⇒ Symbol
readonly
Name of the executor.
-
#instance ⇒ Object, ...
readonly
The pre-created instance or the proc to create/return it.
-
#name ⇒ String, ...
readonly
Name of the activity, or nil if the activity is dynamic.
-
#proc ⇒ Proc
readonly
Proc for the activity.
-
#raw_args ⇒ Boolean
readonly
Whether to use Converters::RawValues as arguments.
Class Method Summary collapse
-
.from_activity(activity) ⇒ Object
Obtain definition info representing the given activity, which can be a class, instance, or definition info.
Instance Method Summary collapse
-
#initialize(name:, instance: nil, executor: :default, cancel_raise: true, raw_args: false) { ... } ⇒ Info
constructor
Manually create activity definition info.
Constructor Details
#initialize(name:, instance: nil, executor: :default, cancel_raise: true, raw_args: false) { ... } ⇒ Info
Manually create activity definition info. Most users will use an instance/class of Temporalio::Activity::Definition.
171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 |
# File 'lib/temporalio/activity/definition.rb', line 171 def initialize( name:, instance: nil, executor: :default, cancel_raise: true, raw_args: false, &block ) @name = name @instance = instance raise ArgumentError, 'Must give block' unless block_given? @proc = block @executor = executor @cancel_raise = cancel_raise @raw_args = raw_args Internal::ProtoUtils.assert_non_reserved_name(name) end |
Instance Attribute Details
#cancel_raise ⇒ Boolean (readonly)
Returns Whether to raise in thread/fiber on cancellation. Default is ‘true`.
120 121 122 |
# File 'lib/temporalio/activity/definition.rb', line 120 def cancel_raise @cancel_raise end |
#executor ⇒ Symbol (readonly)
Returns Name of the executor. Default is ‘:default`.
117 118 119 |
# File 'lib/temporalio/activity/definition.rb', line 117 def executor @executor end |
#instance ⇒ Object, ... (readonly)
Returns The pre-created instance or the proc to create/return it.
111 112 113 |
# File 'lib/temporalio/activity/definition.rb', line 111 def instance @instance end |
#name ⇒ String, ... (readonly)
Returns Name of the activity, or nil if the activity is dynamic.
108 109 110 |
# File 'lib/temporalio/activity/definition.rb', line 108 def name @name end |
#proc ⇒ Proc (readonly)
Returns Proc for the activity. Should use Context#instance to access the instance.
114 115 116 |
# File 'lib/temporalio/activity/definition.rb', line 114 def proc @proc end |
#raw_args ⇒ Boolean (readonly)
Returns Whether to use Converters::RawValues as arguments.
123 124 125 |
# File 'lib/temporalio/activity/definition.rb', line 123 def raw_args @raw_args end |
Class Method Details
.from_activity(activity) ⇒ Object
Obtain definition info representing the given activity, which can be a class, instance, or definition info.
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 |
# File 'lib/temporalio/activity/definition.rb', line 129 def self.from_activity(activity) # Class means create each time, instance means just call, definition # does nothing special case activity when Class unless activity < Definition raise ArgumentError, "Class '#{activity}' does not extend Temporalio::Activity::Definition" end details = activity._activity_definition_details new( name: details[:activity_name], instance: proc { activity.new }, executor: details[:activity_executor], cancel_raise: details[:activity_cancel_raise], raw_args: details[:activity_raw_args] ) { |*args| Context.current.instance&.execute(*args) } when Definition details = activity.class._activity_definition_details new( name: details[:activity_name], instance: activity, executor: details[:activity_executor], cancel_raise: details[:activity_cancel_raise], raw_args: details[:activity_raw_args] ) { |*args| Context.current.instance&.execute(*args) } when Info activity else raise ArgumentError, "#{activity} is not an activity class, instance, or definition info" end end |