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

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

AWS CodeDeploy 的操作、资源和条件键

AWS CodeDeploy(服务前缀:codedeploy)提供以下服务特定的资源、操作和条件上下文键以在 IAM 权限策略中使用。

参考:

AWS CodeDeploy 定义的操作

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

资源类型列指示每项操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource 元素中指定所有资源(“*”)。如果该列包含一种资源类型,则可以在含有该操作的语句中指定该类型的 ARN。必需资源在表中以星号 (*) 表示。如果在使用该操作的语句中指定资源级权限 ARN,则它必须属于该类型。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种类型而不使用其他类型。

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

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
AddTagsToOnPremisesInstances 向一个或多个本地实例添加标签。 标记

instance*

BatchGetApplicationRevisions 获取有关一个或多个应用程序修订的信息。 Read

application*

BatchGetApplications 获取有关与 IAM 用户关联的多个应用程序的信息。 Read

application*

BatchGetDeploymentGroups 获取有关一个或多个部署组的信息。 Read

deploymentgroup*

BatchGetDeploymentInstances 获取有关属于部署组的一个或多个实例的信息。 Read

deploymentgroup*

BatchGetDeploymentTargets 返回与部署关联的一个或多个目标的数组。此方法适用于所有计算类型,应使用此方法来取代弃用的 BatchGetDeploymentInstances。可以返回的最大目标数量为 25。 Read
BatchGetDeployments 获取有关与 IAM 用户关联的多个部署的信息。 Read

deploymentgroup*

BatchGetOnPremisesInstances 获取有关一个或多个本地实例的信息。 Read

instance*

ContinueDeployment 启动将来自原始环境中的实例的流量重新路由到替换环境中的实例的过程,而无需等待指定的等待时间过去。 写入
CreateApplication 创建与 IAM 用户关联的应用程序。 写入

application*

aws:RequestTag/${TagKey}

aws:TagKeys

CreateCloudFormationDeployment [仅权限] 创建 CloudFormation 部署,以协调安排进行 CloudFormation 堆栈更新。 写入
CreateDeployment 为与 IAM 用户关联的应用程序创建部署。 写入

deploymentgroup*

CreateDeploymentConfig 创建与 IAM 用户关联的自定义部署配置。 写入

deploymentconfig*

CreateDeploymentGroup 为与 IAM 用户关联的应用程序创建部署组。 写入

deploymentgroup*

aws:RequestTag/${TagKey}

aws:TagKeys

DeleteApplication 删除与 IAM 用户关联的应用程序。 写入

application*

DeleteDeploymentConfig 删除与 IAM 用户关联的自定义部署配置。 写入

deploymentconfig*

DeleteDeploymentGroup 为与 IAM 用户关联的应用程序删除部署组。 写入

deploymentgroup*

DeleteGitHubAccountToken 删除 GitHub 账户连接。 写入
DeleteResourcesByExternalId 删除与给定外部 ID 关联的资源。 写入
DeregisterOnPremisesInstance 取消注册本地实例。 写入

instance*

GetApplication 获取有关与 IAM 用户关联的单个应用程序的信息。 List

application*

GetApplicationRevision 获取有关与 IAM 用户关联的应用程序的单个应用程序修订的信息。 List

application*

GetDeployment 获取有关与 IAM 用户关联的应用程序的部署组的单个部署的信息。 List

deploymentgroup*

GetDeploymentConfig 获取有关与 IAM 用户关联的单个部署配置的信息。 List

deploymentconfig*

GetDeploymentGroup 获取有关与 IAM 用户关联的应用程序的单个部署组的信息。 List

deploymentgroup*

GetDeploymentInstance 获取有关部署中与 IAM 用户关联的单个实例的信息。 List

deploymentgroup*

GetDeploymentTarget 返回有关部署目标的信息。 Read
GetOnPremisesInstance 获取有关单个本地实例的信息。 List

instance*

ListApplicationRevisions 获取有关与 IAM 用户关联的应用程序的所有应用程序修订的信息。 List

application*

ListApplications 获取有关与 IAM 用户关联的所有应用程序的信息。 List
ListDeploymentConfigs 获取有关与 IAM 用户关联的所有部署配置的信息。 List
ListDeploymentGroups 获取有关与 IAM 用户关联的应用程序的所有部署组的信息。 List

application*

ListDeploymentInstances 获取有关部署中与 IAM 用户关联的所有实例的信息。 List

deploymentgroup*

ListDeploymentTargets 返回与部署关联的目标 ID 数组。 List
ListDeployments 获取有关与 IAM 用户关联的部署组的所有部署的信息,或获取与 IAM 用户关联的所有部署。 List

deploymentgroup*

ListGitHubAccountTokenNames 列出已存储的 GitHub 账户连接的名称。 List
ListOnPremisesInstances 获取一个或多个本地实例名称的列表。 List
ListTagsForResource 返回由指定 ARN 标识的资源的标签列表。标签用于组织和分类您的 CodeDeploy 资源。 List

application

deploymentgroup

PutLifecycleEventHookExecutionStatus 通知与 IAM 用户关联的部署的生命周期事件挂钩执行状态。 写入
RegisterApplicationRevision 注册有关与 IAM 用户关联的应用程序的应用程序修订的信息。 写入

application*

RegisterOnPremisesInstance 注册本地实例。 写入

instance*

RemoveTagsFromOnPremisesInstances 从一个或多个本地实例删除标签。 标记

instance*

SkipWaitTimeForInstanceTermination 在蓝/绿部署中,覆盖任何指定的等待时间,并在流量路由完成后立即开始终止实例。 写入
StopDeployment StopDeployment 的描述 写入
TagResource 将输入 Tags 参数中的标签列表与 ResourceArn 输入参数标识的资源相关联。 标记

application

deploymentgroup

aws:RequestTag/${TagKey}

aws:TagKeys

UntagResource 取消资源与标签列表的关联。资源由 ResourceArn 输入参数标识。标签由 TagKeys 输入参数中的键列表标识。 标记

application

deploymentgroup

aws:TagKeys

UpdateApplication UpdateApplication 的描述 写入

application*

UpdateDeploymentGroup 更改有关与 IAM 用户关联的应用程序的单个部署组的信息。 写入

deploymentgroup*

AWS CodeDeploy 定义的资源类型

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

资源类型 ARN 条件键
application arn:${Partition}:codedeploy:${Region}:${Account}:application:${ApplicationName}
deploymentconfig arn:${Partition}:codedeploy:${Region}:${Account}:deploymentconfig:${DeploymentConfigurationName}
deploymentgroup arn:${Partition}:codedeploy:${Region}:${Account}:deploymentgroup:${ApplicationName}/${DeploymentGroupName}
instance arn:${Partition}:codedeploy:${Region}:${Account}:instance:${InstanceName}

AWS CodeDeploy 的条件键

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

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

条件键 描述 类型
aws:RequestTag/${TagKey} 根据在请求中是否具有标签键值对以筛选操作 字符串
aws:ResourceTag/${TagKey} 根据附加到资源的标签键值对筛选操作 字符串
aws:TagKeys 根据在请求中是否具有标签键以筛选操作 字符串