requestCancelWorkflowExecution method
Records a WorkflowExecutionCancelRequested
event in the
currently running workflow execution identified by the given domain,
workflowId, and runId. This logically requests the cancellation of the
workflow execution as a whole. It is up to the decider to take appropriate
actions when it receives an execution history with this event.
Access Control
You can use IAM policies to control this action's access to Amazon SWF resources as follows:
-
Use a
Resource
element with the domain name to limit the action to only specified domains. -
Use an
Action
element to allow or deny permission to call this action. - You cannot use an IAM policy to constrain this action's parameters.
cause
parameter is
set to OPERATION_NOT_PERMITTED
. For details and example IAM
policies, see Using
IAM to Manage Access to Amazon SWF Workflows in the Amazon SWF
Developer Guide.
May throw UnknownResourceFault. May throw OperationNotPermittedFault.
Parameter domain
:
The name of the domain containing the workflow execution to cancel.
Parameter workflowId
:
The workflowId of the workflow execution to cancel.
Parameter runId
:
The runId of the workflow execution to cancel.
Implementation
Future<void> requestCancelWorkflowExecution({
required String domain,
required String workflowId,
String? runId,
}) async {
ArgumentError.checkNotNull(domain, 'domain');
_s.validateStringLength(
'domain',
domain,
1,
256,
isRequired: true,
);
ArgumentError.checkNotNull(workflowId, 'workflowId');
_s.validateStringLength(
'workflowId',
workflowId,
1,
256,
isRequired: true,
);
_s.validateStringLength(
'runId',
runId,
0,
64,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.0',
'X-Amz-Target': 'SimpleWorkflowService.RequestCancelWorkflowExecution'
};
await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'domain': domain,
'workflowId': workflowId,
if (runId != null) 'runId': runId,
},
);
}