AWS CodeArtifact 的操作、资源和条件键 - 服务授权参考

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

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

AWS CodeArtifact (服务前缀:codeartifact)提供以下特定于服务的资源、操作和条件上下文密钥,用于IAM权限策略。

参考:

AWS CodeArtifact 定义的操作

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

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

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

注意

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

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

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
AssociateExternalConnection 授予向存储库添加外部连接的权限 Write

repository*

AssociateWithDownstreamRepository 授予将现有存储库作为上游存储库与另一个存储库关联的权限 写入

repository*

CopyPackageVersions 授予将程序包版本从一个存储库复制到同一域中的另一个存储库的权限 写入

package*

repository*

CreateDomain 授予创建新域的权限 写入

aws:RequestTag/${TagKey}

aws:TagKeys

CreatePackageGroup 授予权限以创建软件包组 写入

aws:RequestTag/${TagKey}

aws:TagKeys

CreateRepository 授予创建新存储库的权限 Write

aws:RequestTag/${TagKey}

aws:TagKeys

DeleteDomain 授予权限以删除域 Write

domain*

DeleteDomainPermissionsPolicy 授予删除域上的资源策略集的权限 权限管理

domain*

DeletePackage 授予删除软件包的权限 写入

package*

DeletePackageGroup 授予权限以删除软件包组 写入

package-group*

DeletePackageVersions 授予删除程序包版本的权限 Write

package*

DeleteRepository 授予删除存储库的权限 Write

repository*

DeleteRepositoryPermissionsPolicy 授予删除存储库上的资源策略集的权限 Permissions management

repository*

DescribeDomain 授予返回有关域的信息的权限 读取

domain*

DescribePackage 授予权限以检索有关程序包的信息 读取

package*

DescribePackageGroup 授予权限以返回有关软件包组的详细信息 读取

package-group*

DescribePackageVersion 授予返回有关程序包版本的信息的权限 Read

package*

DescribeRepository 授予返回有关存储库的详细信息的权限 Read

repository*

DisassociateExternalConnection 授予取消外部连接与存储库的关联的权限 Write

repository*

DisposePackageVersions 授予将程序包版本的状态设置为“已释放”并删除其资产的权限 写入

package*

GetAssociatedPackageGroup 授予权限以返回软件包的关联软件包组 读取

package-group*

GetAuthorizationToken 授予生成临时身份验证令牌以访问域中的存储库的权限 Read

domain*

GetDomainPermissionsPolicy 授予返回域的资源策略的权限 Read

domain*

GetPackageVersionAsset 授予返回属于程序包版本一部分的资产(或文件)的权限 Read

package*

GetPackageVersionReadme 授予返回程序包版本的自述文件的权限 Read

package*

GetRepositoryEndpoint 授予返回存储库的终端节点的权限 Read

repository*

GetRepositoryPermissionsPolicy 授予返回存储库的资源策略的权限 读取

repository*

ListAllowedRepositoriesForGroup 授予权限以列出软件包组允许的存储库 列表

package-group*

ListAssociatedPackages 授予权限以列出与软件包组关联的软件包 列表

package-group*

ListDomains 授予列出当前用户域名的权限 AWS 账户 列表
ListPackageGroups 授予权限以列出域中的软件包组 列表

domain*

ListPackageVersionAssets 授予列出程序包版本的资产的权限 List

package*

ListPackageVersionDependencies 授予列出程序包版本的直接依赖项的权限 List

package*

ListPackageVersions 授予列出程序包的版本的权限 List

package*

ListPackages 授予列出存储库中的程序包的权限 List

repository*

ListRepositories 授予列出由调用账户管理的存储库的权限 List
ListRepositoriesInDomain 授予列出域中的存储库的权限 列表

domain*

ListSubPackageGroups 授予权限以列出父软件包组的子软件包组 列表

package-group*

ListTagsForResource 授予列出 CodeArtifact 资源标签的权限 列表

domain

package-group

repository

PublishPackageVersion 授予将资产和元数据发布到存储库终端节点的权限 Write

package*

PutDomainPermissionsPolicy 授予将资源策略附加到域的权限 Write

domain*

PutPackageMetadata 授予使用存储库终端节点添加、修改或删除程序包元数据的权限 写入

package*

PutPackageOriginConfiguration 授予权限以便为程序包设置源配置 写入

package*

PutRepositoryPermissionsPolicy 授予将资源策略附加到存储库的权限 Write

repository*

ReadFromRepository 授予从存储库终端节点返回程序包资产和元数据的权限 读取

repository*

TagResource 授予为 CodeArtifact 资源添加标签的权限 标记

domain

package-group

repository

aws:RequestTag/${TagKey}

aws:TagKeys

UntagResource 授予从 CodeArtifact 资源中移除标签的权限 标记

domain

package-group

repository

aws:TagKeys

UpdatePackageGroup 授予权限以修改软件包组的属性 写入

package-group*

UpdatePackageGroupOriginConfiguration 授予权限以修改软件包组的软件包源配置 写入

package-group*

UpdatePackageVersionsStatus 授予修改程序包的一个或多个版本的状态的权限 Write

package*

UpdateRepository 授予修改存储库的属性的权限 写入

repository*

AWS CodeArtifact 定义的资源类型

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

注意

包ARN组资源必须使用编码的包组模式。

资源类型 ARN 条件键
domain arn:${Partition}:codeartifact:${Region}:${Account}:domain/${DomainName}

aws:ResourceTag/${TagKey}

repository arn:${Partition}:codeartifact:${Region}:${Account}:repository/${DomainName}/${RepositoryName}

aws:ResourceTag/${TagKey}

package-group arn:${Partition}:codeartifact:${Region}:${Account}:package-group/${DomainName}${EncodedPackageGroupPattern}

aws:ResourceTag/${TagKey}

package arn:${Partition}:codeartifact:${Region}:${Account}:package/${DomainName}/${RepositoryName}/${PackageFormat}/${PackageNamespace}/${PackageName}

AWS CodeArtifact 的条件键

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

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

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