All Products
Search
Document Center

Expenses and Costs:RAM authorization

Last Updated:Nov 01, 2025

Resource Access Management (RAM) is a service provided by Alibaba Cloud to manage user identities and resource access permissions. Using RAM helps you avoid sharing your Alibaba Cloud account keys with other users and allows you to grant users the least privilege access. RAM uses permission policies to define authorizations. This topic describes the general structure of a RAM policy, and the policy statement elements (Action, Resource, and Condition) defined by Alibaba Cloud Billing API for RAM permission policies. The RAM code (RamCode) for Alibaba Cloud Billing API is bss,bssapi,efc , and the supported authorization granularity is OPERATION .

General structure of a policy

Permission policies support JSON format with the following general structure:

{
  "Version": "1",
  "Statement": [
    {
      "Effect": "<Effect>",
      "Action": "<Action>",
      "Resource": "<Resource>",
      "Condition": {
        "<Condition_operator>": {
          "<Condition_key>": [
            "<Condition_value>"
          ]
        }
      }
    }
  ]
}        

The following list describes the fields in the policy:

  • Version: Specifies the policy version number. It is fixed at 1.

  • Statement:

    • Effect: Specifies the authorization result. Valid values: Allow and Deny.

    • Action: Specifies one or more operations that are allowed or denied.

    • Resource: Specifies the specific objects affected by the operations. You can use Alibaba Cloud Resource Names (ARNs) to describe specific resources.

    • Condition: Specifies the conditions for the authorization to take effect. This field is optional.

      • Condition operator: Specifies the conditional operators. Different types of conditions support different conditional operators.

      • Condition_key: Specifies the condition keys.

      • Condition_value: Specifies the condition values.

Action

The following table lists the actions defined by Alibaba Cloud Billing API. The table's columns are detailed below:

  • Action: The actions can be used in the Action element of RAM permission policy statements to grant permissions to perform the operation.

  • API: The API that you can call to perform the action.

  • Access level: The predefined level of access granted for each API. Valid values: create, list, get, update, and delete.

  • Resource type: The type of the resource that support authorization to perform the action. It indicates if the action supports resource-level permission. The specified resource must be compatible with the action. Otherwise, the policy will be ineffective.

    • For APIs with resource-level permissions, required resource types are marked with an asterisk (*). Specify the corresponding ARN in the Resource element of the policy.

    • For APIs without resource-level permissions, it is shown as All Resources. Use an asterisk (*) in the Resource element of the policy.

  • Condition key: The condition keys defined by the service. The key allows for granular control, applying to either actions alone or actions associated with specific resources. In addition to service-specific condition keys, Alibaba Cloud provides a set of common condition keys that are applicable across all RAM-integrated services. For more information, see Common condition keys.

  • Dependent action: The dependent actions required to run the action. To complete the action, the RAM user or the RAM role must have the permissions to perform all dependent actions.

Action

API

Access level

Resource type

Condition key

Dependent action

bss:ReleaseInstance ReleaseInstance

*All Resource

*

None None
bss:DescribeUserOmsData QueryUserOmsData get

*All Resource

*

None None
bss:QueryRiUtilizationDetail QueryRIUtilizationDetail get

*All Resource

*

None None
bss:DescribeProduct QuerySkuPriceList get

*All Resource

*

None None
bss:ModifySubscribeToOSS SubscribeBillToOSS create

*All Resource

*

None None
bss:CreateResellerUserQuota CreateResellerUserQuota create

*All Resource

*

None None
bss:RefundBatchRemainRefund RefundInstance update

*All Resource

*

None None
bss:QueryCustomerInvoiceInfo QueryInvoicingCustomerList get

*All Resource

*

None None
bss:CancelOrder CancelOrder

*All Resource

*

None None
bss:ApplyInvoice ApplyInvoice create

*All Resource

*

None None
bss:DescribeAcccount QueryAccountBalance get

*All Resource

*

None None
bss:DescribePrice GetPayAsYouGoPrice get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bss:CreateCostUnit CreateCostUnit create

*All Resource

*

None None
bss:GetCustomerAccountInfo GetCustomerAccountInfo get

*All Resource

*

None None
bss:DescribeProduct QueryCommodityList get

*All Resource

*

None None
bss:DeleteCostUnit DeleteCostUnit delete

*All Resource

*

None None
bss:ModifyInstance ModifyInstance update

