Amazon Step Functions 的操作、资源和条件键 - 服务授权参考
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

Amazon Step Functions 的操作、资源和条件键

Amazon Step Functions(服务前缀:states)提供以下特定于服务的资源、操作和条件上下文密钥,供在 IAM 权限策略中使用。

参考:

Amazon Step Functions 定义的操作

您可以在 IAM 策略语句的 Action 元素中指定以下操作。可以使用策略授予在 Amazon中执行操作的权限。您在策略中使用一项操作时,通常使用相同的名称允许或拒绝对 API 操作或 CLI 命令的访问。但在某些情况下,单一动作可控制对多项操作的访问。还有某些操作需要多种不同的动作。

操作表的资源类型列指示每项操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource 元素中指定策略应用的所有资源(“*”)。通过在 IAM policy 中使用条件来筛选访问权限,以控制是否可以在资源或请求中使用特定标签键。如果操作具有一个或多个必需资源,则调用方必须具有使用这些资源来使用该操作的权限。必需资源在表中以星号 (*) 表示。如果您在 IAM policy 中使用 Resource 元素限制资源访问权限,则必须为每种必需的资源类型添加 ARN 或模式。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种可选资源类型。

操作表的条件键列包括可以在策略语句的 Condition 元素中指定的键。有关与服务资源关联的条件键的更多信息,请参阅资源类型表的条件键列。

注意

资源条件键在资源类型表中列出。您可以在操作表的资源类型(* 为必需)列中找到应用于某项操作的资源类型的链接。资源类型表中的资源类型包括条件密钥列,这是应用于操作表中操作的资源条件键。

有关下表中各列的详细信息,请参阅操作表

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
CreateActivity 授予创建活动的权限 Write

activity*

aws:RequestTag/${TagKey}

aws:TagKeys

CreateStateMachine 授予创建状态机的权限 写入

statemachine*

iam:PassRole

states:PublishStateMachineVersion

aws:RequestTag/${TagKey}

aws:TagKeys

CreateStateMachineAlias 授予创建状态机别名的权限 写入

statemachine*

states:StateMachineQualifier

DeleteActivity 授予删除活动的权限 Write

activity*

DeleteStateMachine 授予删除状态机的权限 写入

statemachine*

DeleteStateMachineAlias 授予删除状态机别名的权限 写入

statemachine*

states:StateMachineQualifier

DeleteStateMachineVersion 授予删除状态机版本的权限 写入

statemachine*

states:StateMachineQualifier

DescribeActivity 授予描述活动的权限 Read

activity*

DescribeExecution 授予描述执行的权限 读取

execution*

express*

DescribeMapRun 授予权限以描述映射运行 读取

maprun*

DescribeStateMachine 授予描述状态机的权限 读取

statemachine*

states:StateMachineQualifier

DescribeStateMachineAlias 授予描述状态机别名的权限 读取

statemachine*

states:StateMachineQualifier

DescribeStateMachineForExecution 授予描述执行状态机的权限 Read

execution*

GetActivityTask 授予工作线程用于检索正在运行的状态机安排执行的任务(通过指定活动 ARN)的权限 Write

activity*

GetExecutionHistory 授予将指定执行历史记录作为事件列表返回的权限 读取

execution*

InvokeHTTPEndpoint [仅权限] 授予调用 HTTP Task 状态的权限 写入
ListActivities 授予列出现有活动的权限 List
ListExecutions 授予列出状态机执行的权限 列出

maprun*

statemachine*

states:StateMachineQualifier

ListMapRuns 授予权限以列出执行的映射运行 列出

execution*

ListStateMachineAliases 授予列出状态机别名的权限 列出

statemachine*

states:StateMachineQualifier

ListStateMachineVersions 授予列出状态机版本的权限 列出

statemachine*

ListStateMachines 授予列出现有状态机的权限 列出
ListTagsForResource 授予列出 Ste Amazon p Functions 资源标签的权限 列出

activity

statemachine

PublishStateMachineVersion 授予发布状态机版本的权限 写入

statemachine*

RedriveExecution 授予重新驱动执行的权限 写入

execution*

