身份策略授权参考
云服务在IAM预置了常用的权限,称为系统身份策略。如果IAM系统身份策略无法满足授权要求,管理员可以根据各服务支持的授权项,创建IAM自定义身份策略来进行精细的访问控制,IAM自定义身份策略是对系统身份策略的扩展和补充。
除IAM服务外,Organizations服务中的服务控制策略(Service Control Policy,以下简称SCP)也可以使用这些授权项元素设置访问控制策略。
SCP不直接进行授权,只划定权限边界。将SCP绑定到组织单元或者成员账号时,并没有直接对组织单元或成员账号授予操作权限,而是规定了成员账号或组织单元包含的成员账号的授权范围。IAM身份策略授予权限的有效性受SCP限制,只有在SCP允许范围内的权限才能生效。
IAM服务与Organizations服务在使用这些元素进行访问控制时,存在着一些区别,详情请参见:IAM服务与Organizations服务权限访问控制的区别。
本章节介绍IAM服务身份策略授权场景中自定义身份策略和组织服务中SCP使用的元素,这些元素包含了操作(Action)、资源(Resource)和条件(Condition)。
操作(Action)
操作(Action)即为身份策略中支持的授权项。
- “访问级别”列描述如何对操作进行分类(List、Read和Write等)。此分类可帮助您了解在身份策略中相应操作对应的访问级别。
- “资源类型”列指每个操作是否支持资源级权限。
- 资源类型支持通配符号*表示所有。如果此列没有值(-),则必须在身份策略语句的Resource元素中指定所有资源类型(“*”)。
- 如果该列包含资源类型,则必须在具有该操作的语句中指定该资源的URN。
- 资源类型列中必需资源在表中用星号(*)标识,表示使用此操作必须指定该资源类型。
关于RGC定义的资源类型的详细信息请参见资源类型(Resource)。
- “条件键”列包括了可以在身份策略语句的Condition元素中支持指定的键值。
- 如果该授权项资源类型列存在值,则表示条件键仅对列举的资源类型生效。
- 如果该授权项资源类型列没有值(-),则表示条件键对整个授权项生效。
- 如果此列条件键没有值(-),表示此操作不支持指定条件键。
关于RGC定义的条件键的详细信息请参见条件(Condition)。
- “别名”列包括了可以在身份策略中配置的策略授权项。通过这些授权项,可以控制支持策略授权的API访问。详细信息请参见身份策略兼容性说明。
您可以在身份策略语句的Action元素中指定以下RGC的相关操作。
授权项 | 描述 | 访问级别 | 资源类型(*为必须) | 条件键 | 别名 |
|---|---|---|---|---|---|
rgc:control:list | 授予列出控制策略的权限。 | List | - | - | - |
rgc:controlViolation:list | 授予列出不合规信息的权限。 | List | - | - | - |
rgc:control:get | 授予获取控制策略详细信息的权限。 | Read | - | - | - |
rgc:control:enable | 授予开启控制策略的权限。 | Write | - | - | - |
rgc:control:disable | 授予关闭控制策略的权限。 | Write | - | - | - |
rgc:controlOperate:get | 授予获取控制策略操作状态的权限。 | Read | - | - | - |
rgc:enabledControl:list | 授予列出开启的控制策略的权限。 | List | - | - | - |
rgc:controlsForOrganizationalUnit:list | 授予列出某个注册组织单元下开启的控制策略的权限。 | List | - | - | - |
rgc:controlsForAccount:list | 授予列出某个纳管账号开启的控制策略的权限。 | List | - | - | - |
rgc:complianceStatusForAccount:get | 授予获取组织里某个纳管账号的资源合规状态的权限。 | Read | - | - | - |
rgc:complianceStatusForOrganizationalUnit:get | 授予获取组织里某个注册组织单元下所有纳管账号的资源合规状态的权限。 | Read | - | - | - |
rgc:controlsForOrganizationalUnit:get | 授予获取某个组织单元开启的控制策略的权限。 | Read | - | - | - |
rgc:controlsForAccount:get | 授予获取某个账号开启的控制策略的权限。 | Read | - | - | - |
rgc:configRuleCompliance:list | 授予列出纳管账号的Config规则合规性信息的权限。 | List | - | - | - |
rgc:externalConfigRuleCompliance:list | 授予列出纳管账号的外部Config规则合规性信息的权限。 | List | - | - | - |
rgc:driftDetail:list | 授予列出漂移信息的权限。 | List | - | - | - |
rgc:managedOrganizationalUnit:register | 授予注册组织单元的权限。 | Write | - | - | - |
rgc:managedOrganizationalUnit:reRegister | 授予重新注册组织单元的权限。 | Write | - | - | - |
rgc:managedOrganizationalUnit:deRegister | 授予取消注册组织单元的权限。 | Write | - | - | - |
rgc:operation:get | 授予获取注册过程信息的权限。 | Read | - | - | - |
rgc:managedOrganizationalUnit:delete | 授予删除注册组织单元的权限。 | Write | - | - | - |
rgc:managedOrganizationalUnit:get | 授予获取已注册组织单元的权限。 | Read | - | - | - |
rgc:managedOrganizationalUnit:create | 授予创建组织单元的权限。 | Write | - | - | - |
rgc:managedOrganizationalUnit:list | 授予列举控制策略生效的注册组织单元信息的权限。 | List | - | - | - |
rgc:managedAccount:enroll | 授予纳管账号的权限。 | Write | - | - | - |
rgc:managedAccount:unEnroll | 授予取消纳管账号的权限。 | Write | - | - | - |
rgc:managedAccount:update | 授予更新纳管账号的权限。 | Write | - | - | - |
rgc:managedAccount:get | 授予获取纳管账号的权限。 | Read | - | - | - |
rgc:managedAccountsForParent:list | 授予列出注册组织单元下所有纳管账号信息的权限。 | List | - | - | - |
rgc:managedAccount:create | 授予创建账号的权限。 | Write | - | - | - |
rgc:managedAccount:list | 授予列出控制策略生效的纳管账号信息的权限。 | List | - | - | - |
rgc:managedCoreAccount:get | 授予获取核心纳管账号的权限。 | Read | - | - | - |
rgc:homeRegion:get | 授予查询主区域的权限。 | Read | - | - | - |
rgc:preLaunch:check | 授予设置Landing Zone前检查的权限。 | Write | - | - | - |
rgc:landingZone:setup | 授予设置Landing Zone的权限。 | Write | - | - | - |
rgc:landingZone:delete | 授予删除Landing Zone的权限。 | Write | - | - | - |
rgc:landingZoneStatus:get | 授予获取查询Landing Zone设置状态的权限。 | Read | - | - | - |
rgc:availableUpdate:get | 授予获取Landing Zone可更新状态的权限。 | Read | - | - | - |
rgc:landingZoneConfiguration:get | 授予获取Landing Zone配置信息的权限。 | Read | - | - | - |
rgc:landingZoneIdentityCenter:get | 授予获取当前客户的Identity Center用户信息的权限。 | Read | - | - | - |
rgc:operation:list | 授予获取注册组织单元或纳管账号的当前操作状态的权限。 | List | - | - | - |
rgc:templateDeployParam:get | 授予获取模板部署参数的权限。 | Read | - | - | - |
rgc:template:create | 授予创建模板的权限。 | Write | - | - | - |
rgc:template:delete | 授予删除模板的权限。 | Write | - | - | - |
rgc:predefinedTemplate:list | 授予列出预置模板的权限。 | List | - | - | - |
rgc:managedAccountTemplate:get | 授予获取纳管账号模板详情的权限。 | Read | - | - | - |
rgc:bestPractice:createDetect | 授予创建治理成熟度检测的权限。 | Write | - | - | - |
rgc:bestPractice:getStatus | 授予获取治理成熟度检测状态的权限。 | Read | - | - | - |
rgc:bestPractice:getOverview | 授予获取治理成熟度检测结果总览的权限。 | Read | - | - | - |
rgc:bestPractice:getDetails | 授予获取治理成熟度检测结果详情的权限。 | Read | - | - | - |
rgc:bestPractice:getAccount | 授予获取治理成熟度账号详情的权限。 | Read | - | - | - |
RGC的API通常对应着一个或多个授权项。表2展示了API与授权项的关系,以及该API需要依赖的授权项。
API | 对应的授权项 | 依赖的授权项 |
|---|---|---|
rgc:control:list | - | |
rgc:controlViolation:list | - | |
rgc:control:get | - | |
rgc:control:enable | - | |
rgc:control:disable | - | |
GET /v1/governance/operation-control-status/{operation_control_status_id} | rgc:controlOperate:get | - |
rgc:enabledControl:list | - | |
GET /v1/governance/managed-organizational-units/{managed_organizational_unit_id}/controls | rgc:controlsForOrganizationalUnit:list | - |
GET /v1/governance/managed-accounts/{managed_account_id}/controls | rgc:controlsForAccount:list | - |
GET /v1/governance/managed-accounts/{managed_account_id}/compliance-status | rgc:complianceStatusForAccount:get | - |
GET /v1/governance/managed-organizational-units/{managed_organizational_unit_id}/compliance-status | rgc:complianceStatusForOrganizationalUnit:get | - |
rgc:controlsForOrganizationalUnit:get | - | |
GET /v1/governance/managed-accounts/{managed_account_id}/controls/{control_id} | rgc:controlsForAccount:get | - |
GET /v1/governance/managed-accounts/{managed_account_id}/config-rule-compliances | rgc:configRuleCompliance:list | - |
GET /v1/governance/managed-accounts/{managed_account_id}/external-config-rule-compliances | rgc:externalConfigRuleCompliance:list | - |
rgc:driftDetail:list | - | |
POST /v1/managed-organization/organizational-units/{organizational_unit_id}/register | rgc:managedOrganizationalUnit:register | - |
POST /v1/managed-organization/organizational-units/{organizational_unit_id}/re-register | rgc:managedOrganizationalUnit:reRegister | - |
rgc:managedOrganizationalUnit:deRegister | - | |
rgc:operation:get | - | |
DELETE /v1/managed-organization/managed-organizational-units/{managed_organizational_unit_id} | rgc:managedOrganizationalUnit:delete | - |
GET /v1/managed-organization/managed-organizational-units/{managed_organizational_unit_id} | rgc:managedOrganizationalUnit:get | - |
rgc:managedOrganizationalUnit:create | - | |
rgc:managedOrganizationalUnit:list | - | |
POST /v1/managed-organization/accounts/{managed_account_id}/enroll | rgc:managedAccount:enroll | - |
POST /v1/managed-organization/managed-accounts/{managed_account_id}/un-enroll | rgc:managedAccount:unEnroll | - |
POST /v1/managed-organization/managed-accounts/{managed_account_id}/update | rgc:managedAccount:update | - |
GET /v1/managed-organization/managed-accounts/{managed_account_id} | rgc:managedAccount:get | - |
rgc:managedAccountsForParent:list | - | |
rgc:managedAccount:create | - | |
rgc:managedAccount:list | - | |
rgc:managedCoreAccount:get | - | |
rgc:homeRegion:get | - | |
rgc:preLaunch:check | - | |
rgc:landingZone:setup | - | |
rgc:landingZone:delete | - | |
rgc:landingZoneStatus:get | - | |
rgc:availableUpdate:get | - | |
rgc:landingZoneConfiguration:get | - | |
rgc:landingZoneIdentityCenter:get | - | |
rgc:operation:list | - | |
rgc:templateDeployParam:get | - | |
rgc:template:create | - | |
rgc:template:delete | - | |
rgc:predefinedTemplate:list | - | |
GET /v1/managed-organization/managed-accounts/{managed_account_id}/blueprint | rgc:managedAccountTemplate:get | - |
rgc:bestPractice:createDetect | - | |
rgc:bestPractice:getStatus | - | |
rgc:bestPractice:getOverview | - | |
rgc:bestPractice:getDetails | - | |
rgc:bestPractice:getAccount | - |

