Custom Policy

Caution:
This document describes the Cloud Access Management (CAM) feature for IM. For more information about CAM for other Tencent Cloud services, see CAM-Enabled Products.
You can easily use preset policies in the CAM console for authorization. However, preset policies only provide coarse-grained permission control and cannot be refined to IM applications and Tencent Cloud APIs. If you need refined permission control, you must create custom policies.

Custom Policy Creation Methods

The table compares several custom policy creation methods with detailed instructions for using them.
Entry
Method
Effect
Resource
Action
Flexibility
Difficulty
Policy generator
Manual selection
Syntax description
Manual selection
Medium
Medium
Policy syntax
Syntax description
Syntax description
Syntax description
High
High
CAM server API
Syntax description
Syntax description
Syntax description
High
High

Note:
IM does not support custom policy creation by product feature or project.
Manual selection indicates that you must select an object from the option list in the console.
Syntax description indicates that the authorization policy syntax is used to describe objects.

Authorization Policy Syntax

Resource syntax description

As mentioned previously, the resource granularity for IM permission management is applications. Policy syntax description of applications comply with the Resource Description Method. In the following example, the developer’s root account ID is 12345678, and the developer creates three applications whose SDKAppIDs are 1400000000, 1400000001, and 1400000002 respectively.
Policy syntax description for all IM applications
"resource": [
"qcs::im::uin/12345678:sdkappid/*"
]
Policy syntax description for a single application
"resource": [
"qcs::im::uin/12345678:sdkappid/1400000001"
]
Policy syntax description for multiple applications
"resource": [
"qcs::im::uin/12345678:sdkappid/1400000000",
"qcs::im::uin/12345678:sdkappid/1400000001"
]

Action syntax description

As mentioned previously, the action granularity of TRTC permission management is Tencent Cloud APIs. In the following example, Tencent Cloud APIs such as DescribeAppStatList (for obtaining the application list) and DescribeSdkAppInfo (for obtaining application information) are used.
Policy syntax description for all Tencent Cloud APIs for IM
"action": [
"name/im:*"
]
Policy syntax description for a single Tencent Cloud API
"action": [
"name/im:DescribeAppStatList"
]
Policy syntax description for multiple Tencent Cloud APIs
"action": [
"name/im:DescribeAppStatList",
"name/im:DescribeTrtcAppAndAccountInfo"
]

Custom Policy Usage Example

Using the policy generator

In the following example, we will create a custom policy that allows all operations on the IM application whose SDKAppID is 1400000001.
1. Log in to the Policies page in the CAM console with the root account. Then, click Create Custom Policy.
2. Select Create by Policy Generator to go to the policy creation page.
3. In the Select Service and Action step:
Select Allow for Effect.
Select IM for Service.
Select all items for Action.
Enter qcs::im::uin/12345678:sdkappid/1400000001 for Resource based on the resource syntax description.
Condition is optional.
Click Add Statement. A statement that allows all operations for the IM application 1400000001 appears.
4. Continue to add another statement on the same page by configuring the following settings:
Select Deny for Effect.
Select IM for Service.
Select RemoveUser for Action. (You can quickly find RemoveUser with the search feature.)
Enter qcs::im::uin/12345678:sdkappid/1400000001 for Resource based on the resource syntax description.
Condition is optional.
Click Add Statement. A statement that rejects the RemoveUser operation for IM application 1400000001 appears.
5. Click Next and rename the policy as needed (You can also retain the current policy name).
6. Click Done.
The method for granting the policy to other sub-accounts is the same as Granting IM Permissions to an Existing Sub-account.

Using the policy syntax

In the following example, we will create a custom policy that allows all operations for the IM applications whose SDKAppIDs are 1400000001 and 1400000002.
1. Log in to the Policies page in the CAM console with the root account. Then, click Create Custom Policy.
2. Select Create by Policy Syntax to go to the creation page.
3. In the Select a template type area, select Blank Template.
Note:
A policy template is used to create a policy by copying an existing policy (a preset or custom policy) and then modifying the policy. You can select an appropriate policy template to reduce the difficulty and workload of policy definition.
4. Click Next and rename the policy as needed (You can also retain the current policy name).
5. Copy and paste the following content in the Policy Content box:
{
"version": "2.0",
"statement": [
{
"effect": "allow",
"action": [
"name/im:*"
],
"resource": [
"qcs::im::uin/12345678:sdkappid/1400000001",
"qcs::im::uin/12345678:sdkappid/1400000002"
]
},
{
"effect": "deny",
"action": [
"name/im:RemoveUser"
],
"resource": [
"qcs::im::uin/12345678:sdkappid/1400000001"
]
}
]
}
Note:
The policy content must comply with the CAM policy syntax logic described in Element Reference. For more information on the syntax for resource and action elements, see Resource syntax description and Action syntax description.
6. Click Done. The method for granting the policy to other sub-accounts is the same as Granting IM Permissions to an Existing Sub-account.

Using server APIs provided by CAM

For most developers, performing permission management operations in the console can meet their business needs. However, if you need to automate and systematize your permission management capabilities, you can use server APIs. Policy-related server APIs are included in CAM. For more information, see CAM documentation. Among these APIs, the major ones include: