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

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

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

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

参考:

AWS CodeBuild 定义的操作

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

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

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

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
BatchDeleteBuilds 删除一个或多个构建。 写入

project*

BatchGetBuildBatches 获取有关一个或多个构建批处理的信息。 Read

project*

BatchGetBuilds 获取有关一个或多个构建的信息。 Read

project*

BatchGetProjects 获取有关一个或多个构建项目的信息。 Read

project*

BatchGetReportGroups 返回由输入 reportGroupArns 参数指定的 ReportGroup 对象的数组。 Read

report-group*

BatchGetReports 返回由输入 reportArns 参数指定的 Report 对象的数组。 Read

report-group*

BatchPutCodeCoverages [仅权限] 添加或更新有关报告的信息。 写入

report-group*

BatchPutTestCases [仅权限] 添加或更新有关报告的信息。 写入

report-group*

CreateProject 创建构建项目。 写入

project*

aws:RequestTag/${TagKey}

aws:TagKeys

CreateReport [仅权限] 创建报告。当 buildspec文件中为报告组指定的测试在项目构建期间运行时,将创建报告。 写入

report-group*

CreateReportGroup 创建报告组。 写入

report-group*

aws:RequestTag/${TagKey}

aws:TagKeys

CreateWebhook 对于在 GitHub 或 Bitbucket 存储库中存储源代码的现有 AWS CodeBuild 构建项目,允许 AWS CodeBuild 在每次将代码更改推送到存储库时开始重新构建源代码。 写入

project*

DeleteBuildBatch 删除构建批处理。 写入

project*

DeleteOAuthToken [仅权限] 删除来自连接的第三方 OAuth 提供商的 OAuth 令牌。仅在 AWS CodeBuild 控制台中使用。 写入
DeleteProject 删除构建项目。 写入

project*

DeleteReport 删除报告。 写入

report-group*

DeleteReportGroup 删除报告组。 写入

report-group*

DeleteResourcePolicy 删除关联项目或报告组的资源策略。 权限管理

project

report-group

DeleteSourceCredentials 删除一组 GitHub、GitHub Enterprise 或 Bitbucket 源凭证。 写入
DeleteWebhook 对于在 GitHub 或 Bitbucket 存储库中存储源代码的现有 AWS CodeBuild 构建项目,禁止 AWS CodeBuild 在每次将代码更改推送到存储库时重新构建源代码。 写入

project*

DescribeCodeCoverages 返回一个 CodeCoverage 对象的数组。 Read

report-group*

DescribeTestCases 返回 TestCase 对象的数组。 Read

report-group*

GetReportGroupTrend 分析和累积指定报告组中测试报告的测试报告值。 Read

report-group*

GetResourcePolicy 返回指定项目或报告组的资源策略。 Read

project

report-group

ImportSourceCredentials 导入在 GitHub、GitHub Enterprise 或 Bitbucket 存储库中存储源代码的 AWS CodeBuild 项目的源存储库凭证。 写入
InvalidateProjectCache 重置项目的缓存。 写入

project*

ListBuildBatches 获取构建批处理 ID 的列表,其中每个构建批处理 ID 代表一个构建批处理。 List
ListBuildBatchesForProject 获取指定构建项目的构建批处理 ID 的列表,其中每个构建批处理 ID 代表一个构建批处理。 List

project*

ListBuilds 获取构建 ID 的列表,其中每个构建 ID 代表一个构建。 List
ListBuildsForProject 获取指定构建项目的构建 ID 的列表,其中每个构建 ID 代表一个构建。 List

project*

ListConnectedOAuthAccounts [仅权限] 列出已连接的第三方 OAuth 提供商。仅在 AWS CodeBuild 控制台中使用。 List
ListCuratedEnvironmentImages 获取有关由 AWS CodeBuild 管理的 Docker 映像的信息。 List
ListProjects 获取构建项目名称的列表,其中每个构建项目名称代表一个构建项目。 List
ListReportGroups 返回报告组 ARN 的列表。每个报告组 ARN 代表一个报告组。 List
ListReports 返回报告 ARN 的列表。每个报告 ARN 表示一个报告。 List
ListReportsForReportGroup 返回属于指定报告组的报告 ARN 的列表。每个报告 ARN 表示一个报告。 List

report-group*

ListRepositories [仅权限] 列出来自已连接的第三方 OAuth 提供商的源代码存储库。仅在 AWS CodeBuild 控制台中使用。 List
ListSharedProjects 返回已与请求者共享的项目 ARN 的列表。每个项目 ARN 表示一个项目。 List
ListSharedReportGroups 返回已与请求者共享的报告组 ARN 的列表。每个报告组 ARN 代表一个报告组。 List
ListSourceCredentials 返回 SourceCredentialsInfo 对象列表。 List
PersistOAuthToken [仅权限] 保存来自已连接的第三方 OAuth 提供商的 OAuth 令牌。仅在 AWS CodeBuild 控制台中使用。 写入
PutResourcePolicy 为关联的项目或报告组创建资源策略。 权限管理

project

report-group

RetryBuild 重试构建。 写入

project*

RetryBuildBatch 重试构建批处理。 写入

project*

StartBuild 开始运行构建。 写入

project*

StartBuildBatch 开始运行构建批处理。 写入

project*

StopBuild 尝试停止正在运行的构建。 写入

project*

StopBuildBatch 尝试停止正在运行的构建批处理。 写入

project*

UpdateProject 更改现有构建项目的设置。 写入

project*

aws:RequestTag/${TagKey}

aws:TagKeys

UpdateReport [仅权限] 更新有关报告的信息。 写入

report-group*

UpdateReportGroup 更改现有报告组的设置。 写入

report-group*

aws:RequestTag/${TagKey}

aws:TagKeys

UpdateWebhook 更新与 AWS CodeBuild 构建项目关联的 Webhook。 写入

project*

AWS CodeBuild 定义的资源类型

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

资源类型 ARN 条件键
build arn:${Partition}:codebuild:${Region}:${Account}:build/${BuildId}
build-batch arn:${Partition}:codebuild:${Region}:${Account}:build-batch/${BuildBatchId}
project arn:${Partition}:codebuild:${Region}:${Account}:project/${ProjectName}

aws:ResourceTag/${TagKey}

report-group arn:${Partition}:codebuild:${Region}:${Account}:report-group/${ReportGroupName}

aws:ResourceTag/${TagKey}

report arn:${Partition}:codebuild:${Region}:${Account}:report/${ReportGroupName}:${ReportId}

AWS CodeBuild 的条件键

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

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

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