AWS SDK Version 3 for .NET
API Reference

AWS services or capabilities described in AWS Documentation may vary by region/location. Click Getting Started with Amazon AWS to see specific differences applicable to the China (Beijing) Region.

Specifies a decision made by the decider. A decision can be one of these types:

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

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.

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.

A workflow execution may be closed by the decider by returning one of the following decisions when completing a decision task: 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:

Inheritance Hierarchy

System.Object
  Amazon.SimpleWorkflow.Model.Decision

Namespace: Amazon.SimpleWorkflow.Model
Assembly: AWSSDK.SimpleWorkflow.dll
Version: 3.x.y.z

Syntax

C#
public class Decision

The Decision type exposes the following members

Constructors

NameDescription
Public Method Decision()

Properties

NameTypeDescription
Public Property CancelTimerDecisionAttributes Amazon.SimpleWorkflow.Model.CancelTimerDecisionAttributes

Gets and sets the property CancelTimerDecisionAttributes.

Provides the details of the CancelTimer decision. It isn't set for other decision types.

Public Property CancelWorkflowExecutionDecisionAttributes Amazon.SimpleWorkflow.Model.CancelWorkflowExecutionDecisionAttributes

Gets and sets the property CancelWorkflowExecutionDecisionAttributes.

Provides the details of the CancelWorkflowExecution decision. It isn't set for other decision types.

Public Property CompleteWorkflowExecutionDecisionAttributes Amazon.SimpleWorkflow.Model.CompleteWorkflowExecutionDecisionAttributes

Gets and sets the property CompleteWorkflowExecutionDecisionAttributes.

Provides the details of the CompleteWorkflowExecution decision. It isn't set for other decision types.

Public Property ContinueAsNewWorkflowExecutionDecisionAttributes Amazon.SimpleWorkflow.Model.ContinueAsNewWorkflowExecutionDecisionAttributes

Gets and sets the property ContinueAsNewWorkflowExecutionDecisionAttributes.

Provides the details of the ContinueAsNewWorkflowExecution decision. It isn't set for other decision types.

Public Property DecisionType Amazon.SimpleWorkflow.DecisionType

Gets and sets the property DecisionType.

Specifies the type of the decision.

Public Property FailWorkflowExecutionDecisionAttributes Amazon.SimpleWorkflow.Model.FailWorkflowExecutionDecisionAttributes

Gets and sets the property FailWorkflowExecutionDecisionAttributes.

Provides the details of the FailWorkflowExecution decision. It isn't set for other decision types.

Public Property RecordMarkerDecisionAttributes Amazon.SimpleWorkflow.Model.RecordMarkerDecisionAttributes

Gets and sets the property RecordMarkerDecisionAttributes.

Provides the details of the RecordMarker decision. It isn't set for other decision types.

Public Property RequestCancelActivityTaskDecisionAttributes Amazon.SimpleWorkflow.Model.RequestCancelActivityTaskDecisionAttributes

Gets and sets the property RequestCancelActivityTaskDecisionAttributes.

Provides the details of the RequestCancelActivityTask decision. It isn't set for other decision types.

Public Property RequestCancelExternalWorkflowExecutionDecisionAttributes Amazon.SimpleWorkflow.Model.RequestCancelExternalWorkflowExecutionDecisionAttributes

Gets and sets the property RequestCancelExternalWorkflowExecutionDecisionAttributes.

Provides the details of the RequestCancelExternalWorkflowExecution decision. It isn't set for other decision types.

Public Property ScheduleActivityTaskDecisionAttributes Amazon.SimpleWorkflow.Model.ScheduleActivityTaskDecisionAttributes

Gets and sets the property ScheduleActivityTaskDecisionAttributes.

Provides the details of the ScheduleActivityTask decision. It isn't set for other decision types.

Public Property ScheduleLambdaFunctionDecisionAttributes Amazon.SimpleWorkflow.Model.ScheduleLambdaFunctionDecisionAttributes

Gets and sets the property ScheduleLambdaFunctionDecisionAttributes.

Provides the details of the ScheduleLambdaFunction decision. It isn't set for other decision types.

Public Property SignalExternalWorkflowExecutionDecisionAttributes Amazon.SimpleWorkflow.Model.SignalExternalWorkflowExecutionDecisionAttributes

Gets and sets the property SignalExternalWorkflowExecutionDecisionAttributes.

Provides the details of the SignalExternalWorkflowExecution decision. It isn't set for other decision types.

Public Property StartChildWorkflowExecutionDecisionAttributes Amazon.SimpleWorkflow.Model.StartChildWorkflowExecutionDecisionAttributes

Gets and sets the property StartChildWorkflowExecutionDecisionAttributes.

Provides the details of the StartChildWorkflowExecution decision. It isn't set for other decision types.

Public Property StartTimerDecisionAttributes Amazon.SimpleWorkflow.Model.StartTimerDecisionAttributes

Gets and sets the property StartTimerDecisionAttributes.

Provides the details of the StartTimer decision. It isn't set for other decision types.

Version Information

.NET Core App:
Supported in: 3.1

.NET Standard:
Supported in: 2.0

.NET Framework:
Supported in: 4.5, 4.0, 3.5