respondActivityTaskFailed method
Used by workers to tell the service that the ActivityTask
identified by the taskToken
has failed with
reason
(if specified). The reason
and
details
appear in the ActivityTaskFailed
event
added to the workflow history.
A task is considered open from the time that it is scheduled until it is closed. Therefore a task is reported as open while a worker is processing it. A task is closed after it has been specified in a call to RespondActivityTaskCompleted, RespondActivityTaskCanceled, RespondActivityTaskFailed, or the task has timed out.
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 taskToken
:
The taskToken
of the ActivityTask.
Parameter details
:
Detailed information about the failure.
Parameter reason
:
Description of the error that may assist in diagnostics.
Implementation
Future<void> respondActivityTaskFailed({
required String taskToken,
String? details,
String? reason,
}) async {
ArgumentError.checkNotNull(taskToken, 'taskToken');
_s.validateStringLength(
'taskToken',
taskToken,
1,
1024,
isRequired: true,
);
_s.validateStringLength(
'details',
details,
0,
32768,
);
_s.validateStringLength(
'reason',
reason,
0,
256,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.0',
'X-Amz-Target': 'SimpleWorkflowService.RespondActivityTaskFailed'
};
await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'taskToken': taskToken,
if (details != null) 'details': details,
if (reason != null) 'reason': reason,
},
);
}