更新时间:2025-10-22 GMT+08:00
分享

身份策略授权参考

云服务在IAM预置了常用授权项,称为系统身份策略。如果IAM系统身份策略无法满足授权要求,管理员可以根据各服务支持的授权项,创建IAM自定义身份策略来进行精细的访问控制,IAM自定义身份策略是对系统身份策略的扩展和补充。

除IAM服务外,Organizations服务中的服务控制策略(Service Control Policies,以下简称SCP)也可以使用这些授权项元素设置访问控制策略。

SCP不直接进行授权,只划定权限边界。将SCP绑定到组织单元或者成员账号时,并没有直接对组织单元或成员账号授予操作权限,而是规定了成员账号或组织单元包含的成员账号的授权范围。IAM身份策略授予权限的有效性受SCP限制,只有在SCP允许范围内的权限才能生效。

IAM服务与Organizations服务在使用这些元素进行访问控制时,存在着一些区别,详情请参见:IAM服务与Organizations服务权限访问控制的区别

本章节介绍IAM服务身份策略授权场景中自定义身份策略和组织服务中SCP使用的元素,这些元素包含了操作(Action)、资源(Resource)和条件(Condition)。

操作(Action)

操作(Action)即为身份策略中支持的操作项。

  • “访问级别”列描述如何对操作进行分类(list、read和write等)。此分类可帮助您了解在身份策略中相应操作对应的访问级别。
  • “资源类型”列指每个操作是否支持资源级权限。
    • 资源类型支持通配符号*表示所有。如果此列没有值(-),则必须在身份策略语句的Resource元素中指定所有资源类型(“*”)。
    • 如果该列包含资源类型,则必须在具有该操作的语句中指定该资源的URN。
    • 资源类型列中必需资源在表中用星号(*)标识,表示使用此操作必须指定该资源类型。

    关于费用中心定义的资源类型的详细信息请参见资源类型(Resource)

  • “条件键”列包括了可以在身份策略语句的Condition元素中支持指定的键值。
    • 如果该授权项资源类型列存在值,则表示条件键仅对列举的资源类型生效。
    • 如果该授权项资源类型列没有值(-),则表示条件键对整个授权项生效。
    • 如果此列条件键没有值(-),表示此操作不支持指定条件键。

    关于费用中心定义的条件键的详细信息请参见条件(Condition)

  • 别名”列包括了可以在身份策略中配置的策略授权项。通过这些授权项,可以控制支持策略授权的API访问。详细信息请参见身份策略兼容性说明

您可以在身份策略语句的Action元素中指定以下费用中心的相关操作。

表1 费用中心支持的授权项

授权项

描述

访问级别

资源类型(*为必须)

条件键

别名

billing:balance:update

提现,充值/还款,汇款认领,余额预警

write

-

-

-

billing:balance:view

查看收支明细,付款历史记录,消费配额,调账记录,欠费查询

list

-

g:EnterpriseProjectId

-

billing:balance:export

导出收支明细、付款记录

read

-

-

-

billing:bill:update

账单设置

write

-

-

-

billing:bill:view

查看账单、本月消费、近7天扣费资源,消费走势

list

-

g:EnterpriseProjectId

-

billing:bill:export

导出账单概览

read

-

g:EnterpriseProjectId

-

billing:billDetail:update

账单明细设置

write

-

g:EnterpriseProjectId

-

billing:billDetail:view

查看账单明细

read

-

g:EnterpriseProjectId

-

billing:billDetail:export

导出账单明细

read

-

g:EnterpriseProjectId

-

billing:resourcePackages:view

查看资源包,剩余量汇总,使用明细查询/导出

list

-

-

-

billing:resourcePackages:update

资源包剩余量预警设置

write

-

-

-

billing:contract:update

申请、修改、作废、查看线上合同,查看线下合同

write

-

-

-

billing:coupon:view

查看优惠券、储值卡,激活代金券

read

-

-

-

