AWS Identity and Access Management
用户指南
AWS 文档中描述的 AWS 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 AWS 服务入门

Amazon SNS 的操作、资源和条件键

Amazon SNS(服务前缀:sns)提供以下服务特定的资源、操作和条件上下文键以在 IAM 权限策略中使用。

参考:

Amazon SNS 定义的操作

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

资源列指示每个操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource 元素中指定所有资源(“*”)。如果该列包含一种资源类型,则可以在含有该操作的语句中指定该类型的 ARN。必需资源在表中以星号 (*) 表示。如果在使用该操作的语句中指定资源级权限 ARN,则它必须属于该类型。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种类型而不使用其他类型。

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

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
AddPermission 向主题的访问控制策略添加一个语句,允许指定的 AWS 账户完成指定操作。 权限管理

topic*

CheckIfPhoneNumberIsOptedOut 接受电话号码并指明电话持有者是否已选择不接收来自您的账户的 SMS 消息。 Read
ConfirmSubscription 通过之前的订阅操作验证发送到终端节点的令牌,从而验证终端节点所有者接收消息的意图。 写入

topic*

CreatePlatformApplication 为设备和移动应用程序可能注册的受支持推送通知服务(如 APNS 和 GCM)之一创建平台应用程序对象。 写入
CreatePlatformEndpoint 为受支持推送通知服务(例如 GCM 和 APNS)之一上的设备和移动应用程序创建终端节点。 写入
CreateTopic 创建可以发布通知的主题。 写入

topic*

DeleteEndpoint 从 Amazon SNS 中删除设备和移动应用程序的终端节点。 写入
DeletePlatformApplication 删除用于受支持推送通知服务(例如 APNS 和 GCM)之一的平台应用程序对象。 写入
DeleteTopic 删除主题及其所有订阅。 写入

topic*

GetEndpointAttributes 为受支持推送通知服务(GCM 和 APNS)之一上的设备检索终端节点属性。 Read
GetPlatformApplicationAttributes 检索用于受支持推送通知服务(例如 APNS 和 GCM)的平台应用程序对象的属性。 Read
GetSMSAttributes 返回用于从您的账户中发送 SMS 消息的设置。 Read
GetSubscriptionAttributes 返回订阅的所有属性。 Read
GetTopicAttributes 返回主题的所有属性。返回的主题属性会因用户授权而有所不同。 Read

topic*

ListEndpointsByPlatformApplication 列出受支持推送通知服务(例如 GCM 和 APNS)中的设备的终端节点和终端节点属性。 List
ListPhoneNumbersOptedOut 返回已退出电话号码的列表,这意味着您无法向这些电话号码发送 SMS 消息。 Read
ListPlatformApplications 列出用于受支持推送通知服务(例如 APNS 和 GCM)的平台应用程序对象。 List
ListSubscriptions 返回请求者的订阅列表。 List
ListSubscriptionsByTopic 返回特定主题的订阅列表。 List

topic*

ListTagsForResource 列出添加到指定 Amazon SNS 主题的所有标签。 Read

topic

ListTopics 返回请求者的主题列表。每次调用都会返回一个有限的主题列表,最大值为 100。 List
OptInPhoneNumber 加入当前已退出的电话号码,这样您便可以继续向该号码发送 SMS 消息。 写入
Publish 向主题的所有订阅终端节点发送消息。 写入

topic*

RemovePermission 从主题的访问控制策略中删除语句。 权限管理

topic*

SetEndpointAttributes 为受支持推送通知服务(GCM 和 APNS)之一上的设备设置终端节点属性。 写入
SetPlatformApplicationAttributes 为用于受支持推送通知服务(例如 APNS 和 GCM)的平台应用程序对象设置属性。 写入
SetSubscriptionAttributes 允许订阅所有者将主题的属性设置为新值。 写入
SetTopicAttributes 允许主题所有者将主题的属性设置为新值。 写入

topic*

Subscribe 准备通过向终端节点发送确认消息来订阅终端节点。 写入

topic*

sns:Endpoint

sns:Protocol

TagResource 将标签添加到指定的 Amazon SNS 主题中。 标记

topic

aws:RequestTag/${TagKey}

aws:TagKeys

Unsubscribe 删除订阅。如果订阅需要身份验证才能删除,则只有订阅的所有者或主题的所有者可以取消订阅,并且需要 AWS 签名。 写入
UntagResource 从指定的 Amazon SNS 主题中删除标签。 标记

topic

aws:RequestTag/${TagKey}

aws:TagKeys

Amazon SNS 定义的资源

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

资源类型 ARN 条件键
topic arn:${Partition}:sns:${Region}:${Account}:${TopicName}

用于 Amazon SNS 的条件键

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

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

条件键 描述 类型
aws:RequestTag/${TagKey} 请求中的标签 字符串
aws:TagKeys 请求中的标签键 字符串
sns:Endpoint 来自订阅请求或之前已确认订阅的 URL、电子邮件地址或 ARN。 字符串
sns:Protocol 来自订阅请求或之前已确认订阅的协议值。 字符串