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

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

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

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

参考:

AWS AppSync 定义的操作

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

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

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

注意

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

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

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

domain*

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

graphqlapi*

AssociateSourceGraphqlApi 授予将源与合并源关联API的权限 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 写入
CreateFunction 授予创建新函数的权限 写入
CreateGraphqlApi 授予创建 GraphQL 的权限API,这是顶级资源 AppSync 写入

aws:RequestTag/${TagKey}

aws:TagKeys

appsync:Visibility

iam:CreateServiceLinkedRole

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

api*

aws:ResourceTag/${TagKey}

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

channelNamespace*

aws:ResourceTag/${TagKey}

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

domain*

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

graphqlapi*

aws:ResourceTag/${TagKey}

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

domain*

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

mergedApiAssociation*

DisassociateSourceGraphqlApi 授予API从合并后API标识的合并源中移除关联源的权限 API 写入

sourceApiAssociation*

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*

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

graphqlapi*

aws:ResourceTag/${TagKey}

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

sourceApiAssociation*

GetType 授予权限以检索类型 读取
GraphQL 授予向 GraphQL 发送 GraphQL 查询的权限 API 写入

field*

graphqlapi*

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

aws:ResourceTag/${TagKey}

ListChannelNamespaces 授予列出频道命名空间的权限 列出

api*

aws:ResourceTag/${TagKey}

ListDataSources 授予列出给定数据源的权限 API 列出
ListDomainNames 授予枚举自定义域名的权限 AppSync 列出
ListFunctions 授予列出给定函数的权限 API 列出
ListGraphqlApis 授予列出 GraphQL 的权限 APIs 列出
ListResolvers 授予列出给定API和类型的解析器的权限 列出
ListResolversByFunction 授予列出与特定函数关联的解析程序的权限 列出
ListSourceApiAssociations 授予列出与给定合并APIs内容关联的来源的权限 API 列出
ListTagsForResource 授予列出资源标签的权限 读取

api

channelNamespace

graphqlapi

aws:ResourceTag/${TagKey}

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

field*

graphqlapi*

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

sourceApiAssociation*

TagResource 授予权限以标记资源 Tagging

api*

channelNamespace*

graphqlapi*

api

channelNamespace

graphqlapi

aws:RequestTag/${TagKey}

aws:ResourceTag/${TagKey}

aws:TagKeys

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

api*

channelNamespace*

graphqlapi*

api

channelNamespace

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*

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}
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元素中使用的以下条件键。您可以使用这些键进一步细化应用策略语句的条件。有关下表中各列的详细信息,请参阅条件键表

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

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