listClosedWorkflowExecutions method
- required String domain,
- CloseStatusFilter? closeStatusFilter,
- ExecutionTimeFilter? closeTimeFilter,
- WorkflowExecutionFilter? executionFilter,
- int? maximumPageSize,
- String? nextPageToken,
- bool? reverseOrder,
- ExecutionTimeFilter? startTimeFilter,
- TagFilter? tagFilter,
- WorkflowTypeFilter? typeFilter,
Returns a list of closed workflow executions in the specified domain that meet the filtering criteria. The results may be split into multiple pages. To retrieve subsequent pages, make the call again using the nextPageToken returned by the initial call. 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. -
Constrain the following parameters by using a
Condition
element with the appropriate keys.-
tagFilter.tag
: String constraint. The key isswf:tagFilter.tag
. -
typeFilter.name
: String constraint. The key isswf:typeFilter.name
. -
typeFilter.version
: String constraint. The key isswf:typeFilter.version
.
-
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 that contains the workflow executions to list.
Parameter closeStatusFilter
:
If specified, only workflow executions that match this close status
are listed. For example, if TERMINATED is specified, then only TERMINATED
workflow executions are listed.
Parameter closeTimeFilter
:
If specified, the workflow executions are included in the returned results
based on whether their close times are within the range specified by this
filter. Also, if this parameter is specified, the returned results are
ordered by their close times.
Parameter executionFilter
:
If specified, only workflow executions matching the workflow ID specified
in the filter are returned.
Parameter maximumPageSize
:
The maximum number of results that are returned per call. Use
nextPageToken
to obtain further pages of results.
Parameter nextPageToken
:
If NextPageToken
is returned there are more results
available. The value of NextPageToken
is a unique pagination
token for each page. Make the call again using the returned token to
retrieve the next page. Keep all other arguments unchanged. Each
pagination token expires after 60 seconds. Using an expired pagination
token will return a 400
error: "Specified token has
exceeded its maximum lifetime
".
The configured maximumPageSize
determines how many results
can be returned in a single call.
Parameter reverseOrder
:
When set to true
, returns the results in reverse order. By
default the results are returned in descending order of the start or the
close time of the executions.
Parameter startTimeFilter
:
If specified, the workflow executions are included in the returned results
based on whether their start times are within the range specified by this
filter. Also, if this parameter is specified, the returned results are
ordered by their start times.
Parameter tagFilter
:
If specified, only executions that have the matching tag are listed.
Parameter typeFilter
:
If specified, only executions of the type specified in the filter are
returned.
Implementation
Future<WorkflowExecutionInfos> listClosedWorkflowExecutions({
required String domain,
CloseStatusFilter? closeStatusFilter,
ExecutionTimeFilter? closeTimeFilter,
WorkflowExecutionFilter? executionFilter,
int? maximumPageSize,
String? nextPageToken,
bool? reverseOrder,
ExecutionTimeFilter? startTimeFilter,
TagFilter? tagFilter,
WorkflowTypeFilter? typeFilter,
}) async {
ArgumentError.checkNotNull(domain, 'domain');
_s.validateStringLength(
'domain',
domain,
1,
256,
isRequired: true,
);
_s.validateNumRange(
'maximumPageSize',
maximumPageSize,
0,
1000,
);
_s.validateStringLength(
'nextPageToken',
nextPageToken,
0,
2048,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.0',
'X-Amz-Target': 'SimpleWorkflowService.ListClosedWorkflowExecutions'
};
final jsonResponse = await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'domain': domain,
if (closeStatusFilter != null) 'closeStatusFilter': closeStatusFilter,
if (closeTimeFilter != null) 'closeTimeFilter': closeTimeFilter,
if (executionFilter != null) 'executionFilter': executionFilter,
if (maximumPageSize != null) 'maximumPageSize': maximumPageSize,
if (nextPageToken != null) 'nextPageToken': nextPageToken,
if (reverseOrder != null) 'reverseOrder': reverseOrder,
if (startTimeFilter != null) 'startTimeFilter': startTimeFilter,
if (tagFilter != null) 'tagFilter': tagFilter,
if (typeFilter != null) 'typeFilter': typeFilter,
},
);
return WorkflowExecutionInfos.fromJson(jsonResponse.body);
}