本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
AWS AppSync 的操作、资源和条件键
AWS AppSync (service prefix:appsync
) 提供以下特定于服务的资源、操作和条件上下文密钥,供在IAM权限策略中使用。
参考:
-
了解如何配置该服务。
-
查看此服务可用的API操作列表。
-
了解如何使用 IAM 权限策略保护该服务及其资源。
AWS AppSync 定义的操作
您可以在 Action
策略语句的 IAM 元素中指定以下操作。可以使用策略授予在 AWS中执行操作的权限。当您在策略中使用操作时,通常会允许或拒绝访问具有相同名称的API操作或CLI命令。但在某些情况下,单一动作可控制对多项操作的访问。还有某些操作需要多种不同的动作。
操作表的资源类型列指示每项操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource
元素中指定策略应用的所有资源(“*”)。如果该列包含资源类型,则可以在带有该操作ARN的语句中指定该类型的资源类型。如果操作具有一个或多个必需资源,则调用方必须具有使用这些资源来使用该操作的权限。必需资源在表中以星号 (*) 表示。如果您使用IAM策略中的Resource
元素限制资源访问权限,则必须为每种必需的资源类型包含ARN或模式。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种可选资源类型。
操作表的条件键列包括可以在策略语句的 Condition
元素中指定的键。有关与服务资源关联的条件键的更多信息,请参阅资源类型表的条件键列。
注意
资源条件键在资源类型表中列出。您可以在操作表的资源类型(* 为必需)列中找到应用于某项操作的资源类型的链接。资源类型表中的资源类型包括条件密钥列,这是应用于操作表中操作的资源条件键。
有关下表中各列的详细信息,请参阅操作表。
操作 | 描述 | 访问级别 | 资源类型(* 为必需) | 条件键 | 相关操作 |
---|---|---|---|---|---|
AssociateApi | 授予将 GraphQL 附加API到中的自定义域名的权限 AppSync | 写入 | |||
AssociateMergedGraphqlApi | 授予将合并后的API内容与源关联的权限 API | 写入 | |||
AssociateSourceGraphqlApi | 授予将源与合并源关联API的权限 API | 写入 | |||
CreateApi | 授予创建 API | 写入 |
iam:CreateServiceLinkedRole |
||
CreateApiCache | 授予在中创建API缓存的权限 AppSync | 写入 | |||
CreateApiKey | 授予创建唯一密钥的权限,您可以将其分发给正在执行您的密钥的客户 API | 写入 | |||
CreateChannelNamespace | 授予创建频道命名空间的权限 | 写入 | |||
CreateDataSource | 授予创建数据源的权限 | 写入 | |||
CreateDomainName | 授予在中创建自定义域名的权限 AppSync | 写入 | |||
CreateFunction | 授予创建新函数的权限 | 写入 | |||
CreateGraphqlApi | 授予创建 GraphQL 的权限API,这是顶级资源 AppSync | 写入 |
iam:CreateServiceLinkedRole |
||
CreateResolver | 授予权限以创建解析程序。解析程序可将传入请求转换为数据源可以理解的格式,并将数据源的响应转换为 GraphQL | 写入 | |||
CreateType | 授予权限以创建类型。 | 写入 | |||
DeleteApi | 授予删除 a 的权限API。这还将清理低于该 AppSync 资源的所有资源 API | 写入 | |||
DeleteApiCache | 授予删除中API缓存的权限 AppSync | 写入 | |||
DeleteApiKey | 授予删除API密钥的权限 | 写入 | |||
DeleteChannelNamespace | 授予删除频道命名空间的权限 | 写入 | |||
DeleteDataSource | 授予删除数据源的权限 | 写入 | |||
DeleteDomainName | 授予在中删除自定义域名的权限 AppSync | 写入 | |||
DeleteFunction | 授予权限以删除函数 | 写入 | |||
DeleteGraphqlApi | 授予权限以删除 GraphQL API。这还将清理低于该 AppSync 资源的所有资源 API | 写入 | |||
DeleteResolver | 授予权限以删除解析程序 | 写入 | |||
DeleteResourcePolicy[仅权限] | 授予删除资源策略的权限 | 写入 | |||
DeleteType | 授予删除类型的权限。 | 写入 | |||
DisassociateApi | 授予将 G API raphQL 与中的自定义域名分离 AppSync | 写入 | |||
DisassociateMergedGraphqlApi | 授予API从源API标识的合并源中移除关联源的权限 API | 写入 | |||
DisassociateSourceGraphqlApi | 授予API从合并后API标识的合并源中移除关联源的权限 API | 写入 | |||
EvaluateCode | 授予使用运行时和上下文评估代码的权限 | 读取 | |||
EvaluateMappingTemplate | 授予权限以评估模板映射 | 读取 | |||
EventConnect | 授予连接活动的权限 API | 写入 | |||
EventPublish | 授予将事件发布到频道命名空间的权限 | 写入 | |||
EventSubscribe | 授予订阅频道命名空间的权限 | 写入 | |||
FlushApiCache | 授予刷新API缓存的权限 AppSync | 写入 | |||
GetApi | 授予检索权限 API | 读取 | |||
GetApiAssociation | 授予读取自定义域名-GraphQL API 关联详细信息的权限 AppSync | 读取 | |||
GetApiCache | 授予读取有关API缓存信息的权限 AppSync | 读取 | |||
GetChannelNamespace | 授予检索频道命名空间的权限 | 读取 | |||
GetDataSource | 授予检索数据来源的权限 | 读取 | |||
GetDataSourceIntrospection | 授予检索数据来源自检的权限 | 读取 | |||
GetDomainName | 授予读取有关自定义域名的信息的权限 AppSync | 读取 | |||
GetFunction | 授予检索函数的权限 | 读取 | |||
GetGraphqlApi | 授予检索 GraphQL 的权限 API | 读取 | |||
GetGraphqlApiEnvironmentVariables | 授予检索 GraphQL 环境变量的权限 API | 读取 | |||
GetIntrospectionSchema | 授予检索 GraphQL 内省架构的权限 API | 读取 | |||
GetResolver | 授予检索解析程序的权限 | 读取 | |||
GetResourcePolicy[仅权限] | 授予读取资源策略的权限 | 读取 | |||
GetSchemaCreationStatus | 授予检索架构创建操作当前状态的权限 | 读取 | |||
GetSourceApiAssociation | 授予读取有关合并API关联源信息的权限 API | 读取 | |||
GetType | 授予权限以检索类型 | 读取 | |||
GraphQL | 授予向 GraphQL 发送 GraphQL 查询的权限 API | 写入 | |||
ListApiKeys | 授予列出给定API密钥的权限 API | 列出 | |||
ListApis | 授予上架权限 APIs | 列出 | |||
ListChannelNamespaces | 授予列出频道命名空间的权限 | 列出 | |||
ListDataSources | 授予列出给定数据源的权限 API | 列出 | |||
ListDomainNames | 授予枚举自定义域名的权限 AppSync | 列出 | |||
ListFunctions | 授予列出给定函数的权限 API | 列出 | |||
ListGraphqlApis | 授予列出 GraphQL 的权限 APIs | 列出 | |||
ListResolvers | 授予列出给定API和类型的解析器的权限 | 列出 | |||
ListResolversByFunction | 授予列出与特定函数关联的解析程序的权限 | 列出 | |||
ListSourceApiAssociations | 授予列出与给定合并APIs内容关联的来源的权限 API | 列出 | |||
ListTagsForResource | 授予列出资源标签的权限 | 读取 | |||
ListTypes | 授予列出给定类型的权限 API | 列出 | |||
ListTypesByAssociation | 授予列出给定合并关联API和源API关联的类型的权限 | 列出 | |||
PutGraphqlApiEnvironmentVariables | 授予更新 GraphQL 环境变量的权限 API | 写入 | |||
PutResourcePolicy[仅权限] | 授予设置资源策略的权限 | 写入 | |||
SetWebACL | 授予设置网站的权限 ACL | 写入 | |||
SourceGraphQL[仅权限] | 授予向合并后的源发送 GraphQL 查询API的权限 API | 写入 | |||
StartDataSourceIntrospection | 授予进行数据来源自检的权限 | 写入 | |||
StartSchemaCreation | 授予向 Graph API QL 添加新架构的权限。此操作是异步的- GetSchemaCreationStatus 可以显示何时完成 | 写入 | |||
StartSchemaMerge | 授予为给定的合并API和关联源启动架构合并的权限 API | 写入 | |||
TagResource | 授予权限以标记资源 | Tagging | |||
UntagResource | 授予权限以取消标记资源 | 标记 | |||
UpdateApi | 授予更新权限 API | 写入 |
iam:CreateServiceLinkedRole |
||
UpdateApiCache | 授予更新中API缓存的权限 AppSync | 写入 | |||
UpdateApiKey | 授予更新给定API密钥的权限 API | 写入 | |||
UpdateChannelNamespace | 授予更新频道命名空间的权限 | 写入 | |||
UpdateDataSource | 授予权限以更新数据源 | 写入 | |||
UpdateDomainName | 授予在中更新自定义域名的权限 AppSync | 写入 | |||
UpdateFunction | 授予更新现有函数对象的权限 | 写入 | |||
UpdateGraphqlApi | 授予更新 GraphQL 的权限 API | 写入 |
iam:CreateServiceLinkedRole |
||
UpdateResolver | 授予权限以更新预留程序 | 写入 | |||
UpdateSourceApiAssociation | 授予更新合并API源API关联的权限 | 写入 | |||
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}
|
|
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}
|
|
channelNamespace |
arn:${Partition}:appsync:${Region}:${Account}:apis/${ApiId}/channelNamespace/${ChannelNamespaceName}
|
AWS AppSync 的条件键
AWS AppSync 定义了可以在IAM策略Condition
元素中使用的以下条件键。您可以使用这些键进一步细化应用策略语句的条件。有关下表中各列的详细信息,请参阅条件键表。
要查看适用于所有服务的全局条件键,请参阅可用的全局条件键。
条件键 | 描述 | Type |
---|---|---|
appsync:Visibility | 根据可见性筛选访问权限 API | String |
aws:RequestTag/${TagKey} | 按请求中的标签键值对筛选访问 | String |
aws:ResourceTag/${TagKey} | 按附加到资源的标签键值对筛选访问权限 | String |
aws:TagKeys | 根据在请求中是否具有标签键来筛选访问 | ArrayOfString |