本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
的操作、资源和条件键 AWS CodeBuild
AWS CodeBuild (服务前缀:codebuild
)提供以下特定于服务的资源、操作和条件上下文密钥,供在 IAM 权限策略中使用。
参考:
由 AWS CodeBuild 定义的操作
您可以在 IAM 策略语句的 Action
元素中指定以下操作。可以使用策略授予在 AWS中执行操作的权限。您在策略中使用一项操作时,通常使用相同的名称允许或拒绝对 API 操作或 CLI 命令的访问。但在某些情况下,单一动作可控制对多项操作的访问。还有某些操作需要多种不同的动作。
操作表的资源类型列指示每项操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource
元素中指定策略应用的所有资源(“*”)。通过在 IAM policy 中使用条件来筛选访问权限,以控制是否可以在资源或请求中使用特定标签键。如果操作具有一个或多个必需资源,则调用方必须具有使用这些资源来使用该操作的权限。必需资源在表中以星号 (*) 表示。如果您在 IAM policy 中使用 Resource
元素限制资源访问权限,则必须为每种必需的资源类型添加 ARN 或模式。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种可选资源类型。
操作表的条件键列包括可以在策略语句的 Condition
元素中指定的键。有关与服务资源关联的条件键的更多信息,请参阅资源类型表的条件键列。
注意
资源条件键在资源类型表中列出。您可以在操作表的资源类型(* 为必需)列中找到应用于某项操作的资源类型的链接。资源类型表中的资源类型包括条件密钥列,这是应用于操作表中操作的资源条件键。
有关下表中各列的详细信息,请参阅操作表。
操作 | 描述 | 访问级别 | 资源类型(* 为必需) | 条件键 | 相关操作 |
---|---|---|---|---|---|
BatchDeleteBuilds | 授予权限以删除一个或多个构建 | 写入 | |||
BatchGetBuildBatches | 授予权限以获取一个或多个构建批处理的相关信息 | 读取 | |||
BatchGetBuilds | 授予权限以获取一个或多个构建的相关信息 | 读取 | |||
BatchGetFleets | 授予返回输入参数指定的 Fleet 对象数组的权限 | 读取 | |||
BatchGetProjects | 授予权限以获取一个或多个构建项目的相关信息 | 读取 | |||
BatchGetReportGroups | 授予返回由输入 reportGroupArns 参数指定的 ReportGroup 对象数组的权限 | 读取 | |||
BatchGetReports | 授予权限以返回由输入 reportArns 参数指定的 Report 对象的数组 | 读取 | |||
BatchPutCodeCoverages [仅权限] | 授予权限以添加或更新有关报告的信息 | 写入 | |||
BatchPutTestCases [仅权限] | 授予权限以添加或更新有关报告的信息 | 写入 | |||
CreateFleet | 授予创建计算队列的权限 | 写入 | |||
CreateProject | 授予权限以创建构建项目 | 写入 | |||
CreateReport [仅权限] | 授予权限以创建报告。当 buildspec 文件中为报告组指定的测试在项目构建期间运行时,将创建报告 | 写入 | |||
CreateReportGroup | 授予权限以创建报告组 | 写入 | |||
CreateWebhook | 授予权限以创建 Webhook。对于源代码存储在 GitHub 或 Bitbucket 存储库中的现有 AWS CodeBuild 构建项目, AWS CodeBuild 允许在每次将代码更改推送到存储库时开始重建源代码 | 写入 | |||
DeleteBuildBatch | 授予权限以删除构建批处理 | 写入 | |||
DeleteFleet | 授予删除计算队列的权限 | 写入 | |||
DeleteOAuthToken [仅权限] | 授予权限以删除来自连接的第三方 OAuth 提供商的 OAuth 令牌。仅在 AWS CodeBuild 控制台中使用 | 写入 | |||
DeleteProject | 授予权限以删除构建项目 | 写入 | |||
DeleteReport | 授予权限以删除报告 | 写入 | |||
DeleteReportGroup | 授予权限以删除报告组 | 写入 | |||
DeleteResourcePolicy | 授予权限以删除关联的项目或报告组的资源策略 | 权限管理 | |||
DeleteSourceCredentials | 授予删除一组 GitHub、 GitHub 企业版或 Bitbucket 源凭证的权限 | 写入 | |||
DeleteWebhook | 授予权限以删除 Webhook。对于源代码存储在 GitHub 或 Bitbucket 存储库中的现有 AWS CodeBuild 构建项目,每次将代码更改推送 AWS CodeBuild 到存储库时都停止重建源代码 | 写入 | |||
DescribeCodeCoverages | 授予返回 CodeCoverage 对象数组的权限 | 读取 | |||
DescribeTestCases | 授予返回 TestCase 对象数组的权限 | 读取 | |||
GetReportGroupTrend | 授予权限以分析和累积指定报告组中测试报告的测试报告值 | 读取 | |||
GetResourcePolicy | 授予权限以返回指定项目或报告组的资源策略 | 读取 | |||
ImportSourceCredentials | 授予导入源代码存储在 GitHub、E GitHub nterprise 或 Bitbucket 存储库中的 AWS CodeBuild 项目的源存储库凭据的权限 | 写入 | |||
InvalidateProjectCache | 授予权限以重置项目缓存 | 写入 | |||
ListBuildBatches | 授予权限以获取构建批处理 ID 的列表,其中每个构建批处理 ID 代表一个构建批处理 | 列出 | |||
ListBuildBatchesForProject | 授予权限以获取指定构建项目的构建批处理 ID 的列表,其中每个构建批处理 ID 代表一个构建批处理 | 列出 | |||
ListBuilds | 授予权限以获取构建 ID 的列表,其中每个构建 ID 代表一个构建 | 列出 | |||
ListBuildsForProject | 授予权限以获取指定构建项目的构建 ID 的列表,其中每个构建 ID 代表一个构建 | 列出 | |||
ListConnectedOAuthAccounts [仅权限] | 授予权限以列出已连接的第三方 OAuth 提供商。仅在 AWS CodeBuild 控制台中使用 | 列出 | |||
ListCuratedEnvironmentImages | 授予权限以获取有关由管理的 Docker 镜像的信息 AWS CodeBuild | 列出 | |||
ListFleets | 授予获取计算队列 ARN 列表的权限,每个计算队列 ARN 代表一个队列 | 列出 | |||
ListProjects | 授予权限以获取构建项目名称的列表,其中每个构建项目名称代表一个构建项目 | 列出 | |||
ListReportGroups | 授予权限以返回报告组 ARN 的列表。每个报告组 ARN 代表一个报告组 | 列出 | |||
ListReports | 授予权限以返回报告 ARN 的列表。每个报告 ARN 表示一个报告 | 列出 | |||
ListReportsForReportGroup | 授予权限以返回属于指定报告组的报告 ARN 的列表。每个报告 ARN 表示一个报告 | 列出 | |||
ListRepositories [仅权限] | 授予权限以列出来自已连接的第三方 OAuth 提供商的源代码存储库。仅在 AWS CodeBuild 控制台中使用 | 列出 | |||
ListSharedProjects | 授予权限以返回已与请求者共享的项目 ARN 的列表。每个项目 ARN 表示一个项目 | 列出 | |||
ListSharedReportGroups | 授予权限以返回已与请求者共享的报告组 ARN 的列表。每个报告组 ARN 代表一个报告组 | 列出 | |||
ListSourceCredentials | 授予返回 SourceCredentialsInfo 对象列表的权限 | 列出 | |||
PersistOAuthToken [仅权限] | 授予权限以保存来自连接的第三方 OAuth 提供商的 OAuth 令牌。仅在 AWS CodeBuild 控制台中使用 | 写入 | |||
PutResourcePolicy | 授予权限以为关联的项目或报告组创建资源策略 | 权限管理 | |||
RetryBuild | 授予权限以重试构建 | 写入 | |||
RetryBuildBatch | 授予权限以重试构建批处理 | 写入 | |||
StartBuild | 授予权限以开始运行构建 | 写入 | |||
StartBuildBatch | 授予权限以开始运行构建批处理 | 写入 | |||
StopBuild | 授予权限以尝试停止运行构建 | 写入 | |||
StopBuildBatch | 授予权限以尝试停止运行构建批处理 | 写入 | |||
UpdateFleet | 授予更改现有计算队列设置的权限 | 写入 | |||
UpdateProject | 授予权限以更改现有构建项目的设置 | 写入 | |||
UpdateProjectVisibility | 授予权限以更改项目及其构建的公共可见性 | 写入 | |||
UpdateReport [仅权限] | 授予权限以更新有关报告的信息 | 写入 | |||
UpdateReportGroup | 授予权限以更改现有报告组的设置 | 写入 | |||
UpdateWebhook | 授予更新与 AWS CodeBuild 构建项目关联的 webhook 的权限 | 写入 |
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}
|
|
report-group |
arn:${Partition}:codebuild:${Region}:${Account}:report-group/${ReportGroupName}
|
|
report |
arn:${Partition}:codebuild:${Region}:${Account}:report/${ReportGroupName}:${ReportId}
|
|
fleet |
arn:${Partition}:codebuild:${Region}:${Account}:fleet/${FleetName}:${FleetId}
|
AWS CodeBuild 的条件键
AWS CodeBuild 定义了可在 IAM 策略Condition
元素中使用的以下条件键。您可以使用这些键进一步细化应用策略语句的条件。有关下表中各列的详细信息,请参阅条件键表。
要查看适用于所有服务的全局条件键,请参阅可用的全局条件键。
条件键 | 描述 | 类型 |
---|---|---|
aws:RequestTag/${TagKey} | 根据在请求中是否具有标签键值对来按照操作筛选访问权限 | String |
aws:ResourceTag/${TagKey} | 根据附加到资源的标签键值对来按操作筛选访问权限 | String |
aws:TagKeys | 根据在请求中是否具有标签键来按操作筛选访问权限 | ArrayOfString |