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

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

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

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

参考:

AWS AppSync 定义的操作

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

操作表的访问级别列描述如何对操作进行分类(列出、读取、权限管理或标记)。此分类可以帮助您了解当您在策略中使用操作时,相应操作授予的访问级别。有关访问级别的更多信息,请参阅策略摘要中的访问级别

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

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

操作表的依赖操作列显示成功调用操作可能需要的其他权限。除了操作本身的权限以外,可能还需要这些权限。若某个操作指定依赖操作,则这些依赖关系可能适用于为该操作定义的其他资源,而不仅仅是表中列出的第一个资源。

注意

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

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

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
AssociateApi 授予将 GraphQL API 附加到中的自定义域名的权限 AppSync 写入

domain*

AssociateMergedGraphqlApi 授予将合并的 API 与源 API 关联的权限 写入

graphqlapi*

AssociateSourceGraphqlApi 授予将源 API 与合并的 API 关联的权限 写入

graphqlapi*

AssociateWebACL [仅权限] 授予关联 Web ACL 和资源的权限 写入

api

graphqlapi

CreateApi 授予权限以创建 API 写入

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

iam:CreateServiceLinkedRole

CreateApiCache 授予在中创建 API 缓存的权限 AppSync 写入
CreateApiKey 授予创建唯一密钥以分发到执行您的 API 的客户端的权限 写入
CreateChannelNamespace 授予权限以创建渠道命名空间 写入

channelNamespace*

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

CreateDataSource 授予创建数据源的权限 写入
CreateDomainName 授予在中创建自定义域名的权限 AppSync 写入

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

CreateFunction 授予创建新函数的权限 写入
CreateGraphqlApi 授予创建 GraphQL API 的权限,这是顶级资源 AppSync 写入

aws:RequestTag/${TagKey}

aws:TagKeys

appsync:Visibility

iam:CreateServiceLinkedRole

CreateResolver 授予权限以创建解析程序。解析程序可将传入请求转换为数据源可以理解的格式,并将数据源的响应转换为 GraphQL 写入
CreateType 授予权限以创建类型。 写入
DeleteApi 授予权限以删除 API。这还将清理该 API 下的所有 AppSync 资源 写入

api*

aws:ResourceTag/${TagKey}

DeleteApiCache 授予在中删除 API 缓存的权限 AppSync 写入
DeleteApiKey 授予删除 API 密钥的权限 写入
DeleteChannelNamespace 授予权限以删除渠道命名空间 写入

channelNamespace*

aws:ResourceTag/${TagKey}

DeleteDataSource 授予删除数据源的权限 写入
DeleteDomainName 授予在中删除自定义域名的权限 AppSync 写入

domain*

aws:ResourceTag/${TagKey}

DeleteFunction 授予权限以删除函数 写入
DeleteGraphqlApi 授予权限以删除 GraphQL API。这还将清理该 API 下的所有 AppSync 资源 写入

graphqlapi*

aws:ResourceTag/${TagKey}

DeleteResolver 授予权限以删除解析程序 写入
DeleteResourcePolicy [仅权限] 授予删除资源策略的权限 写入
DeleteType 授予删除类型的权限。 写入
DisassociateApi 授予将 GraphQL API 分离到中的自定义域名的权限 AppSync 写入

domain*

DisassociateMergedGraphqlApi 授予从源 API 识别的合并 API 中删除关联的源 API 的权限 写入

mergedApiAssociation*

DisassociateSourceGraphqlApi 授予从合并的 API 识别的合并 API 中删除关联的源 API 的权限 写入

sourceApiAssociation*

DisassociateWebACL [仅权限] 授予解除 Web ACL 与资源的关联的权限 写入

api

graphqlapi

EvaluateCode 授予使用运行时和上下文评估代码的权限 读取
EvaluateMappingTemplate 授予权限以评估模板映射 读取
EventConnect 授予权限以连接事件 API 写入

api*

EventPublish 授予权限以将事件发布到渠道命名空间 写入

channelNamespace*

EventSubscribe 授予权限以订阅渠道命名空间 写入

channelNamespace*

FlushApiCache 授予刷新 API 缓存的权限 AppSync 写入
GetApi 授予权限以检索 API 读取

api*

aws:ResourceTag/${TagKey}

GetApiAssociation 授予读取自定义域名的权限-GraphQL API 关联详情 AppSync 读取

domain*

GetApiCache 授予读取有关 API 缓存信息的权限 AppSync 读取
GetChannelNamespace 授予权限以检索渠道命名空间 读取

channelNamespace*

aws:ResourceTag/${TagKey}

GetDataSource 授予检索数据来源的权限 读取
GetDataSourceIntrospection 授予检索数据来源自检的权限 读取
GetDomainName 授予读取有关自定义域名的信息的权限 AppSync 读取

domain*

aws:ResourceTag/${TagKey}

GetFunction 授予检索函数的权限 读取
GetGraphqlApi 授予检索 GraphQL API 的权限 读取

graphqlapi*

aws:ResourceTag/${TagKey}

GetGraphqlApiEnvironmentVariables 授予权限以检索 GraphQL API 的环境变量 读取
GetIntrospectionSchema 授予检索 GraphQL API 的自检架构的权限 读取
GetResolver 授予检索解析程序的权限 读取
GetResourcePolicy [仅权限] 授予读取资源策略的权限 读取
GetSchemaCreationStatus 授予检索架构创建操作当前状态的权限 读取
GetSourceApiAssociation 授予读取有关合并 API 关联的源 API 的信息的权限 读取

