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

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

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

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

参考:

由 Amazon CodeBuild 定义的操作

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

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

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

注意

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

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

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

project*

BatchGetBuildBatches 授予权限以获取一个或多个构建批处理的相关信息 读取

project*

BatchGetBuilds 授予权限以获取一个或多个构建的相关信息 读取

project*

BatchGetFleets 授予返回输入参数指定的 Fleet 对象数组的权限 读取

fleet*

BatchGetProjects 授予权限以获取一个或多个构建项目的相关信息 读取

project*

BatchGetReportGroups 授予返回由输入 reportGroupArns 参数指定的 ReportGroup 对象数组的权限 读取

report-group*

BatchGetReports 授予权限以返回由输入 reportArns 参数指定的 Report 对象的数组 读取

report-group*

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

report-group*

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

report-group*

CreateFleet 授予创建计算队列的权限 写入

fleet*

aws:RequestTag/${TagKey}

aws:TagKeys

CreateProject 授予权限以创建构建项目 写入

project*

aws:RequestTag/${TagKey}

aws:TagKeys

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

report-group*

CreateReportGroup 授予权限以创建报告组 写入

report-group*

aws:RequestTag/${TagKey}

aws:TagKeys

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

project*

DeleteBuildBatch 授予权限以删除构建批处理 写入

project*

DeleteFleet 授予删除计算队列的权限 写入

fleet*

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

project*

DeleteReport 授予权限以删除报告 写入

report-group*

DeleteReportGroup 授予权限以删除报告组 写入

report-group*

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

project

report-group

DeleteSourceCredentials 授予删除一组 GitHub、 GitHub 企业版或 Bitbucket 源凭证的权限 写入
DeleteWebhook 授予权限以删除 Webhook。对于源代码存储在 GitHub 或 Bitbucket 存储库中的现有Amazon CodeBuild 构建项目,每次将代码更改推送Amazon CodeBuild 到存储库时都停止重建源代码 写入

project*

DescribeCodeCoverages 授予返回 CodeCoverage 对象数组的权限 读取

report-group*

DescribeTestCases 授予返回 TestCase 对象数组的权限 读取

report-group*

GetReportGroupTrend 授予权限以分析和累积指定报告组中测试报告的测试报告值 读取

report-group*

GetResourcePolicy 授予权限以返回指定项目或报告组的资源策略 读取

project

report-group

ImportSourceCredentials 授予导入源代码存储在 GitHub、E GitHub nterprise 或 Bitbucket 存储库中的Amazon CodeBuild 项目的源存储库凭据的权限 写入
InvalidateProjectCache 授予权限以重置项目缓存 写入

project*

ListBuildBatches 授予权限以获取构建批处理 ID 的列表,其中每个构建批处理 ID 代表一个构建批处理 列出
ListBuildBatchesForProject 授予权限以获取指定构建项目的构建批处理 ID 的列表,其中每个构建批处理 ID 代表一个构建批处理 列出

project*

ListBuilds 授予权限以获取构建 ID 的列表,其中每个构建 ID 代表一个构建 列出
ListBuildsForProject 授予权限以获取指定构建项目的构建 ID 的列表,其中每个构建 ID 代表一个构建 列出

project*

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

report-group*

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

project

report-group

RetryBuild 授予权限以重试构建 写入

project*

RetryBuildBatch 授予权限以重试构建批处理 写入

project*

StartBuild 授予权限以开始运行构建 写入

project*

StartBuildBatch 授予权限以开始运行构建批处理 写入

project*

StopBuild 授予权限以尝试停止运行构建 写入

project*

StopBuildBatch 授予权限以尝试停止运行构建批处理 写入

project*

UpdateFleet 授予更改现有计算队列设置的权限 写入

fleet*

aws:RequestTag/${TagKey}

aws:TagKeys

UpdateProject 授予权限以更改现有构建项目的设置 写入

project*

aws:RequestTag/${TagKey}

aws:TagKeys

UpdateProjectVisibility 授予权限以更改项目及其构建的公共可见性 写入

project*

aws:RequestTag/${TagKey}

aws:TagKeys

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

report-group*

UpdateReportGroup 授予权限以更改现有报告组的设置 写入

report-group*

aws:RequestTag/${TagKey}

aws:TagKeys

UpdateWebhook 授予更新与Amazon CodeBuild 构建项目关联的 webhook 的权限 写入

project*

Amazon 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}
fleet arn:${Partition}:codebuild:${Region}:${Account}:fleet/${FleetName}:${FleetId}

Amazon CodeBuild 的条件键

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

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

条件键 描述 类型
aws:RequestTag/${TagKey} 根据在请求中是否具有标签键值对来按照操作筛选访问权限 String
aws:ResourceTag/${TagKey} 根据附加到资源的标签键值对来按操作筛选访问权限 String
aws:TagKeys 根据在请求中是否具有标签键来按操作筛选访问权限 ArrayOfString