Table of Contents
SFN.
Client
¶A low-level client representing AWS Step Functions (SFN)
Step Functions is a service that lets you coordinate the components of distributed applications and microservices using visual workflows.
You can use Step Functions to build applications from individual components, each of which performs a discrete function, or task , allowing you to scale and change applications quickly. Step Functions provides a console that helps visualize the components of your application as a series of steps. Step Functions automatically triggers and tracks each step, and retries steps when there are errors, so your application executes predictably and in the right order every time. Step Functions logs the state of each step, so you can quickly diagnose and debug any issues.
Step Functions manages operations and underlying infrastructure to ensure your application is available at any scale. You can run tasks on Amazon Web Services, your own servers, or any system that has access to Amazon Web Services. You can access and use Step Functions using the console, the Amazon Web Services SDKs, or an HTTP API. For more information about Step Functions, see the Step Functions Developer Guide .
import boto3
client = boto3.client('stepfunctions')
These are the available methods:
can_paginate()
close()
create_activity()
create_state_machine()
delete_activity()
delete_state_machine()
describe_activity()
describe_execution()
describe_map_run()
describe_state_machine()
describe_state_machine_for_execution()
get_activity_task()
get_execution_history()
get_paginator()
get_waiter()
list_activities()
list_executions()
list_map_runs()
list_state_machines()
list_tags_for_resource()
send_task_failure()
send_task_heartbeat()
send_task_success()
start_execution()
start_sync_execution()
stop_execution()
tag_resource()
untag_resource()
update_map_run()
update_state_machine()
can_paginate
(operation_name)¶Check if an operation can be paginated.
create_foo
, and you'd normally invoke the
operation as client.create_foo(**kwargs)
, if the
create_foo
operation can be paginated, you can use the
call client.get_paginator("create_foo")
.True
if the operation can be paginated,
False
otherwise.close
()¶Closes underlying endpoint connections.
create_activity
(**kwargs)¶Creates an activity. An activity is a task that you write in any programming language and host on any machine that has access to Step Functions. Activities must poll Step Functions using the GetActivityTask
API action and respond using SendTask*
API actions. This function lets Step Functions know the existence of your activity and returns an identifier for use in a state machine and when polling from the activity.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
Note
CreateActivity
is an idempotent API. Subsequent requests won’t create a duplicate resource if it was already created. CreateActivity
's idempotency check is based on the activity name
. If a following request has different tags
values, Step Functions will ignore these differences and treat it as an idempotent request of the previous. In this case, tags
will not be updated, even if they are different.
See also: AWS API Documentation
Request Syntax
response = client.create_activity(
name='string',
tags=[
{
'key': 'string',
'value': 'string'
},
]
)
[REQUIRED]
The name of the activity to create. This name must be unique for your Amazon Web Services account and region for 90 days. For more information, see Limits Related to State Machine Executions in the Step Functions Developer Guide .
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
The list of tags to add to a resource.
An array of key-value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide , and Controlling Access Using IAM Tags.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
Tags are key-value pairs that can be associated with Step Functions state machines and activities.
An array of key-value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide , and Controlling Access Using IAM Tags.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
The key of a tag.
The value of a tag.
dict
Response Syntax
{
'activityArn': 'string',
'creationDate': datetime(2015, 1, 1)
}
Response Structure
(dict) --
activityArn (string) --
The Amazon Resource Name (ARN) that identifies the created activity.
creationDate (datetime) --
The date the activity is created.
Exceptions
SFN.Client.exceptions.ActivityLimitExceeded
SFN.Client.exceptions.InvalidName
SFN.Client.exceptions.TooManyTags
create_state_machine
(**kwargs)¶Creates a state machine. A state machine consists of a collection of states that can do work ( Task
states), determine to which states to transition next ( Choice
states), stop an execution with an error ( Fail
states), and so on. State machines are specified using a JSON-based, structured language. For more information, see Amazon States Language in the Step Functions User Guide.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
Note
CreateStateMachine
is an idempotent API. Subsequent requests won’t create a duplicate resource if it was already created. CreateStateMachine
's idempotency check is based on the state machine name
, definition
, type
, LoggingConfiguration
and TracingConfiguration
. If a following request has a different roleArn
or tags
, Step Functions will ignore these differences and treat it as an idempotent request of the previous. In this case, roleArn
and tags
will not be updated, even if they are different.
See also: AWS API Documentation
Request Syntax
response = client.create_state_machine(
name='string',
definition='string',
roleArn='string',
type='STANDARD'|'EXPRESS',
loggingConfiguration={
'level': 'ALL'|'ERROR'|'FATAL'|'OFF',
'includeExecutionData': True|False,
'destinations': [
{
'cloudWatchLogsLogGroup': {
'logGroupArn': 'string'
}
},
]
},
tags=[
{
'key': 'string',
'value': 'string'
},
],
tracingConfiguration={
'enabled': True|False
}
)
[REQUIRED]
The name of the state machine.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
[REQUIRED]
The Amazon States Language definition of the state machine. See Amazon States Language.
[REQUIRED]
The Amazon Resource Name (ARN) of the IAM role to use for this state machine.
STANDARD
. You cannot update the type
of a state machine once it has been created.Defines what execution history events are logged and where they are logged.
Note
By default, the level
is set to OFF
. For more information see Log Levels in the Step Functions User Guide.
Defines which category of execution history events are logged.
Determines whether execution data is included in your log. When set to false
, data is excluded.
An array of objects that describes where your execution history events will be logged. Limited to size 1. Required, if your log level is not set to OFF
.
An object describing a CloudWatch log group. For more information, see AWS::Logs::LogGroup in the CloudFormation User Guide.
The ARN of the the CloudWatch log group to which you want your logs emitted to. The ARN must end with :*
Tags to be added when creating a state machine.
An array of key-value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide , and Controlling Access Using IAM Tags.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
Tags are key-value pairs that can be associated with Step Functions state machines and activities.
An array of key-value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide , and Controlling Access Using IAM Tags.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
The key of a tag.
The value of a tag.
Selects whether X-Ray tracing is enabled.
When set to true
, X-Ray tracing is enabled.
dict
Response Syntax
{
'stateMachineArn': 'string',
'creationDate': datetime(2015, 1, 1)
}
Response Structure
(dict) --
stateMachineArn (string) --
The Amazon Resource Name (ARN) that identifies the created state machine.
creationDate (datetime) --
The date the state machine is created.
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.InvalidDefinition
SFN.Client.exceptions.InvalidName
SFN.Client.exceptions.InvalidLoggingConfiguration
SFN.Client.exceptions.InvalidTracingConfiguration
SFN.Client.exceptions.StateMachineAlreadyExists
SFN.Client.exceptions.StateMachineDeleting
SFN.Client.exceptions.StateMachineLimitExceeded
SFN.Client.exceptions.StateMachineTypeNotSupported
SFN.Client.exceptions.TooManyTags
delete_activity
(**kwargs)¶Deletes an activity.
See also: AWS API Documentation
Request Syntax
response = client.delete_activity(
activityArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the activity to delete.
{}
Response Structure
Exceptions
SFN.Client.exceptions.InvalidArn
delete_state_machine
(**kwargs)¶Deletes a state machine. This is an asynchronous operation: It sets the state machine's status to DELETING
and begins the deletion process.
If the given state machine Amazon Resource Name (ARN) is a qualified state machine ARN, it will fail with ValidationException.
A qualified state machine ARN refers to a Distributed Map state defined within a state machine. For example, the qualified state machine ARN arn:partition:states:region:account-id:stateMachine:stateMachineName/mapStateLabel
refers to a Distributed Map state with a label mapStateLabel
in the state machine named stateMachineName
.
Note
For EXPRESS
state machines, the deletion will happen eventually (usually less than a minute). Running executions may emit logs after DeleteStateMachine
API is called.
See also: AWS API Documentation
Request Syntax
response = client.delete_state_machine(
stateMachineArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the state machine to delete.
{}
Response Structure
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.ValidationException
describe_activity
(**kwargs)¶Describes an activity.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
See also: AWS API Documentation
Request Syntax
response = client.describe_activity(
activityArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the activity to describe.
{
'activityArn': 'string',
'name': 'string',
'creationDate': datetime(2015, 1, 1)
}
Response Structure
The Amazon Resource Name (ARN) that identifies the activity.
The name of the activity.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
The date the activity is created.
Exceptions
SFN.Client.exceptions.ActivityDoesNotExist
SFN.Client.exceptions.InvalidArn
describe_execution
(**kwargs)¶Provides all information about a state machine execution, such as the state machine associated with the execution, the execution input and output, and relevant execution metadata. Use this API action to return the Map Run ARN if the execution was dispatched by a Map Run.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
This API action is not supported by EXPRESS
state machine executions unless they were dispatched by a Map Run.
See also: AWS API Documentation
Request Syntax
response = client.describe_execution(
executionArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the execution to describe.
{
'executionArn': 'string',
'stateMachineArn': 'string',
'name': 'string',
'status': 'RUNNING'|'SUCCEEDED'|'FAILED'|'TIMED_OUT'|'ABORTED',
'startDate': datetime(2015, 1, 1),
'stopDate': datetime(2015, 1, 1),
'input': 'string',
'inputDetails': {
'included': True|False
},
'output': 'string',
'outputDetails': {
'included': True|False
},
'traceHeader': 'string',
'mapRunArn': 'string',
'error': 'string',
'cause': 'string'
}
Response Structure
The Amazon Resource Name (ARN) that identifies the execution.
The Amazon Resource Name (ARN) of the executed stated machine.
The name of the execution.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
The current status of the execution.
The date the execution is started.
If the execution has already ended, the date the execution stopped.
The string that contains the JSON input data of the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
Provides details about execution input or output.
Indicates whether input or output was included in the response. Always true
for API calls.
The JSON output data of the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
Note
This field is set only if the execution succeeds. If the execution fails, this field is null.
Provides details about execution input or output.
Indicates whether input or output was included in the response. Always true
for API calls.
The X-Ray trace header that was passed to the execution.
The Amazon Resource Name (ARN) that identifies a Map Run, which dispatched this execution.
The error string if the state machine execution failed.
The cause string if the state machine execution failed.
Exceptions
SFN.Client.exceptions.ExecutionDoesNotExist
SFN.Client.exceptions.InvalidArn
describe_map_run
(**kwargs)¶Provides information about a Map Run's configuration, progress, and results. For more information, see Examining Map Run in the Step Functions Developer Guide .
See also: AWS API Documentation
Request Syntax
response = client.describe_map_run(
mapRunArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) that identifies a Map Run.
{
'mapRunArn': 'string',
'executionArn': 'string',
'status': 'RUNNING'|'SUCCEEDED'|'FAILED'|'ABORTED',
'startDate': datetime(2015, 1, 1),
'stopDate': datetime(2015, 1, 1),
'maxConcurrency': 123,
'toleratedFailurePercentage': ...,
'toleratedFailureCount': 123,
'itemCounts': {
'pending': 123,
'running': 123,
'succeeded': 123,
'failed': 123,
'timedOut': 123,
'aborted': 123,
'total': 123,
'resultsWritten': 123
},
'executionCounts': {
'pending': 123,
'running': 123,
'succeeded': 123,
'failed': 123,
'timedOut': 123,
'aborted': 123,
'total': 123,
'resultsWritten': 123
}
}
Response Structure
The Amazon Resource Name (ARN) that identifies a Map Run.
The Amazon Resource Name (ARN) that identifies the execution in which the Map Run was started.
The current status of the Map Run.
The date when the Map Run was started.
The date when the Map Run was stopped.
The maximum number of child workflow executions configured to run in parallel for the Map Run at the same time.
The maximum percentage of failed child workflow executions before the Map Run fails.
The maximum number of failed child workflow executions before the Map Run fails.
A JSON object that contains information about the total number of items, and the item count for each processing status, such as pending
and failed
.
The total number of items to process in child workflow executions that haven't started running yet.
The total number of items being processed in child workflow executions that are currently in-progress.
The total number of items processed in child workflow executions that have completed successfully.
The total number of items processed in child workflow executions that have failed.
The total number of items processed in child workflow executions that have timed out.
The total number of items processed in child workflow executions that were either stopped by the user or by Step Functions, because the Map Run failed.
The total number of items processed in all the child workflow executions started by a Map Run.
Returns the count of items whose results were written by ResultWriter
. For more information, see ResultWriter in the Step Functions Developer Guide .
A JSON object that contains information about the total number of child workflow executions for the Map Run, and the count of child workflow executions for each status, such as failed
and succeeded
.
The total number of child workflow executions that were started by a Map Run, but haven't started executing yet.
The total number of child workflow executions that were started by a Map Run and are currently in-progress.
The total number of child workflow executions that were started by a Map Run and have completed successfully.
The total number of child workflow executions that were started by a Map Run, but have failed.
The total number of child workflow executions that were started by a Map Run and have timed out.
The total number of child workflow executions that were started by a Map Run and were running, but were either stopped by the user or by Step Functions because the Map Run failed.
The total number of child workflow executions that were started by a Map Run.
Returns the count of child workflow executions whose results were written by ResultWriter
. For more information, see ResultWriter in the Step Functions Developer Guide .
Exceptions
SFN.Client.exceptions.ResourceNotFound
SFN.Client.exceptions.InvalidArn
describe_state_machine
(**kwargs)¶Provides information about a state machine's definition, its IAM role Amazon Resource Name (ARN), and configuration. If the state machine ARN is a qualified state machine ARN, the response returned includes the Map
state's label.
A qualified state machine ARN refers to a Distributed Map state defined within a state machine. For example, the qualified state machine ARN arn:partition:states:region:account-id:stateMachine:stateMachineName/mapStateLabel
refers to a Distributed Map state with a label mapStateLabel
in the state machine named stateMachineName
.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
See also: AWS API Documentation
Request Syntax
response = client.describe_state_machine(
stateMachineArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the state machine to describe.
{
'stateMachineArn': 'string',
'name': 'string',
'status': 'ACTIVE'|'DELETING',
'definition': 'string',
'roleArn': 'string',
'type': 'STANDARD'|'EXPRESS',
'creationDate': datetime(2015, 1, 1),
'loggingConfiguration': {
'level': 'ALL'|'ERROR'|'FATAL'|'OFF',
'includeExecutionData': True|False,
'destinations': [
{
'cloudWatchLogsLogGroup': {
'logGroupArn': 'string'
}
},
]
},
'tracingConfiguration': {
'enabled': True|False
},
'label': 'string'
}
Response Structure
The Amazon Resource Name (ARN) that identifies the state machine.
The name of the state machine.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
The current status of the state machine.
The Amazon States Language definition of the state machine. See Amazon States Language.
The Amazon Resource Name (ARN) of the IAM role used when creating this state machine. (The IAM role maintains security by granting Step Functions access to Amazon Web Services resources.)
The type
of the state machine ( STANDARD
or EXPRESS
).
The date the state machine is created.
The LoggingConfiguration
data type is used to set CloudWatch Logs options.
Defines which category of execution history events are logged.
Determines whether execution data is included in your log. When set to false
, data is excluded.
An array of objects that describes where your execution history events will be logged. Limited to size 1. Required, if your log level is not set to OFF
.
An object describing a CloudWatch log group. For more information, see AWS::Logs::LogGroup in the CloudFormation User Guide.
The ARN of the the CloudWatch log group to which you want your logs emitted to. The ARN must end with :*
Selects whether X-Ray tracing is enabled.
When set to true
, X-Ray tracing is enabled.
A user-defined or an auto-generated string that identifies a Map
state. This parameter is present only if the stateMachineArn
specified in input is a qualified state machine ARN.
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.StateMachineDoesNotExist
describe_state_machine_for_execution
(**kwargs)¶Provides information about a state machine's definition, its execution role ARN, and configuration. If an execution was dispatched by a Map Run, the Map Run is returned in the response. Additionally, the state machine returned will be the state machine associated with the Map Run.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
This API action is not supported by EXPRESS
state machines.
See also: AWS API Documentation
Request Syntax
response = client.describe_state_machine_for_execution(
executionArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the execution you want state machine information for.
{
'stateMachineArn': 'string',
'name': 'string',
'definition': 'string',
'roleArn': 'string',
'updateDate': datetime(2015, 1, 1),
'loggingConfiguration': {
'level': 'ALL'|'ERROR'|'FATAL'|'OFF',
'includeExecutionData': True|False,
'destinations': [
{
'cloudWatchLogsLogGroup': {
'logGroupArn': 'string'
}
},
]
},
'tracingConfiguration': {
'enabled': True|False
},
'mapRunArn': 'string',
'label': 'string'
}
Response Structure
The Amazon Resource Name (ARN) of the state machine associated with the execution.
The name of the state machine associated with the execution.
The Amazon States Language definition of the state machine. See Amazon States Language.
The Amazon Resource Name (ARN) of the IAM role of the State Machine for the execution.
The date and time the state machine associated with an execution was updated. For a newly created state machine, this is the creation date.
The LoggingConfiguration
data type is used to set CloudWatch Logs options.
Defines which category of execution history events are logged.
Determines whether execution data is included in your log. When set to false
, data is excluded.
An array of objects that describes where your execution history events will be logged. Limited to size 1. Required, if your log level is not set to OFF
.
An object describing a CloudWatch log group. For more information, see AWS::Logs::LogGroup in the CloudFormation User Guide.
The ARN of the the CloudWatch log group to which you want your logs emitted to. The ARN must end with :*
Selects whether X-Ray tracing is enabled.
When set to true
, X-Ray tracing is enabled.
The Amazon Resource Name (ARN) of the Map Run that started the child workflow execution. This field is returned only if the executionArn
is a child workflow execution that was started by a Distributed Map state.
A user-defined or an auto-generated string that identifies a Map
state. This field is returned only if the executionArn
is a child workflow execution that was started by a Distributed Map state.
Exceptions
SFN.Client.exceptions.ExecutionDoesNotExist
SFN.Client.exceptions.InvalidArn
get_activity_task
(**kwargs)¶Used by workers to retrieve a task (with the specified activity ARN) which has been scheduled for execution by a running state machine. This initiates a long poll, where the service holds the HTTP connection open and responds as soon as a task becomes available (i.e. an execution of a task of this type is needed.) The maximum time the service holds on to the request before responding is 60 seconds. If no task is available within 60 seconds, the poll returns a taskToken
with a null string.
Note
This API action isn't logged in CloudTrail.
Warning
Workers should set their client side socket timeout to at least 65 seconds (5 seconds higher than the maximum time the service may hold the poll request).
Polling with GetActivityTask
can cause latency in some implementations. See Avoid Latency When Polling for Activity Tasks in the Step Functions Developer Guide.
See also: AWS API Documentation
Request Syntax
response = client.get_activity_task(
activityArn='string',
workerName='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the activity to retrieve tasks from (assigned when you create the task using CreateActivity.)
dict
Response Syntax
{
'taskToken': 'string',
'input': 'string'
}
Response Structure
(dict) --
taskToken (string) --
A token that identifies the scheduled task. This token must be copied and included in subsequent calls to SendTaskHeartbeat, SendTaskSuccess or SendTaskFailure in order to report the progress or completion of the task.
input (string) --
The string that contains the JSON input data for the task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
Exceptions
SFN.Client.exceptions.ActivityDoesNotExist
SFN.Client.exceptions.ActivityWorkerLimitExceeded
SFN.Client.exceptions.InvalidArn
get_execution_history
(**kwargs)¶Returns the history of the specified execution as a list of events. By default, the results are returned in ascending order of the timeStamp
of the events. Use the reverseOrder
parameter to get the latest events first.
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
This API action is not supported by EXPRESS
state machines.
See also: AWS API Documentation
Request Syntax
response = client.get_execution_history(
executionArn='string',
maxResults=123,
reverseOrder=True|False,
nextToken='string',
includeExecutionData=True|False
)
[REQUIRED]
The Amazon Resource Name (ARN) of the execution.
The maximum number of results that are returned per call. You can use nextToken
to obtain further pages of results. The default is 100 and the maximum allowed page size is 1000. A value of 0 uses the default.
This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.
timeStamp
.nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.true
.dict
Response Syntax
{
'events': [
{
'timestamp': datetime(2015, 1, 1),
'type': 'ActivityFailed'|'ActivityScheduled'|'ActivityScheduleFailed'|'ActivityStarted'|'ActivitySucceeded'|'ActivityTimedOut'|'ChoiceStateEntered'|'ChoiceStateExited'|'ExecutionAborted'|'ExecutionFailed'|'ExecutionStarted'|'ExecutionSucceeded'|'ExecutionTimedOut'|'FailStateEntered'|'LambdaFunctionFailed'|'LambdaFunctionScheduled'|'LambdaFunctionScheduleFailed'|'LambdaFunctionStarted'|'LambdaFunctionStartFailed'|'LambdaFunctionSucceeded'|'LambdaFunctionTimedOut'|'MapIterationAborted'|'MapIterationFailed'|'MapIterationStarted'|'MapIterationSucceeded'|'MapStateAborted'|'MapStateEntered'|'MapStateExited'|'MapStateFailed'|'MapStateStarted'|'MapStateSucceeded'|'ParallelStateAborted'|'ParallelStateEntered'|'ParallelStateExited'|'ParallelStateFailed'|'ParallelStateStarted'|'ParallelStateSucceeded'|'PassStateEntered'|'PassStateExited'|'SucceedStateEntered'|'SucceedStateExited'|'TaskFailed'|'TaskScheduled'|'TaskStarted'|'TaskStartFailed'|'TaskStateAborted'|'TaskStateEntered'|'TaskStateExited'|'TaskSubmitFailed'|'TaskSubmitted'|'TaskSucceeded'|'TaskTimedOut'|'WaitStateAborted'|'WaitStateEntered'|'WaitStateExited'|'MapRunAborted'|'MapRunFailed'|'MapRunStarted'|'MapRunSucceeded',
'id': 123,
'previousEventId': 123,
'activityFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'activityScheduleFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'activityScheduledEventDetails': {
'resource': 'string',
'input': 'string',
'inputDetails': {
'truncated': True|False
},
'timeoutInSeconds': 123,
'heartbeatInSeconds': 123
},
'activityStartedEventDetails': {
'workerName': 'string'
},
'activitySucceededEventDetails': {
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'activityTimedOutEventDetails': {
'error': 'string',
'cause': 'string'
},
'taskFailedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'taskScheduledEventDetails': {
'resourceType': 'string',
'resource': 'string',
'region': 'string',
'parameters': 'string',
'timeoutInSeconds': 123,
'heartbeatInSeconds': 123,
'taskCredentials': {
'roleArn': 'string'
}
},
'taskStartFailedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'taskStartedEventDetails': {
'resourceType': 'string',
'resource': 'string'
},
'taskSubmitFailedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'taskSubmittedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'taskSucceededEventDetails': {
'resourceType': 'string',
'resource': 'string',
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'taskTimedOutEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'executionFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'executionStartedEventDetails': {
'input': 'string',
'inputDetails': {
'truncated': True|False
},
'roleArn': 'string'
},
'executionSucceededEventDetails': {
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'executionAbortedEventDetails': {
'error': 'string',
'cause': 'string'
},
'executionTimedOutEventDetails': {
'error': 'string',
'cause': 'string'
},
'mapStateStartedEventDetails': {
'length': 123
},
'mapIterationStartedEventDetails': {
'name': 'string',
'index': 123
},
'mapIterationSucceededEventDetails': {
'name': 'string',
'index': 123
},
'mapIterationFailedEventDetails': {
'name': 'string',
'index': 123
},
'mapIterationAbortedEventDetails': {
'name': 'string',
'index': 123
},
'lambdaFunctionFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'lambdaFunctionScheduleFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'lambdaFunctionScheduledEventDetails': {
'resource': 'string',
'input': 'string',
'inputDetails': {
'truncated': True|False
},
'timeoutInSeconds': 123,
'taskCredentials': {
'roleArn': 'string'
}
},
'lambdaFunctionStartFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'lambdaFunctionSucceededEventDetails': {
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'lambdaFunctionTimedOutEventDetails': {
'error': 'string',
'cause': 'string'
},
'stateEnteredEventDetails': {
'name': 'string',
'input': 'string',
'inputDetails': {
'truncated': True|False
}
},
'stateExitedEventDetails': {
'name': 'string',
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'mapRunStartedEventDetails': {
'mapRunArn': 'string'
},
'mapRunFailedEventDetails': {
'error': 'string',
'cause': 'string'
}
},
],
'nextToken': 'string'
}
Response Structure
(dict) --
events (list) --
The list of events that occurred in the execution.
(dict) --
Contains details about the events of an execution.
timestamp (datetime) --
The date and time the event occurred.
type (string) --
The type of the event.
id (integer) --
The id of the event. Events are numbered sequentially, starting at one.
previousEventId (integer) --
The id of the previous event.
activityFailedEventDetails (dict) --
Contains details about an activity that failed during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
activityScheduleFailedEventDetails (dict) --
Contains details about an activity schedule event that failed during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
activityScheduledEventDetails (dict) --
Contains details about an activity scheduled during an execution.
resource (string) --
The Amazon Resource Name (ARN) of the scheduled activity.
input (string) --
The JSON data input to the activity task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about the input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
timeoutInSeconds (integer) --
The maximum allowed duration of the activity task.
heartbeatInSeconds (integer) --
The maximum allowed duration between two heartbeats for the activity task.
activityStartedEventDetails (dict) --
Contains details about the start of an activity during an execution.
workerName (string) --
The name of the worker that the task is assigned to. These names are provided by the workers when calling GetActivityTask.
activitySucceededEventDetails (dict) --
Contains details about an activity that successfully terminated during an execution.
output (string) --
The JSON data output by the activity task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
activityTimedOutEventDetails (dict) --
Contains details about an activity timeout that occurred during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the timeout.
taskFailedEventDetails (dict) --
Contains details about the failure of a task.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
taskScheduledEventDetails (dict) --
Contains details about a task that was scheduled.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
region (string) --
The region of the scheduled task
parameters (string) --
The JSON data passed to the resource referenced in a task state. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
timeoutInSeconds (integer) --
The maximum allowed duration of the task.
heartbeatInSeconds (integer) --
The maximum allowed duration between two heartbeats for the task.
taskCredentials (dict) --
The credentials that Step Functions uses for the task.
roleArn (string) --
The ARN of an IAM role that Step Functions assumes for the task. The role can allow cross-account access to resources.
taskStartFailedEventDetails (dict) --
Contains details about a task that failed to start.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
taskStartedEventDetails (dict) --
Contains details about a task that was started.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
taskSubmitFailedEventDetails (dict) --
Contains details about a task that where the submit failed.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
taskSubmittedEventDetails (dict) --
Contains details about a submitted task.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
output (string) --
The response from a resource when a task has started. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
taskSucceededEventDetails (dict) --
Contains details about a task that succeeded.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
output (string) --
The full JSON response from a resource when a task has succeeded. This response becomes the output of the related task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
taskTimedOutEventDetails (dict) --
Contains details about a task that timed out.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
executionFailedEventDetails (dict) --
Contains details about an execution failure event.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
executionStartedEventDetails (dict) --
Contains details about the start of the execution.
input (string) --
The JSON data input to the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about the input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
roleArn (string) --
The Amazon Resource Name (ARN) of the IAM role used for executing Lambda tasks.
executionSucceededEventDetails (dict) --
Contains details about the successful termination of the execution.
output (string) --
The JSON data output by the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
executionAbortedEventDetails (dict) --
Contains details about an abort of an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
executionTimedOutEventDetails (dict) --
Contains details about the execution timeout that occurred during the execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the timeout.
mapStateStartedEventDetails (dict) --
Contains details about Map state that was started.
length (integer) --
The size of the array for Map state iterations.
mapIterationStartedEventDetails (dict) --
Contains details about an iteration of a Map state that was started.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
mapIterationSucceededEventDetails (dict) --
Contains details about an iteration of a Map state that succeeded.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
mapIterationFailedEventDetails (dict) --
Contains details about an iteration of a Map state that failed.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
mapIterationAbortedEventDetails (dict) --
Contains details about an iteration of a Map state that was aborted.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
lambdaFunctionFailedEventDetails (dict) --
Contains details about a Lambda function that failed during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
lambdaFunctionScheduleFailedEventDetails (dict) --
Contains details about a failed Lambda function schedule event that occurred during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
lambdaFunctionScheduledEventDetails (dict) --
Contains details about a Lambda function scheduled during an execution.
resource (string) --
The Amazon Resource Name (ARN) of the scheduled Lambda function.
input (string) --
The JSON data input to the Lambda function. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
timeoutInSeconds (integer) --
The maximum allowed duration of the Lambda function.
taskCredentials (dict) --
The credentials that Step Functions uses for the task.
roleArn (string) --
The ARN of an IAM role that Step Functions assumes for the task. The role can allow cross-account access to resources.
lambdaFunctionStartFailedEventDetails (dict) --
Contains details about a lambda function that failed to start during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
lambdaFunctionSucceededEventDetails (dict) --
Contains details about a Lambda function that terminated successfully during an execution.
output (string) --
The JSON data output by the Lambda function. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
lambdaFunctionTimedOutEventDetails (dict) --
Contains details about a Lambda function timeout that occurred during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the timeout.
stateEnteredEventDetails (dict) --
Contains details about a state entered during an execution.
name (string) --
The name of the state.
input (string) --
The string that contains the JSON input data for the state. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about the input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
stateExitedEventDetails (dict) --
Contains details about an exit from a state during an execution.
name (string) --
The name of the state.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
output (string) --
The JSON output data of the state. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
mapRunStartedEventDetails (dict) --
Contains details, such as mapRunArn
, and the start date and time of a Map Run. mapRunArn
is the Amazon Resource Name (ARN) of the Map Run that was started.
mapRunArn (string) --
The Amazon Resource Name (ARN) of a Map Run that was started.
mapRunFailedEventDetails (dict) --
Contains error and cause details about a Map Run that failed.
error (string) --
The error code of the Map Run failure.
cause (string) --
A more detailed explanation of the cause of the failure.
nextToken (string) --
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Exceptions
SFN.Client.exceptions.ExecutionDoesNotExist
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.InvalidToken
get_paginator
(operation_name)¶Create a paginator for an operation.
create_foo
, and you'd normally invoke the
operation as client.create_foo(**kwargs)
, if the
create_foo
operation can be paginated, you can use the
call client.get_paginator("create_foo")
.client.can_paginate
method to
check if an operation is pageable.get_waiter
(waiter_name)¶Returns an object that can wait for some condition.
list_activities
(**kwargs)¶Lists the existing activities.
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
See also: AWS API Documentation
Request Syntax
response = client.list_activities(
maxResults=123,
nextToken='string'
)
The maximum number of results that are returned per call. You can use nextToken
to obtain further pages of results. The default is 100 and the maximum allowed page size is 1000. A value of 0 uses the default.
This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.
nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.dict
Response Syntax
{
'activities': [
{
'activityArn': 'string',
'name': 'string',
'creationDate': datetime(2015, 1, 1)
},
],
'nextToken': 'string'
}
Response Structure
(dict) --
activities (list) --
The list of activities.
(dict) --
Contains details about an activity.
activityArn (string) --
The Amazon Resource Name (ARN) that identifies the activity.
name (string) --
The name of the activity.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
creationDate (datetime) --
The date the activity is created.
nextToken (string) --
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Exceptions
SFN.Client.exceptions.InvalidToken
list_executions
(**kwargs)¶Lists all executions of a state machine or a Map Run. You can list all executions related to a state machine by specifying a state machine Amazon Resource Name (ARN), or those related to a Map Run by specifying a Map Run ARN.
Results are sorted by time, with the most recent execution first.
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
This API action is not supported by EXPRESS
state machines.
See also: AWS API Documentation
Request Syntax
response = client.list_executions(
stateMachineArn='string',
statusFilter='RUNNING'|'SUCCEEDED'|'FAILED'|'TIMED_OUT'|'ABORTED',
maxResults=123,
nextToken='string',
mapRunArn='string'
)
The Amazon Resource Name (ARN) of the state machine whose executions is listed.
You can specify either a mapRunArn
or a stateMachineArn
, but not both.
The maximum number of results that are returned per call. You can use nextToken
to obtain further pages of results. The default is 100 and the maximum allowed page size is 1000. A value of 0 uses the default.
This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.
nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.The Amazon Resource Name (ARN) of the Map Run that started the child workflow executions. If the mapRunArn
field is specified, a list of all of the child workflow executions started by a Map Run is returned. For more information, see Examining Map Run in the Step Functions Developer Guide .
You can specify either a mapRunArn
or a stateMachineArn
, but not both.
dict
Response Syntax
{
'executions': [
{
'executionArn': 'string',
'stateMachineArn': 'string',
'name': 'string',
'status': 'RUNNING'|'SUCCEEDED'|'FAILED'|'TIMED_OUT'|'ABORTED',
'startDate': datetime(2015, 1, 1),
'stopDate': datetime(2015, 1, 1),
'mapRunArn': 'string',
'itemCount': 123
},
],
'nextToken': 'string'
}
Response Structure
(dict) --
executions (list) --
The list of matching executions.
(dict) --
Contains details about an execution.
executionArn (string) --
The Amazon Resource Name (ARN) that identifies the execution.
stateMachineArn (string) --
The Amazon Resource Name (ARN) of the executed state machine.
name (string) --
The name of the execution.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
status (string) --
The current status of the execution.
startDate (datetime) --
The date the execution started.
stopDate (datetime) --
If the execution already ended, the date the execution stopped.
mapRunArn (string) --
The Amazon Resource Name (ARN) of a Map Run. This field is returned only if mapRunArn
was specified in the ListExecutions
API action. If stateMachineArn
was specified in ListExecutions
, the mapRunArn
isn't returned.
itemCount (integer) --
The total number of items processed in a child workflow execution. This field is returned only if mapRunArn
was specified in the ListExecutions
API action. If stateMachineArn
was specified in ListExecutions
, the itemCount
field isn't returned.
nextToken (string) --
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.InvalidToken
SFN.Client.exceptions.StateMachineDoesNotExist
SFN.Client.exceptions.StateMachineTypeNotSupported
SFN.Client.exceptions.ValidationException
SFN.Client.exceptions.ResourceNotFound
list_map_runs
(**kwargs)¶Lists all Map Runs that were started by a given state machine execution. Use this API action to obtain Map Run ARNs, and then call DescribeMapRun
to obtain more information, if needed.
See also: AWS API Documentation
Request Syntax
response = client.list_map_runs(
executionArn='string',
maxResults=123,
nextToken='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the execution for which the Map Runs must be listed.
The maximum number of results that are returned per call. You can use nextToken
to obtain further pages of results. The default is 100 and the maximum allowed page size is 1000. A value of 0 uses the default.
This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.
nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.dict
Response Syntax
{
'mapRuns': [
{
'executionArn': 'string',
'mapRunArn': 'string',
'stateMachineArn': 'string',
'startDate': datetime(2015, 1, 1),
'stopDate': datetime(2015, 1, 1)
},
],
'nextToken': 'string'
}
Response Structure
(dict) --
mapRuns (list) --
An array that lists information related to a Map Run, such as the Amazon Resource Name (ARN) of the Map Run and the ARN of the state machine that started the Map Run.
(dict) --
Contains details about a specific Map Run.
executionArn (string) --
The executionArn
of the execution from which the Map Run was started.
mapRunArn (string) --
The Amazon Resource Name (ARN) of the Map Run.
stateMachineArn (string) --
The Amazon Resource Name (ARN) of the executed state machine.
startDate (datetime) --
The date on which the Map Run started.
stopDate (datetime) --
The date on which the Map Run stopped.
nextToken (string) --
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Exceptions
SFN.Client.exceptions.ExecutionDoesNotExist
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.InvalidToken
list_state_machines
(**kwargs)¶Lists the existing state machines.
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Note
This operation is eventually consistent. The results are best effort and may not reflect very recent updates and changes.
See also: AWS API Documentation
Request Syntax
response = client.list_state_machines(
maxResults=123,
nextToken='string'
)
The maximum number of results that are returned per call. You can use nextToken
to obtain further pages of results. The default is 100 and the maximum allowed page size is 1000. A value of 0 uses the default.
This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.
nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.dict
Response Syntax
{
'stateMachines': [
{
'stateMachineArn': 'string',
'name': 'string',
'type': 'STANDARD'|'EXPRESS',
'creationDate': datetime(2015, 1, 1)
},
],
'nextToken': 'string'
}
Response Structure
(dict) --
stateMachines (list) --
(dict) --
Contains details about the state machine.
stateMachineArn (string) --
The Amazon Resource Name (ARN) that identifies the state machine.
name (string) --
The name of the state machine.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
type (string) --
creationDate (datetime) --
The date the state machine is created.
nextToken (string) --
If nextToken
is returned, there are more results available. The value of nextToken
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 24 hours. Using an expired pagination token will return an HTTP 400 InvalidToken error.
Exceptions
SFN.Client.exceptions.InvalidToken
List tags for a given resource.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
See also: AWS API Documentation
Request Syntax
response = client.list_tags_for_resource(
resourceArn='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) for the Step Functions state machine or activity.
{
'tags': [
{
'key': 'string',
'value': 'string'
},
]
}
Response Structure
An array of tags associated with the resource.
Tags are key-value pairs that can be associated with Step Functions state machines and activities.
An array of key-value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide , and Controlling Access Using IAM Tags.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
The key of a tag.
The value of a tag.
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.ResourceNotFound
send_task_failure
(**kwargs)¶Used by activity workers and task states using the callback pattern to report that the task identified by the taskToken
failed.
See also: AWS API Documentation
Request Syntax
response = client.send_task_failure(
taskToken='string',
error='string',
cause='string'
)
[REQUIRED]
The token that represents this task. Task tokens are generated by Step Functions when tasks are assigned to a worker, or in the context object when a workflow enters a task state. See GetActivityTaskOutput$taskToken.
dict
Response Syntax
{}
Response Structure
Exceptions
SFN.Client.exceptions.TaskDoesNotExist
SFN.Client.exceptions.InvalidToken
SFN.Client.exceptions.TaskTimedOut
send_task_heartbeat
(**kwargs)¶Used by activity workers and task states using the callback pattern to report to Step Functions that the task represented by the specified taskToken
is still making progress. This action resets the Heartbeat
clock. The Heartbeat
threshold is specified in the state machine's Amazon States Language definition ( HeartbeatSeconds
). This action does not in itself create an event in the execution history. However, if the task times out, the execution history contains an ActivityTimedOut
entry for activities, or a TaskTimedOut
entry for for tasks using the job run or callback pattern.
Note
The Timeout
of a task, defined in the state machine's Amazon States Language definition, is its maximum allowed duration, regardless of the number of SendTaskHeartbeat requests received. Use HeartbeatSeconds
to configure the timeout interval for heartbeats.
See also: AWS API Documentation
Request Syntax
response = client.send_task_heartbeat(
taskToken='string'
)
[REQUIRED]
The token that represents this task. Task tokens are generated by Step Functions when tasks are assigned to a worker, or in the context object when a workflow enters a task state. See GetActivityTaskOutput$taskToken.
{}
Response Structure
Exceptions
SFN.Client.exceptions.TaskDoesNotExist
SFN.Client.exceptions.InvalidToken
SFN.Client.exceptions.TaskTimedOut
send_task_success
(**kwargs)¶Used by activity workers and task states using the callback pattern to report that the task identified by the taskToken
completed successfully.
See also: AWS API Documentation
Request Syntax
response = client.send_task_success(
taskToken='string',
output='string'
)
[REQUIRED]
The token that represents this task. Task tokens are generated by Step Functions when tasks are assigned to a worker, or in the context object when a workflow enters a task state. See GetActivityTaskOutput$taskToken.
[REQUIRED]
The JSON output of the task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
dict
Response Syntax
{}
Response Structure
Exceptions
SFN.Client.exceptions.TaskDoesNotExist
SFN.Client.exceptions.InvalidOutput
SFN.Client.exceptions.InvalidToken
SFN.Client.exceptions.TaskTimedOut
start_execution
(**kwargs)¶Starts a state machine execution. If the given state machine Amazon Resource Name (ARN) is a qualified state machine ARN, it will fail with ValidationException.
A qualified state machine ARN refers to a Distributed Map state defined within a state machine. For example, the qualified state machine ARN arn:partition:states:region:account-id:stateMachine:stateMachineName/mapStateLabel
refers to a Distributed Map state with a label mapStateLabel
in the state machine named stateMachineName
.
Note
StartExecution
is idempotent for STANDARD
workflows. For a STANDARD
workflow, if StartExecution
is called with the same name and input as a running execution, the call will succeed and return the same response as the original request. If the execution is closed or if the input is different, it will return a 400 ExecutionAlreadyExists
error. Names can be reused after 90 days.
StartExecution
is not idempotent for EXPRESS
workflows.
See also: AWS API Documentation
Request Syntax
response = client.start_execution(
stateMachineArn='string',
name='string',
input='string',
traceHeader='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the state machine to execute.
The name of the execution. This name must be unique for your Amazon Web Services account, region, and state machine for 90 days. For more information, see Limits Related to State Machine Executions in the Step Functions Developer Guide .
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
The string that contains the JSON input data for the execution, for example:
"input": "{\"first_name\" : \"test\"}"
Note
If you don't include any JSON input data, you still must include the two braces, for example: "input": "{}"
Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
dict
Response Syntax
{
'executionArn': 'string',
'startDate': datetime(2015, 1, 1)
}
Response Structure
(dict) --
executionArn (string) --
The Amazon Resource Name (ARN) that identifies the execution.
startDate (datetime) --
The date the execution is started.
Exceptions
SFN.Client.exceptions.ExecutionLimitExceeded
SFN.Client.exceptions.ExecutionAlreadyExists
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.InvalidExecutionInput
SFN.Client.exceptions.InvalidName
SFN.Client.exceptions.StateMachineDoesNotExist
SFN.Client.exceptions.StateMachineDeleting
SFN.Client.exceptions.ValidationException
start_sync_execution
(**kwargs)¶Starts a Synchronous Express state machine execution. StartSyncExecution
is not available for STANDARD
workflows.
Note
StartSyncExecution
will return a 200 OK
response, even if your execution fails, because the status code in the API response doesn't reflect function errors. Error codes are reserved for errors that prevent your execution from running, such as permissions errors, limit errors, or issues with your state machine code and configuration.
Note
This API action isn't logged in CloudTrail.
See also: AWS API Documentation
Request Syntax
response = client.start_sync_execution(
stateMachineArn='string',
name='string',
input='string',
traceHeader='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the state machine to execute.
The string that contains the JSON input data for the execution, for example:
"input": "{\"first_name\" : \"test\"}"
Note
If you don't include any JSON input data, you still must include the two braces, for example: "input": "{}"
Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
dict
Response Syntax
{
'executionArn': 'string',
'stateMachineArn': 'string',
'name': 'string',
'startDate': datetime(2015, 1, 1),
'stopDate': datetime(2015, 1, 1),
'status': 'SUCCEEDED'|'FAILED'|'TIMED_OUT',
'error': 'string',
'cause': 'string',
'input': 'string',
'inputDetails': {
'included': True|False
},
'output': 'string',
'outputDetails': {
'included': True|False
},
'traceHeader': 'string',
'billingDetails': {
'billedMemoryUsedInMB': 123,
'billedDurationInMilliseconds': 123
}
}
Response Structure
(dict) --
executionArn (string) --
The Amazon Resource Name (ARN) that identifies the execution.
stateMachineArn (string) --
The Amazon Resource Name (ARN) that identifies the state machine.
name (string) --
The name of the execution.
startDate (datetime) --
The date the execution is started.
stopDate (datetime) --
If the execution has already ended, the date the execution stopped.
status (string) --
The current status of the execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
input (string) --
The string that contains the JSON input data of the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Provides details about execution input or output.
included (boolean) --
Indicates whether input or output was included in the response. Always true
for API calls.
output (string) --
The JSON output data of the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
Note
This field is set only if the execution succeeds. If the execution fails, this field is null.
outputDetails (dict) --
Provides details about execution input or output.
included (boolean) --
Indicates whether input or output was included in the response. Always true
for API calls.
traceHeader (string) --
The X-Ray trace header that was passed to the execution.
billingDetails (dict) --
An object that describes workflow billing details, including billed duration and memory use.
billedMemoryUsedInMB (integer) --
Billed memory consumption of your workflow, in MB.
billedDurationInMilliseconds (integer) --
Billed duration of your workflow, in milliseconds.
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.InvalidExecutionInput
SFN.Client.exceptions.InvalidName
SFN.Client.exceptions.StateMachineDoesNotExist
SFN.Client.exceptions.StateMachineDeleting
SFN.Client.exceptions.StateMachineTypeNotSupported
stop_execution
(**kwargs)¶Stops an execution.
This API action is not supported by EXPRESS
state machines.
See also: AWS API Documentation
Request Syntax
response = client.stop_execution(
executionArn='string',
error='string',
cause='string'
)
[REQUIRED]
The Amazon Resource Name (ARN) of the execution to stop.
dict
Response Syntax
{
'stopDate': datetime(2015, 1, 1)
}
Response Structure
(dict) --
stopDate (datetime) --
The date the execution is stopped.
Exceptions
SFN.Client.exceptions.ExecutionDoesNotExist
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.ValidationException
tag_resource
(**kwargs)¶Add a tag to a Step Functions resource.
An array of key-value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide , and Controlling Access Using IAM Tags.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
See also: AWS API Documentation
Request Syntax
response = client.tag_resource(
resourceArn='string',
tags=[
{
'key': 'string',
'value': 'string'
},
]
)
[REQUIRED]
The Amazon Resource Name (ARN) for the Step Functions state machine or activity.
[REQUIRED]
The list of tags to add to a resource.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
Tags are key-value pairs that can be associated with Step Functions state machines and activities.
An array of key-value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide , and Controlling Access Using IAM Tags.
Tags may only contain Unicode letters, digits, white space, or these symbols: _ . : / = + - @
.
The key of a tag.
The value of a tag.
dict
Response Syntax
{}
Response Structure
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.ResourceNotFound
SFN.Client.exceptions.TooManyTags
untag_resource
(**kwargs)¶Remove a tag from a Step Functions resource
See also: AWS API Documentation
Request Syntax
response = client.untag_resource(
resourceArn='string',
tagKeys=[
'string',
]
)
[REQUIRED]
The Amazon Resource Name (ARN) for the Step Functions state machine or activity.
[REQUIRED]
The list of tags to remove from the resource.
dict
Response Syntax
{}
Response Structure
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.ResourceNotFound
update_map_run
(**kwargs)¶Updates an in-progress Map Run's configuration to include changes to the settings that control maximum concurrency and Map Run failure.
See also: AWS API Documentation
Request Syntax
response = client.update_map_run(
mapRunArn='string',
maxConcurrency=123,
toleratedFailurePercentage=...,
toleratedFailureCount=123
)
[REQUIRED]
The Amazon Resource Name (ARN) of a Map Run.
dict
Response Syntax
{}
Response Structure
Exceptions
SFN.Client.exceptions.ResourceNotFound
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.ValidationException
update_state_machine
(**kwargs)¶Updates an existing state machine by modifying its definition
, roleArn
, or loggingConfiguration
. Running executions will continue to use the previous definition
and roleArn
. You must include at least one of definition
or roleArn
or you will receive a MissingRequiredParameter
error.
If the given state machine Amazon Resource Name (ARN) is a qualified state machine ARN, it will fail with ValidationException.
A qualified state machine ARN refers to a Distributed Map state defined within a state machine. For example, the qualified state machine ARN arn:partition:states:region:account-id:stateMachine:stateMachineName/mapStateLabel
refers to a Distributed Map state with a label mapStateLabel
in the state machine named stateMachineName
.
Note
All StartExecution
calls within a few seconds will use the updated definition
and roleArn
. Executions started immediately after calling UpdateStateMachine
may use the previous state machine definition
and roleArn
.
See also: AWS API Documentation
Request Syntax
response = client.update_state_machine(
stateMachineArn='string',
definition='string',
roleArn='string',
loggingConfiguration={
'level': 'ALL'|'ERROR'|'FATAL'|'OFF',
'includeExecutionData': True|False,
'destinations': [
{
'cloudWatchLogsLogGroup': {
'logGroupArn': 'string'
}
},
]
},
tracingConfiguration={
'enabled': True|False
}
)
[REQUIRED]
The Amazon Resource Name (ARN) of the state machine.
The LoggingConfiguration
data type is used to set CloudWatch Logs options.
Defines which category of execution history events are logged.
Determines whether execution data is included in your log. When set to false
, data is excluded.
An array of objects that describes where your execution history events will be logged. Limited to size 1. Required, if your log level is not set to OFF
.
An object describing a CloudWatch log group. For more information, see AWS::Logs::LogGroup in the CloudFormation User Guide.
The ARN of the the CloudWatch log group to which you want your logs emitted to. The ARN must end with :*
Selects whether X-Ray tracing is enabled.
When set to true
, X-Ray tracing is enabled.
dict
Response Syntax
{
'updateDate': datetime(2015, 1, 1)
}
Response Structure
(dict) --
updateDate (datetime) --
The date and time the state machine was updated.
Exceptions
SFN.Client.exceptions.InvalidArn
SFN.Client.exceptions.InvalidDefinition
SFN.Client.exceptions.InvalidLoggingConfiguration
SFN.Client.exceptions.InvalidTracingConfiguration
SFN.Client.exceptions.MissingRequiredParameter
SFN.Client.exceptions.StateMachineDeleting
SFN.Client.exceptions.StateMachineDoesNotExist
SFN.Client.exceptions.ValidationException
The available paginators are:
SFN.Paginator.GetExecutionHistory
SFN.Paginator.ListActivities
SFN.Paginator.ListExecutions
SFN.Paginator.ListMapRuns
SFN.Paginator.ListStateMachines
SFN.Paginator.
GetExecutionHistory
¶paginator = client.get_paginator('get_execution_history')
paginate
(**kwargs)¶Creates an iterator that will paginate through responses from SFN.Client.get_execution_history()
.
See also: AWS API Documentation
Request Syntax
response_iterator = paginator.paginate(
executionArn='string',
reverseOrder=True|False,
includeExecutionData=True|False,
PaginationConfig={
'MaxItems': 123,
'PageSize': 123,
'StartingToken': 'string'
}
)
[REQUIRED]
The Amazon Resource Name (ARN) of the execution.
timeStamp
.true
.A dictionary that provides parameters to control pagination.
The total number of items to return. If the total number of items available is more than the value specified in max-items then a NextToken
will be provided in the output that you can use to resume pagination.
The size of each page.
A token to specify where to start paginating. This is the NextToken
from a previous response.
dict
Response Syntax
{
'events': [
{
'timestamp': datetime(2015, 1, 1),
'type': 'ActivityFailed'|'ActivityScheduled'|'ActivityScheduleFailed'|'ActivityStarted'|'ActivitySucceeded'|'ActivityTimedOut'|'ChoiceStateEntered'|'ChoiceStateExited'|'ExecutionAborted'|'ExecutionFailed'|'ExecutionStarted'|'ExecutionSucceeded'|'ExecutionTimedOut'|'FailStateEntered'|'LambdaFunctionFailed'|'LambdaFunctionScheduled'|'LambdaFunctionScheduleFailed'|'LambdaFunctionStarted'|'LambdaFunctionStartFailed'|'LambdaFunctionSucceeded'|'LambdaFunctionTimedOut'|'MapIterationAborted'|'MapIterationFailed'|'MapIterationStarted'|'MapIterationSucceeded'|'MapStateAborted'|'MapStateEntered'|'MapStateExited'|'MapStateFailed'|'MapStateStarted'|'MapStateSucceeded'|'ParallelStateAborted'|'ParallelStateEntered'|'ParallelStateExited'|'ParallelStateFailed'|'ParallelStateStarted'|'ParallelStateSucceeded'|'PassStateEntered'|'PassStateExited'|'SucceedStateEntered'|'SucceedStateExited'|'TaskFailed'|'TaskScheduled'|'TaskStarted'|'TaskStartFailed'|'TaskStateAborted'|'TaskStateEntered'|'TaskStateExited'|'TaskSubmitFailed'|'TaskSubmitted'|'TaskSucceeded'|'TaskTimedOut'|'WaitStateAborted'|'WaitStateEntered'|'WaitStateExited'|'MapRunAborted'|'MapRunFailed'|'MapRunStarted'|'MapRunSucceeded',
'id': 123,
'previousEventId': 123,
'activityFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'activityScheduleFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'activityScheduledEventDetails': {
'resource': 'string',
'input': 'string',
'inputDetails': {
'truncated': True|False
},
'timeoutInSeconds': 123,
'heartbeatInSeconds': 123
},
'activityStartedEventDetails': {
'workerName': 'string'
},
'activitySucceededEventDetails': {
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'activityTimedOutEventDetails': {
'error': 'string',
'cause': 'string'
},
'taskFailedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'taskScheduledEventDetails': {
'resourceType': 'string',
'resource': 'string',
'region': 'string',
'parameters': 'string',
'timeoutInSeconds': 123,
'heartbeatInSeconds': 123,
'taskCredentials': {
'roleArn': 'string'
}
},
'taskStartFailedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'taskStartedEventDetails': {
'resourceType': 'string',
'resource': 'string'
},
'taskSubmitFailedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'taskSubmittedEventDetails': {
'resourceType': 'string',
'resource': 'string',
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'taskSucceededEventDetails': {
'resourceType': 'string',
'resource': 'string',
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'taskTimedOutEventDetails': {
'resourceType': 'string',
'resource': 'string',
'error': 'string',
'cause': 'string'
},
'executionFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'executionStartedEventDetails': {
'input': 'string',
'inputDetails': {
'truncated': True|False
},
'roleArn': 'string'
},
'executionSucceededEventDetails': {
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'executionAbortedEventDetails': {
'error': 'string',
'cause': 'string'
},
'executionTimedOutEventDetails': {
'error': 'string',
'cause': 'string'
},
'mapStateStartedEventDetails': {
'length': 123
},
'mapIterationStartedEventDetails': {
'name': 'string',
'index': 123
},
'mapIterationSucceededEventDetails': {
'name': 'string',
'index': 123
},
'mapIterationFailedEventDetails': {
'name': 'string',
'index': 123
},
'mapIterationAbortedEventDetails': {
'name': 'string',
'index': 123
},
'lambdaFunctionFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'lambdaFunctionScheduleFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'lambdaFunctionScheduledEventDetails': {
'resource': 'string',
'input': 'string',
'inputDetails': {
'truncated': True|False
},
'timeoutInSeconds': 123,
'taskCredentials': {
'roleArn': 'string'
}
},
'lambdaFunctionStartFailedEventDetails': {
'error': 'string',
'cause': 'string'
},
'lambdaFunctionSucceededEventDetails': {
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'lambdaFunctionTimedOutEventDetails': {
'error': 'string',
'cause': 'string'
},
'stateEnteredEventDetails': {
'name': 'string',
'input': 'string',
'inputDetails': {
'truncated': True|False
}
},
'stateExitedEventDetails': {
'name': 'string',
'output': 'string',
'outputDetails': {
'truncated': True|False
}
},
'mapRunStartedEventDetails': {
'mapRunArn': 'string'
},
'mapRunFailedEventDetails': {
'error': 'string',
'cause': 'string'
}
},
],
'NextToken': 'string'
}
Response Structure
(dict) --
events (list) --
The list of events that occurred in the execution.
(dict) --
Contains details about the events of an execution.
timestamp (datetime) --
The date and time the event occurred.
type (string) --
The type of the event.
id (integer) --
The id of the event. Events are numbered sequentially, starting at one.
previousEventId (integer) --
The id of the previous event.
activityFailedEventDetails (dict) --
Contains details about an activity that failed during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
activityScheduleFailedEventDetails (dict) --
Contains details about an activity schedule event that failed during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
activityScheduledEventDetails (dict) --
Contains details about an activity scheduled during an execution.
resource (string) --
The Amazon Resource Name (ARN) of the scheduled activity.
input (string) --
The JSON data input to the activity task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about the input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
timeoutInSeconds (integer) --
The maximum allowed duration of the activity task.
heartbeatInSeconds (integer) --
The maximum allowed duration between two heartbeats for the activity task.
activityStartedEventDetails (dict) --
Contains details about the start of an activity during an execution.
workerName (string) --
The name of the worker that the task is assigned to. These names are provided by the workers when calling GetActivityTask.
activitySucceededEventDetails (dict) --
Contains details about an activity that successfully terminated during an execution.
output (string) --
The JSON data output by the activity task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
activityTimedOutEventDetails (dict) --
Contains details about an activity timeout that occurred during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the timeout.
taskFailedEventDetails (dict) --
Contains details about the failure of a task.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
taskScheduledEventDetails (dict) --
Contains details about a task that was scheduled.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
region (string) --
The region of the scheduled task
parameters (string) --
The JSON data passed to the resource referenced in a task state. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
timeoutInSeconds (integer) --
The maximum allowed duration of the task.
heartbeatInSeconds (integer) --
The maximum allowed duration between two heartbeats for the task.
taskCredentials (dict) --
The credentials that Step Functions uses for the task.
roleArn (string) --
The ARN of an IAM role that Step Functions assumes for the task. The role can allow cross-account access to resources.
taskStartFailedEventDetails (dict) --
Contains details about a task that failed to start.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
taskStartedEventDetails (dict) --
Contains details about a task that was started.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
taskSubmitFailedEventDetails (dict) --
Contains details about a task that where the submit failed.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
taskSubmittedEventDetails (dict) --
Contains details about a submitted task.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
output (string) --
The response from a resource when a task has started. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
taskSucceededEventDetails (dict) --
Contains details about a task that succeeded.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
output (string) --
The full JSON response from a resource when a task has succeeded. This response becomes the output of the related task. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
taskTimedOutEventDetails (dict) --
Contains details about a task that timed out.
resourceType (string) --
The service name of the resource in a task state.
resource (string) --
The action of the resource called by a task state.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
executionFailedEventDetails (dict) --
Contains details about an execution failure event.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
executionStartedEventDetails (dict) --
Contains details about the start of the execution.
input (string) --
The JSON data input to the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about the input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
roleArn (string) --
The Amazon Resource Name (ARN) of the IAM role used for executing Lambda tasks.
executionSucceededEventDetails (dict) --
Contains details about the successful termination of the execution.
output (string) --
The JSON data output by the execution. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
executionAbortedEventDetails (dict) --
Contains details about an abort of an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
executionTimedOutEventDetails (dict) --
Contains details about the execution timeout that occurred during the execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the timeout.
mapStateStartedEventDetails (dict) --
Contains details about Map state that was started.
length (integer) --
The size of the array for Map state iterations.
mapIterationStartedEventDetails (dict) --
Contains details about an iteration of a Map state that was started.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
mapIterationSucceededEventDetails (dict) --
Contains details about an iteration of a Map state that succeeded.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
mapIterationFailedEventDetails (dict) --
Contains details about an iteration of a Map state that failed.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
mapIterationAbortedEventDetails (dict) --
Contains details about an iteration of a Map state that was aborted.
name (string) --
The name of the iteration’s parent Map state.
index (integer) --
The index of the array belonging to the Map state iteration.
lambdaFunctionFailedEventDetails (dict) --
Contains details about a Lambda function that failed during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
lambdaFunctionScheduleFailedEventDetails (dict) --
Contains details about a failed Lambda function schedule event that occurred during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
lambdaFunctionScheduledEventDetails (dict) --
Contains details about a Lambda function scheduled during an execution.
resource (string) --
The Amazon Resource Name (ARN) of the scheduled Lambda function.
input (string) --
The JSON data input to the Lambda function. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
timeoutInSeconds (integer) --
The maximum allowed duration of the Lambda function.
taskCredentials (dict) --
The credentials that Step Functions uses for the task.
roleArn (string) --
The ARN of an IAM role that Step Functions assumes for the task. The role can allow cross-account access to resources.
lambdaFunctionStartFailedEventDetails (dict) --
Contains details about a lambda function that failed to start during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the failure.
lambdaFunctionSucceededEventDetails (dict) --
Contains details about a Lambda function that terminated successfully during an execution.
output (string) --
The JSON data output by the Lambda function. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
lambdaFunctionTimedOutEventDetails (dict) --
Contains details about a Lambda function timeout that occurred during an execution.
error (string) --
The error code of the failure.
cause (string) --
A more detailed explanation of the cause of the timeout.
stateEnteredEventDetails (dict) --
Contains details about a state entered during an execution.
name (string) --
The name of the state.
input (string) --
The string that contains the JSON input data for the state. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
inputDetails (dict) --
Contains details about the input for an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
stateExitedEventDetails (dict) --
Contains details about an exit from a state during an execution.
name (string) --
The name of the state.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
output (string) --
The JSON output data of the state. Length constraints apply to the payload size, and are expressed as bytes in UTF-8 encoding.
outputDetails (dict) --
Contains details about the output of an execution history event.
truncated (boolean) --
Indicates whether input or output was truncated in the response. Always false
for API calls.
mapRunStartedEventDetails (dict) --
Contains details, such as mapRunArn
, and the start date and time of a Map Run. mapRunArn
is the Amazon Resource Name (ARN) of the Map Run that was started.
mapRunArn (string) --
The Amazon Resource Name (ARN) of a Map Run that was started.
mapRunFailedEventDetails (dict) --
Contains error and cause details about a Map Run that failed.
error (string) --
The error code of the Map Run failure.
cause (string) --
A more detailed explanation of the cause of the failure.
NextToken (string) --
A token to resume pagination.
SFN.Paginator.
ListActivities
¶paginator = client.get_paginator('list_activities')
paginate
(**kwargs)¶Creates an iterator that will paginate through responses from SFN.Client.list_activities()
.
See also: AWS API Documentation
Request Syntax
response_iterator = paginator.paginate(
PaginationConfig={
'MaxItems': 123,
'PageSize': 123,
'StartingToken': 'string'
}
)
A dictionary that provides parameters to control pagination.
The total number of items to return. If the total number of items available is more than the value specified in max-items then a NextToken
will be provided in the output that you can use to resume pagination.
The size of each page.
A token to specify where to start paginating. This is the NextToken
from a previous response.
{
'activities': [
{
'activityArn': 'string',
'name': 'string',
'creationDate': datetime(2015, 1, 1)
},
],
'NextToken': 'string'
}
Response Structure
The list of activities.
Contains details about an activity.
The Amazon Resource Name (ARN) that identifies the activity.
The name of the activity.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
The date the activity is created.
A token to resume pagination.
SFN.Paginator.
ListExecutions
¶paginator = client.get_paginator('list_executions')
paginate
(**kwargs)¶Creates an iterator that will paginate through responses from SFN.Client.list_executions()
.
See also: AWS API Documentation
Request Syntax
response_iterator = paginator.paginate(
stateMachineArn='string',
statusFilter='RUNNING'|'SUCCEEDED'|'FAILED'|'TIMED_OUT'|'ABORTED',
mapRunArn='string',
PaginationConfig={
'MaxItems': 123,
'PageSize': 123,
'StartingToken': 'string'
}
)
The Amazon Resource Name (ARN) of the state machine whose executions is listed.
You can specify either a mapRunArn
or a stateMachineArn
, but not both.
The Amazon Resource Name (ARN) of the Map Run that started the child workflow executions. If the mapRunArn
field is specified, a list of all of the child workflow executions started by a Map Run is returned. For more information, see Examining Map Run in the Step Functions Developer Guide .
You can specify either a mapRunArn
or a stateMachineArn
, but not both.
A dictionary that provides parameters to control pagination.
The total number of items to return. If the total number of items available is more than the value specified in max-items then a NextToken
will be provided in the output that you can use to resume pagination.
The size of each page.
A token to specify where to start paginating. This is the NextToken
from a previous response.
dict
Response Syntax
{
'executions': [
{
'executionArn': 'string',
'stateMachineArn': 'string',
'name': 'string',
'status': 'RUNNING'|'SUCCEEDED'|'FAILED'|'TIMED_OUT'|'ABORTED',
'startDate': datetime(2015, 1, 1),
'stopDate': datetime(2015, 1, 1),
'mapRunArn': 'string',
'itemCount': 123
},
],
'NextToken': 'string'
}
Response Structure
(dict) --
executions (list) --
The list of matching executions.
(dict) --
Contains details about an execution.
executionArn (string) --
The Amazon Resource Name (ARN) that identifies the execution.
stateMachineArn (string) --
The Amazon Resource Name (ARN) of the executed state machine.
name (string) --
The name of the execution.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
status (string) --
The current status of the execution.
startDate (datetime) --
The date the execution started.
stopDate (datetime) --
If the execution already ended, the date the execution stopped.
mapRunArn (string) --
The Amazon Resource Name (ARN) of a Map Run. This field is returned only if mapRunArn
was specified in the ListExecutions
API action. If stateMachineArn
was specified in ListExecutions
, the mapRunArn
isn't returned.
itemCount (integer) --
The total number of items processed in a child workflow execution. This field is returned only if mapRunArn
was specified in the ListExecutions
API action. If stateMachineArn
was specified in ListExecutions
, the itemCount
field isn't returned.
NextToken (string) --
A token to resume pagination.
SFN.Paginator.
ListMapRuns
¶paginator = client.get_paginator('list_map_runs')
paginate
(**kwargs)¶Creates an iterator that will paginate through responses from SFN.Client.list_map_runs()
.
See also: AWS API Documentation
Request Syntax
response_iterator = paginator.paginate(
executionArn='string',
PaginationConfig={
'MaxItems': 123,
'PageSize': 123,
'StartingToken': 'string'
}
)
[REQUIRED]
The Amazon Resource Name (ARN) of the execution for which the Map Runs must be listed.
A dictionary that provides parameters to control pagination.
The total number of items to return. If the total number of items available is more than the value specified in max-items then a NextToken
will be provided in the output that you can use to resume pagination.
The size of each page.
A token to specify where to start paginating. This is the NextToken
from a previous response.
dict
Response Syntax
{
'mapRuns': [
{
'executionArn': 'string',
'mapRunArn': 'string',
'stateMachineArn': 'string',
'startDate': datetime(2015, 1, 1),
'stopDate': datetime(2015, 1, 1)
},
],
'NextToken': 'string'
}
Response Structure
(dict) --
mapRuns (list) --
An array that lists information related to a Map Run, such as the Amazon Resource Name (ARN) of the Map Run and the ARN of the state machine that started the Map Run.
(dict) --
Contains details about a specific Map Run.
executionArn (string) --
The executionArn
of the execution from which the Map Run was started.
mapRunArn (string) --
The Amazon Resource Name (ARN) of the Map Run.
stateMachineArn (string) --
The Amazon Resource Name (ARN) of the executed state machine.
startDate (datetime) --
The date on which the Map Run started.
stopDate (datetime) --
The date on which the Map Run stopped.
NextToken (string) --
A token to resume pagination.
SFN.Paginator.
ListStateMachines
¶paginator = client.get_paginator('list_state_machines')
paginate
(**kwargs)¶Creates an iterator that will paginate through responses from SFN.Client.list_state_machines()
.
See also: AWS API Documentation
Request Syntax
response_iterator = paginator.paginate(
PaginationConfig={
'MaxItems': 123,
'PageSize': 123,
'StartingToken': 'string'
}
)
A dictionary that provides parameters to control pagination.
The total number of items to return. If the total number of items available is more than the value specified in max-items then a NextToken
will be provided in the output that you can use to resume pagination.
The size of each page.
A token to specify where to start paginating. This is the NextToken
from a previous response.
{
'stateMachines': [
{
'stateMachineArn': 'string',
'name': 'string',
'type': 'STANDARD'|'EXPRESS',
'creationDate': datetime(2015, 1, 1)
},
],
'NextToken': 'string'
}
Response Structure
Contains details about the state machine.
The Amazon Resource Name (ARN) that identifies the state machine.
The name of the state machine.
A name must not contain:
< > { } [ ]
? *
" # % \ ^ | ~ ` $ & , ; : /
U+0000-001F
, U+007F-009F
)To enable logging with CloudWatch Logs, the name should only contain 0-9, A-Z, a-z, - and _.
The date the state machine is created.
A token to resume pagination.