sourceApiAssociation*

GetType 授予权限以检索类型 读取
GetWebACLForResource [仅权限] 授予获取资源关联网站 ACLs 的权限 读取

api

graphqlapi

GraphQL [仅权限] 授予向 GraphQL API 发送 GraphQL 查询的权限 写入

field*

graphqlapi*

ListApiKeys 授予列出给定 API 的 API 密钥的权限 列表
ListApis 授予上架权限 APIs 列表

aws:ResourceTag/${TagKey}

ListChannelNamespaces 授予权限以列出渠道命名空间 列表

api*

aws:ResourceTag/${TagKey}

ListDataSources 授予列出给定 API 的数据源的权限 列表
ListDomainNames 授予枚举自定义域名的权限 AppSync 列表

aws:ResourceTag/${TagKey}

ListFunctions 授予列出给定 API 的函数的权限 列表
ListGraphqlApis 授予列出 GraphQL 的权限 APIs 列表
ListResolvers 授予列出给定 API 和类型的解析程序的权限 列表
ListResolversByFunction 授予列出与特定函数关联的解析程序的权限 列表
ListResourcesForWebACL [仅权限] 授予获取 Web ACL 关联资源的权限 列表
ListSourceApiAssociations 授予列出与给定合并 API APIs 关联的源的权限 列表
ListTagsForResource 授予列出资源标签的权限 读取

api

channelNamespace

domain

graphqlapi

aws:ResourceTag/${TagKey}

ListTypes 授予列出给定 API 类型的权限 列表
ListTypesByAssociation 授予列出给定的合并 API 和源 API 关联的类型的权限 列表
PutGraphqlApiEnvironmentVariables 授予权限以更新 GraphQL API 的环境变量 写入
PutResourcePolicy [仅权限] 授予设置资源策略的权限 写入
SetWebACL 授予设置 Web ACL 的权限 权限管理
SourceGraphQL [仅权限] 授予将 GraphQL 查询发送到合并 API 的源 API 的权限 写入

field*

graphqlapi*

StartDataSourceIntrospection 授予进行数据来源自检的权限 写入
StartSchemaCreation 授予向 GraphQL API 添加新架构的权限。此操作是异步的- GetSchemaCreationStatus 可以显示何时完成 写入
StartSchemaMerge 授予为给定的合并 API 和关联的源 API 启动架构合并的权限 写入

sourceApiAssociation*

TagResource 授予权限以标记资源 Tagging

api

channelNamespace

domain

graphqlapi

aws:RequestTag/${TagKey}

aws:ResourceTag/${TagKey}

aws:TagKeys

UntagResource 授予权限以取消标记资源 标签

api

channelNamespace

domain

graphqlapi

aws:TagKeys

aws:ResourceTag/${TagKey}

UpdateApi 授予权限以更新 API 写入

api*

iam:CreateServiceLinkedRole

aws:ResourceTag/${TagKey}

UpdateApiCache 授予更新 API 缓存的权限 AppSync 写入
UpdateApiKey 授予更新给定 API 的 API 密钥的权限 写入
UpdateChannelNamespace 授予权限以更新渠道命名空间 写入

channelNamespace*

aws:ResourceTag/${TagKey}

UpdateDataSource 授予权限以更新数据源 写入
UpdateDomainName 授予在中更新自定义域名的权限 AppSync 写入

domain*

aws:ResourceTag/${TagKey}

UpdateFunction 授予更新现有函数对象的权限 写入
UpdateGraphqlApi 授予权限以更新 GraphQL API 写入

graphqlapi*

iam:CreateServiceLinkedRole

aws:ResourceTag/${TagKey}

UpdateResolver 授予权限以更新预留程序 写入
UpdateSourceApiAssociation 授予更新合并的 API 源 API 关联的权限 写入

sourceApiAssociation*

UpdateType 授予权限以更新类型 写入

AWS AppSync 定义的资源类型

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

资源类型 ARN 条件键
datasource arn:${Partition}:appsync:${Region}:${Account}:apis/${GraphQLAPIId}/datasources/${DatasourceName}
domain arn:${Partition}:appsync:${Region}:${Account}:domainnames/${DomainName}

aws:ResourceTag/${TagKey}

graphqlapi arn:${Partition}:appsync:${Region}:${Account}:apis/${GraphQLAPIId}

aws:ResourceTag/${TagKey}

field arn:${Partition}:appsync:${Region}:${Account}:apis/${GraphQLAPIId}/types/${TypeName}/fields/${FieldName}
type arn:${Partition}:appsync:${Region}:${Account}:apis/${GraphQLAPIId}/types/${TypeName}
function arn:${Partition}:appsync:${Region}:${Account}:apis/${GraphQLAPIId}/functions/${FunctionId}
sourceApiAssociation arn:${Partition}:appsync:${Region}:${Account}:apis/${MergedGraphQLAPIId}/sourceApiAssociations/${Associationid}
mergedApiAssociation arn:${Partition}:appsync:${Region}:${Account}:apis/${SourceGraphQLAPIId}/mergedApiAssociations/${Associationid}
api arn:${Partition}:appsync:${Region}:${Account}:apis/${ApiId}

aws:ResourceTag/${TagKey}

channelNamespace arn:${Partition}:appsync:${Region}:${Account}:apis/${ApiId}/channelNamespace/${ChannelNamespaceName}

aws:ResourceTag/${TagKey}

AWS AppSync 的条件键

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

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

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