Class: Aws::SWF::Types::Decision
- Inherits:
-
Struct
- Object
- Struct
- Aws::SWF::Types::Decision
- Defined in:
- gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb
Overview
Specifies a decision made by the decider. A decision can be one of these types:
CancelTimer
– Cancels a previously started timer and records aTimerCanceled
event in the history.CancelWorkflowExecution
– Closes the workflow execution and records aWorkflowExecutionCanceled
event in the history.CompleteWorkflowExecution
– Closes the workflow execution and records aWorkflowExecutionCompleted
event in the history .ContinueAsNewWorkflowExecution
– Closes the workflow execution and starts a new workflow execution of the same type using the same workflow ID and a unique run Id. AWorkflowExecutionContinuedAsNew
event is recorded in the history.FailWorkflowExecution
– Closes the workflow execution and records aWorkflowExecutionFailed
event in the history.RecordMarker
– Records aMarkerRecorded
event in the history. Markers can be used for adding custom information in the history for instance to let deciders know that they don't need to look at the history beyond the marker event.RequestCancelActivityTask
– Attempts to cancel a previously scheduled activity task. If the activity task was scheduled but has not been assigned to a worker, then it is canceled. If the activity task was already assigned to a worker, then the worker is informed that cancellation has been requested in the response to RecordActivityTaskHeartbeat.RequestCancelExternalWorkflowExecution
– Requests that a request be made to cancel the specified external workflow execution and records aRequestCancelExternalWorkflowExecutionInitiated
event in the history.ScheduleActivityTask
– Schedules an activity task.SignalExternalWorkflowExecution
– Requests a signal to be delivered to the specified external workflow execution and records aSignalExternalWorkflowExecutionInitiated
event in the history.StartChildWorkflowExecution
– Requests that a child workflow execution be started and records aStartChildWorkflowExecutionInitiated
event in the history. The child workflow execution is a separate workflow execution with its own history.StartTimer
– Starts a timer for this workflow execution and records aTimerStarted
event in the history. This timer fires after the specified delay and record aTimerFired
event.
Access Control
If you grant permission to use RespondDecisionTaskCompleted
, you can
use IAM policies to express permissions for the list of decisions
returned by this action as if they were members of the API. Treating
decisions as a pseudo API maintains a uniform conceptual model and
helps keep policies readable. For details and example IAM policies,
see Using IAM to Manage Access to Amazon SWF Workflows in the
Amazon SWF Developer Guide.
Decision Failure
Decisions can fail for several reasons
The ordering of decisions should follow a logical flow. Some decisions might not make sense in the current context of the workflow execution and therefore fails.
A limit on your account was reached.
The decision lacks sufficient permissions.
One of the following events might be added to the history to indicate
an error. The event attribute's cause
parameter indicates the
cause. If cause
is set to OPERATION_NOT_PERMITTED
, the decision
failed because it lacked sufficient permissions. For details and
example IAM policies, see Using IAM to Manage Access to Amazon SWF
Workflows in the Amazon SWF Developer Guide.
ScheduleActivityTaskFailed
– AScheduleActivityTask
decision failed. This could happen if the activity type specified in the decision isn't registered, is in a deprecated state, or the decision isn't properly configured.RequestCancelActivityTaskFailed
– ARequestCancelActivityTask
decision failed. This could happen if there is no open activity task with the specified activityId.StartTimerFailed
– AStartTimer
decision failed. This could happen if there is another open timer with the same timerId.CancelTimerFailed
– ACancelTimer
decision failed. This could happen if there is no open timer with the specified timerId.StartChildWorkflowExecutionFailed
– AStartChildWorkflowExecution
decision failed. This could happen if the workflow type specified isn't registered, is deprecated, or the decision isn't properly configured.SignalExternalWorkflowExecutionFailed
– ASignalExternalWorkflowExecution
decision failed. This could happen if theworkflowID
specified in the decision was incorrect.RequestCancelExternalWorkflowExecutionFailed
– ARequestCancelExternalWorkflowExecution
decision failed. This could happen if theworkflowID
specified in the decision was incorrect.CancelWorkflowExecutionFailed
– ACancelWorkflowExecution
decision failed. This could happen if there is an unhandled decision task pending in the workflow execution.CompleteWorkflowExecutionFailed
– ACompleteWorkflowExecution
decision failed. This could happen if there is an unhandled decision task pending in the workflow execution.ContinueAsNewWorkflowExecutionFailed
– AContinueAsNewWorkflowExecution
decision failed. This could happen if there is an unhandled decision task pending in the workflow execution or the ContinueAsNewWorkflowExecution decision was not configured correctly.FailWorkflowExecutionFailed
– AFailWorkflowExecution
decision failed. This could happen if there is an unhandled decision task pending in the workflow execution.
The preceding error events might occur due to an error in the decider logic, which might put the workflow execution in an unstable state The cause field in the event structure for the error event indicates the cause of the error.
CompleteWorkflowExecution
, FailWorkflowExecution
,
CancelWorkflowExecution
and ContinueAsNewWorkflowExecution
. An
UnhandledDecision
fault is returned if a workflow closing decision
is specified and a signal or activity event had been added to the
history while the decision task was being performed by the decider.
Unlike the above situations which are logic issues, this fault is
always possible because of race conditions in a distributed system.
The right action here is to call RespondDecisionTaskCompleted without
any decisions. This would result in another decision task with these
new events included in the history. The decider should handle the new
events and may decide to close the workflow execution.
How to Code a Decision
You code a decision by first setting the decision type field to one of the above decision values, and then set the corresponding attributes field shown below:
ScheduleActivityTaskDecisionAttributes
RequestCancelActivityTaskDecisionAttributes
CompleteWorkflowExecutionDecisionAttributes
FailWorkflowExecutionDecisionAttributes
CancelWorkflowExecutionDecisionAttributes
ContinueAsNewWorkflowExecutionDecisionAttributes
RecordMarkerDecisionAttributes
StartTimerDecisionAttributes
CancelTimerDecisionAttributes
SignalExternalWorkflowExecutionDecisionAttributes
RequestCancelExternalWorkflowExecutionDecisionAttributes
StartChildWorkflowExecutionDecisionAttributes
Constant Summary collapse
- SENSITIVE =
[]
Instance Attribute Summary collapse
-
#cancel_timer_decision_attributes ⇒ Types::CancelTimerDecisionAttributes
Provides the details of the
CancelTimer
decision. -
#cancel_workflow_execution_decision_attributes ⇒ Types::CancelWorkflowExecutionDecisionAttributes
Provides the details of the
CancelWorkflowExecution
decision. -
#complete_workflow_execution_decision_attributes ⇒ Types::CompleteWorkflowExecutionDecisionAttributes
Provides the details of the
CompleteWorkflowExecution
decision. -
#continue_as_new_workflow_execution_decision_attributes ⇒ Types::ContinueAsNewWorkflowExecutionDecisionAttributes
Provides the details of the
ContinueAsNewWorkflowExecution
decision. -
#decision_type ⇒ String
Specifies the type of the decision.
-
#fail_workflow_execution_decision_attributes ⇒ Types::FailWorkflowExecutionDecisionAttributes
Provides the details of the
FailWorkflowExecution
decision. -
#record_marker_decision_attributes ⇒ Types::RecordMarkerDecisionAttributes
Provides the details of the
RecordMarker
decision. -
#request_cancel_activity_task_decision_attributes ⇒ Types::RequestCancelActivityTaskDecisionAttributes
Provides the details of the
RequestCancelActivityTask
decision. -
#request_cancel_external_workflow_execution_decision_attributes ⇒ Types::RequestCancelExternalWorkflowExecutionDecisionAttributes
Provides the details of the
RequestCancelExternalWorkflowExecution
decision. -
#schedule_activity_task_decision_attributes ⇒ Types::ScheduleActivityTaskDecisionAttributes
Provides the details of the
ScheduleActivityTask
decision. -
#schedule_lambda_function_decision_attributes ⇒ Types::ScheduleLambdaFunctionDecisionAttributes
Provides the details of the
ScheduleLambdaFunction
decision. -
#signal_external_workflow_execution_decision_attributes ⇒ Types::SignalExternalWorkflowExecutionDecisionAttributes
Provides the details of the
SignalExternalWorkflowExecution
decision. -
#start_child_workflow_execution_decision_attributes ⇒ Types::StartChildWorkflowExecutionDecisionAttributes
Provides the details of the
StartChildWorkflowExecution
decision. -
#start_timer_decision_attributes ⇒ Types::StartTimerDecisionAttributes
Provides the details of the
StartTimer
decision.
Instance Attribute Details
#cancel_timer_decision_attributes ⇒ Types::CancelTimerDecisionAttributes
Provides the details of the CancelTimer
decision. It isn't set
for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#cancel_workflow_execution_decision_attributes ⇒ Types::CancelWorkflowExecutionDecisionAttributes
Provides the details of the CancelWorkflowExecution
decision. It
isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#complete_workflow_execution_decision_attributes ⇒ Types::CompleteWorkflowExecutionDecisionAttributes
Provides the details of the CompleteWorkflowExecution
decision. It
isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#continue_as_new_workflow_execution_decision_attributes ⇒ Types::ContinueAsNewWorkflowExecutionDecisionAttributes
Provides the details of the ContinueAsNewWorkflowExecution
decision. It isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#decision_type ⇒ String
Specifies the type of the decision.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#fail_workflow_execution_decision_attributes ⇒ Types::FailWorkflowExecutionDecisionAttributes
Provides the details of the FailWorkflowExecution
decision. It
isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#record_marker_decision_attributes ⇒ Types::RecordMarkerDecisionAttributes
Provides the details of the RecordMarker
decision. It isn't set
for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#request_cancel_activity_task_decision_attributes ⇒ Types::RequestCancelActivityTaskDecisionAttributes
Provides the details of the RequestCancelActivityTask
decision. It
isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#request_cancel_external_workflow_execution_decision_attributes ⇒ Types::RequestCancelExternalWorkflowExecutionDecisionAttributes
Provides the details of the RequestCancelExternalWorkflowExecution
decision. It isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#schedule_activity_task_decision_attributes ⇒ Types::ScheduleActivityTaskDecisionAttributes
Provides the details of the ScheduleActivityTask
decision. It
isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#schedule_lambda_function_decision_attributes ⇒ Types::ScheduleLambdaFunctionDecisionAttributes
Provides the details of the ScheduleLambdaFunction
decision. It
isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#signal_external_workflow_execution_decision_attributes ⇒ Types::SignalExternalWorkflowExecutionDecisionAttributes
Provides the details of the SignalExternalWorkflowExecution
decision. It isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#start_child_workflow_execution_decision_attributes ⇒ Types::StartChildWorkflowExecutionDecisionAttributes
Provides the details of the StartChildWorkflowExecution
decision.
It isn't set for other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |
#start_timer_decision_attributes ⇒ Types::StartTimerDecisionAttributes
Provides the details of the StartTimer
decision. It isn't set for
other decision types.
1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 |
# File 'gems/aws-sdk-swf/lib/aws-sdk-swf/types.rb', line 1565 class Decision < Struct.new( :decision_type, :schedule_activity_task_decision_attributes, :request_cancel_activity_task_decision_attributes, :complete_workflow_execution_decision_attributes, :fail_workflow_execution_decision_attributes, :cancel_workflow_execution_decision_attributes, :continue_as_new_workflow_execution_decision_attributes, :record_marker_decision_attributes, :start_timer_decision_attributes, :cancel_timer_decision_attributes, :signal_external_workflow_execution_decision_attributes, :request_cancel_external_workflow_execution_decision_attributes, :start_child_workflow_execution_decision_attributes, :schedule_lambda_function_decision_attributes) SENSITIVE = [] include Aws::Structure end |