*All Resource

*

None None
bss:DescrbePrepaidCards QueryPrepaidCards get

*All Resource

*

None None
bss:DescribeSubscribeToOSS QueryBillToOSSSubscription get

*All Resource

*

None None
bss:DescribePrice GetSubscriptionPrice get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bss:ModifyPrepaidInstanceAutoRenew SetRenewal update

*All Resource

*

None None
bss:QueryCustomerAddress QueryCustomerAddressList get

*All Resource

*

None None
bss:DescribeOrderDetail GetOrderDetail get

*All Resource

*

None None
bss:QueryProductList QueryProductList get

*All Resource

*

None None
bss:ChangeResellerConsumeAmount ChangeResellerConsumeAmount update

*All Resource

*

None None
bss:FrDeductLogQueryRequest QueryDPUtilizationDetail get

*All Resource

*

None None
bss:SetResellerUserQuota SetResellerUserQuota update

*All Resource

*

None None
bss:ModifyInstance CreateResourcePackage create

*All Resource

*

None None
bss:DescribeProduct QueryPriceEntityList get

*All Resource

*

None None
bss:SavingsPlansAnalysis DescribeSavingsPlansCoverageDetail get

*All Resource

*

None None
bss:DescribeInstances QueryAvailableInstances get

*All Resource

*

None None
bss:DescribeGaapBill QueryInstanceGaapCost get

*All Resource

*

None None
bss:SavingsPlansAnalysis DescribeSavingsPlansCoverageTotal get

*All Resource

*

None None
bss:QueryResellerUserAlarmThreshold QueryResellerUserAlarmThreshold get

*All Resource

*

None None
bss:DescribeProduct DescribeResourcePackageProduct get

*All Resource

*

None None
bss:ConvertChargeType ConvertChargeType create

*All Resource

*

None None
bss:DescribeOrderList QueryOrders get

*All Resource

*

None None
bss:ModifySubscribeToOSS UnsubscribeBillToOSS

*All Resource

*

None None
bss:DescribePrice GetResourcePackagePrice get

*All Resource

*

None None
bss:DescribeInstances QueryResourcePackageInstances get

*All Resource

*

None None
bss:QueryCostUnit QueryCostUnit get

*All Resource

*

None None
bss:ModifyInstance CreateInstance create

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bss:DescribeBillList QueryBill get

*All Resource

*

None None
bss:SetResellerUserStatus SetResellerUserStatus update

*All Resource

*

None None
bss:RefundQueryRemainAmount InquiryPriceRefundInstance get

*All Resource

*

None None
bss:RenewChangeInstance RenewChangeInstance none

*All Resource

*

None None
bss:ModifyCostUnit ModifyCostUnit update

*All Resource

*

None None
bss:AllocateCostUnitResource AllocateCostUnitResource

*All Resource

*

None None
bss:ModifyInstance RenewInstance create

*All Resource

*

None None
bss:GetCustomerList GetCustomerList get

*All Resource

*

None None
bss:QueryCostUnitResource QueryCostUnitResource get

*All Resource

*

None None
bss:QueryAccountBill QueryAccountBill get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bss:CreateResourcePackage UpgradeResourcePackage update

*All Resource

*

None None
bss:DescribeBillList QueryInstanceBill get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bss:QueryResellerAvailableQuota QueryResellerAvailableQuota get

*All Resource

*

None None
bss:ModifyPrepaidInstanceAutoRenew SetAllExpirationDay update

*All Resource

*

None None
bss:DescribeAcccountTran QueryAccountTransactions get

*All Resource

*

None None
bss:DescribeCostBudgetsSummary DescribeCostBudgetsSummary get

*All Resource

*

None None
bss:CreateResourcePackage RenewResourcePackage update

*All Resource

*

None None
bss:DescribePricingModule DescribePricingModule get

*All Resource

*

None None
bss:SetResellerUserAlarmThreshold SetResellerUserAlarmThreshold update

*All Resource

*

None None
bss:SavingsPlansAnalysis DescribeSavingsPlansUsageDetail get

*All Resource

*

None None
bss:DescribeBillList QueryBillOverview get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bss:DescribeCoupons QueryCashCoupons get

*All Resource

*

None None
bss:QueryEvaluate QueryEvaluateList get

*All Resource

*

None None
bss:SavingsPlansAnalysis DescribeSavingsPlansUsageTotal get