RevealSecrets [仅权限] 授予检索执行中的敏感数据的权限 读取
SendTaskFailure 授予工作线程用于报告由 taskToken 标识的任务已失败的权限 Write
SendTaskHeartbeat 授予工作线程用于向服务报告,由指定的 taskToken 表示的任务仍在进行中的权限 Write
SendTaskSuccess 授予工作线程用于报告由 taskToken 标识的任务已成功完成的权限 Write
StartExecution 授予启动状态机执行的权限 Write

statemachine*

states:StateMachineQualifier

StartSyncExecution 授予启动 Synchronous Express 状态机执行的权限 Write

statemachine*

states:StateMachineQualifier

StopExecution 授予停止执行的权限 写入

execution*

TagResource 授予标记 Ste Amazon p Functions 资源的权限 标记

activity

statemachine

aws:TagKeys

aws:RequestTag/${TagKey}

TestState 授予测试状态机定义的权限 写入

states:RevealSecrets

UntagResource 授予从 Ste Amazon p Functions 资源中移除标签的权限 标记

activity

statemachine

aws:TagKeys

UpdateMapRun 授予权限以更新映射运行 写入

maprun*

UpdateStateMachine 授予更新状态机的权限 写入

statemachine*

iam:PassRole

states:PublishStateMachineVersion

aws:RequestTag/${TagKey}

aws:TagKeys

UpdateStateMachineAlias 授予更新状态机别名的权限 写入

statemachine*

states:StateMachineQualifier

Amazon Step Functions 定义的资源类型

以下资源类型是由该服务定义的,可以在 IAM 权限策略语句的 Resource 元素中使用这些资源类型。操作表中的每个操作指定了可以使用该操作指定的资源类型。您也可以在策略中包含条件键,从而定义资源类型。这些键显示在资源类型表的最后一列。有关下表中各列的详细信息,请参阅资源类型表

资源类型 ARN 条件键
activity arn:${Partition}:states:${Region}:${Account}:activity:${ActivityName}

aws:ResourceTag/${TagKey}

execution arn:${Partition}:states:${Region}:${Account}:execution:${StateMachineName}:${ExecutionId}

aws:ResourceTag/${TagKey}

express arn:${Partition}:states:${Region}:${Account}:express:${StateMachineName}:${ExecutionId}:${ExpressId}
statemachine arn:${Partition}:states:${Region}:${Account}:stateMachine:${StateMachineName}

aws:ResourceTag/${TagKey}

statemachineversion arn:${Partition}:states:${Region}:${Account}:stateMachine:${StateMachineName}:${StateMachineVersionId}
statemachinealias arn:${Partition}:states:${Region}:${Account}:stateMachine:${StateMachineName}:${StateMachineAliasName}
maprun arn:${Partition}:states:${Region}:${Account}:mapRun:${StateMachineName}/${MapRunLabel}:${MapRunId}
labelled execution arn:${Partition}:states:${Region}:${Account}:execution:${StateMachineName}/${MapRunLabel}:${ExecutionId}
labelled express arn:${Partition}:states:${Region}:${Account}:express:${StateMachineName}/${MapRunLabel}:${ExecutionId}:${ExpressId}

Amazon Step Functions 的条件键

Amazon Step Functions 定义了以下可以在 IAM 策略Condition元素中使用的条件键。您可以使用这些键进一步细化应用策略语句的条件。有关下表中各列的详细信息,请参阅条件键表

要查看适用于所有服务的全局条件键,请参阅可用的全局条件键

条件键 描述 类型
aws:RequestTag/${TagKey} 按请求中允许的标签键值对筛选访问 字符串
aws:ResourceTag/${TagKey} 按某个资源的标签键值对筛选访问 字符串
aws:TagKeys 按请求中允许的标签键列表筛选访问 ArrayOfString
states:HTTPEndpoint 按请求中的 HTTP Task 状态允许的端点筛选访问权限 字符串
states:HTTPMethod 按请求中的 HTTP Task 状态允许的方法筛选访问权限 字符串
states:StateMachineQualifier 按状态机 ARN 的限定符筛选访问权限 字符串