billing:coupon:update

购买储值卡

write

-

-

-

billing:contract:viewDiscount

查看商务折扣

read

-

-

-

billing:invoice:manage

发票管理:索取发票、管理发票抬头和管理收件地址

write

-

-

-

billing:invoice:view

查看开票记录,发票详情

read

-

-

-

billing:invoice:export

导出发票信息,下载发票

read

-

-

-

billing:order:pay

支付订单

write

-

g:EnterpriseProjectId

-

billing:order:view

查看订单信息、查看按需套餐包

list

-

g:EnterpriseProjectId

-

billing:subscription:renew

续费、设置自动续费、设置到期策略、按需转包年/包月

write

-

g:EnterpriseProjectId

-

billing:subscription:view

查看续费管理信息,查询可按需转包年/包月资源列表

list

-

g:EnterpriseProjectId

-

billing:subscription:unsubscribe

查看可退订资源,退订资源,取消发货,硬件退换货

write

-

g:EnterpriseProjectId

-

billing:consumption:view

查看企业项目消耗分析

read

-

-

-

billing::activeEPFinance

开通/关闭企业项目功能

write

-

-

-

billing::activeEPFundQuota

开通/关闭企业项目资金配额功能

write

-

-

-

billing::viewEPFundQuota

查询企业项目资金配额

read

-

-

-

billing::updateEPFundQuota

修改企业项目资金配额

write

-

-

-

billing::listEPFundQuotaHistory

查询企业项目资金配额调整记录

read

-

-

-

billing::updateEPGroup

修改企业项目群

write

-

-

-

billing::viewEPGroup

查看企业项目群

read

-

-

-

费用中心相关API与授权项关系,请参考客户运营能力

资源类型(Resource)

费用中心不支持在身份策略中的资源中指定资源进行权限控制。如需允许访问费用中心,请在身份策略的Resource元素中使用通配符号*,表示身份策略将应用到所有资源。

条件(Condition)

条件键概述

条件(Condition)是身份策略生效的特定条件,包括条件键运算符

  • 条件键表示身份策略语句的Condition元素中的键值。根据适用范围,分为全局级条件键和服务级条件键。
    • 全局级条件键(前缀为g:)适用于所有操作,在鉴权过程中,云服务不需要提供用户身份信息,系统将自动获取并鉴权。详情请参见:全局条件键
    • 服务级条件键(前缀通常为服务缩写,如BILLING:)仅适用于对应服务的操作,详情请参见表2
    • 单值/多值表示API调用时请求中与条件关联的值数。单值条件键在API调用时的请求中最多包含一个值,多值条件键在API调用时请求可以包含多个值。例如:g:SourceVpce是单值条件键,表示仅允许通过某个VPC终端节点发起请求访问某资源,一个请求最多包含一个VPC终端节点ID值。g:TagKeys是多值条件键,表示请求中携带的所有标签的key组成的列表,当用户在调用API请求时传入标签可以传入多个值。
  • 运算符与条件键、条件值一起构成完整的条件判断语句,当请求信息满足该条件时,身份策略才能生效。支持的运算符请参见:运算符

费用中心支持的服务级条件键

费用中心定义了以下可以在身份策略的Condition元素中使用的条件键,您可以使用这些条件键进一步细化身份策略语句应用的条件。

表2 费用中心支持的服务级条件键

服务级条件键

类型

单值/多值

说明

billing:cloudServiceType

string

多值

根据请求参数中云服务的类型,过滤访问。

条件键示例

billing:cloudServiceType

示例:表示仅允许退订hws.service.type.ebs类型的云服务资源。

{
	"Version": "5.0",
	"Statement": [{
		"Effect": "Allow",
		"Action": [
			"billing:subscription:unsubscribe"
		],
		"Condition": {
			"ForAnyValue:StringEquals": {
				"billing:cloudServiceType": [
                                 "hws.service.type.ebs"
                             ]
			}
		}
	}]
}

相关文档