*All Resource

*

None None
bssapi:DescribeResourceCoverageTotal DescribeResourceCoverageTotal get

*All Resource

*

None None
bssapi:QueryRedeem QueryRedeem get

*All Resource

*

None None
bssapi:CreateSavingsPlansInstance CreateSavingsPlansInstance create

*All Resource

*

None None
bssapi:QueryInstanceByTag QueryInstanceByTag get

*All Resource

*

None None
bssapi:QueryRelationList QueryRelationList get

*All Resource

*

None None
bssapi:QuerySavingsPlansDeductLog QuerySavingsPlansDeductLog get

*All Resource

*

None None
bssapi:DescribeResourceUsageTotal DescribeResourceUsageTotal get

*All Resource

*

None None
bssapi:QueryPermissionList QueryPermissionList get

*All Resource

*

None None
bssapi:QuerySavingsPlansInstance QuerySavingsPlansInstance get

*All Resource

*

None None
bssapi:TagResources TagResources

*All Resource

*

None None
bssapi:UntagResources UntagResources

*All Resource

*

None None
bssapi:DescribeCostBill DescribeInstanceAmortizedCostByAmortizationPeriod get

*All Resource

*

None None
bssapi:DescribeCostBill DescribeProductAmortizedCostByConsumePeriod get

*All Resource

*

None None
bssapi:QuerySplitItemBill QuerySplitItemBill get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bssapi:DescribeInstanceBill DescribeInstanceBill get

*All Resource

*

bssapi:ProductCode

bssapi:ProductCode

bssapi:ProductType

bssapi:ProductType

None
bssapi:DescribeResourceUsageDetail DescribeResourceUsageDetail get

*All Resource

*

None None
bssapi:QuerySavingsPlansDiscount QuerySavingsPlansDiscount get

*All Resource

*

None None
bssapi:QueryAccountTransactionDetails QueryAccountTransactionDetails get

*All Resource

*

None None
bssapi:DescribeCostBill DescribeProductAmortizedCostByAmortizationPeriod get

*All Resource

*

None None
bssapi:DescribeSplitItemBill DescribeSplitItemBill get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bssapi:QuerySettleBill QuerySettleBill get

*All Resource

*

bssapi:ProductCode

bssapi:ProductType

None
bssapi:QueryFinancialAccountInfo QueryFinancialAccountInfo get

*All Resource

*

None None
bssapi:DescribeCostBill DescribeInstanceAmortizedCostByConsumePeriod get

*All Resource

*

None None
bssapi:DescribeResourceCoverageDetail DescribeResourceCoverageDetail get

*All Resource

*

None None

Resource

The following table lists the resources defined by Alibaba Cloud Billing API. Specify them in the Resource element of RAM policy statements to grant permissions for specific operations. They are uniquely identified by ARNs. Format: acs:{#ramcode}:{#regionId}:{#accountId}:{#resourceType}:

  • acs: The initialism of Alibaba Cloud service, which indicates the public cloud of Alibaba Cloud.

  • {#ramcode}: The code used in RAM to indicate an Alibaba Cloud service.

  • {#regionId}: The region ID. If the resource covers all regions, set it to an asterisk (*).

  • {#accountId}: The ID of the Alibaba Cloud account. If the resource covers all Alibaba Cloud accounts, set it to an asterisk (*).

  • {#resourceType}: The service-defined resource identifier. It supports a hierarchical structure, which is similar to a file path. If the statement covers global resources, set it to an asterisk (*).

Resource type

ARN

Condition

The following table lists the product-level condition keys defined by Alibaba Cloud Billing API. You can also use Alibaba Cloud's Common condition keys. Specify these keys in the Condition element of RAM policy statements to define granular authorization rules. In the condition key, specify the condition values in the Condition_value element of the policy.

Each condition key has a specific data type, such as string, number, Boolean, or IP address. The data type determines which conditional operators can be used to compare the request values against policy values. You must specify the conditional operators compatible with the data type of the condition key. Mismatched operators will invalidate the policy. See Condition operator for valid combinations.

Condition key

Description

Data type

bssapi:ProductCode Product code for operating resources. Example: ecs STRING
bssapi:ProductType Product type for operating resources. Example: ecs STRING

How to create custom RAM policies?

You can create custom policies and grant them to RAM users, RAM user groups, or RAM roles. For instructions, see: