更新时间:2024-07-24 GMT+08:00

云数据库 GaussDB

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

SCP不直接进行授权,只划定权限边界。将SCP绑定到组织单元或者成员账号时,并没有直接对组织单元或成员账号授予操作权限,而是规定了成员账号或组织单元包含的成员账号的授权范围。

本章节介绍组织服务中SCP使用的元素,这些元素包含了操作(Action)、资源(Resource)和条件(Condition)。

如何使用这些元素编辑SCP自定义策略,请参考创建SCP

操作(Action)

操作(Action)即为SCP中支持的授权项。

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

    关于GaussDB定义的资源类型的详细信息请参见资源类型(Resource)

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

    关于GaussDB定义的条件键的详细信息请参见条件(Condition)

您可以在SCP语句的Action元素中指定以下GaussDB的相关操作。

表1 GaussDB支持的授权项

授权项

描述

访问级别

资源类型(*为必须)

条件键

gaussdb:backup:createBackup

授予创建数据库实例手动备份的权限。

write

instance

-

gaussdb:backup:deleteBackup

授予删除备份的权限。

write

instance

-

gaussdb:backup:listAll

授予查询备份列表的权限。

list

instance

-

gaussdb:instance:updateBackupPolicy

授予设置备份策略的权限。

write

instance

gaussdb:BackupEnabled

gaussdb:param:applyParam

授予应用参数模板的权限。

write

instance

-

gaussdb:tag:create

授予添加资源标签的权限。

tagging

instance

-

gaussdb:instance:bindEIP

授予绑定弹性公网IP的权限。

write

instance

-

gaussdb:instance:check

授予校验实例相关信息的权限。

read

instance

-

gaussdb:instance:createInstance

授予创建数据库实例的权限。

write

instance

  • gaussdb:BackupEnabled
  • gaussdb:Encrypted

gaussdb:instance:createDatabase

授予创建数据库的权限。

write

instance

-

gaussdb:instance:createDatabaseSchema

授予创建数据库Schema的权限。

write

instance

-

gaussdb:instance:createDatabaseUser

授予创建数据库用户的权限。

write

instance

-

gaussdb:instance:deleteInstance

授予删除数据库实例的权限。

write

instance

-

gaussdb:instance:get

授予查询实例详情的权限。

read

instance

-

gaussdb:instance:getBackupPolicy

授予查询自动备份策略的权限。

read

instance

-

gaussdb:instance:getBalanceStatus

授予查询实例主备平衡状态的权限。

read

instance

-

gaussdb:instance:getDiskUsage

授予查询磁盘使用率的权限。

read

instance

-

gaussdb:instance:getRecyclePolicy

授予查看实例回收备份策略的权限。

read

instance

-

gaussdb:instance:downloadSslCert

授予下载实例SSL证书的权限。

read

instance

-

gaussdb:instance:grantDatabasePrivilege

授予授权数据库账号的权限。

write

instance

-

gaussdb:instance:listAll

授予查询数据库实例列表的权限。

list

instance

-

gaussdb:instance:listPublicIps

授予查询实例已绑定EIP列表的权限。

list

instance

-

gaussdb:instance:listComponents

授予查询实例组件列表的权限。

list

instance

-

gaussdb:instance:listDatabases

授予查询数据库列表的权限。

list

instance

-

gaussdb:instance:listDatabaseUsers

授予查询数据库用户列表的权限。

list

instance

-

gaussdb:tag:listAll

授予查询资源标签列表的权限。

list

instance

-

gaussdb:quota:listAll

授予查询配额列表的权限。

list

instance

-

gaussdb:instance:listRecoverableTimes

授予查询备份可恢复时间段的权限。

list

instance

-

gaussdb:instance:listSchemas

授予查询数据库Schema列表的权限。

list

instance

-

gaussdb:instance:renameInstance

授予重置实例名称的权限。

write

instance

-

gaussdb:instance:resetPassword

授予重置数据库密码的权限。

write

instance

-

gaussdb:instance:resizeFlavor

授予变更实例规格的权限。

write

instance

-

gaussdb:instance:restartInstance

授予重启数据库实例的权限。

write

instance

-

gaussdb:instance:setRecyclePolicy

授予设置实例回收备份策略的权限。

write

instance

-

gaussdb:instance:switchShard

授予分片节点主备切换的权限。

write

instance

-

gaussdb:instance:extend

授予扩容相关操作的权限。

write

instance

-

gaussdb:param:update

授予修改参数组的权限。

write

instance

-

gaussdb:param:check

授予校验参数组的权限。

read

instance

-

gaussdb:param:copy

授予复制参数模板的权限。

write

instance

-

gaussdb:param:createParam

授予创建参数组的权限。

write

instance

-

gaussdb:param:deleteParam

授予删除参数组的权限。

write

instance

-

gaussdb:param:get

授予查询参数配置详情的权限。

read

instance

-

gaussdb:param:compare

授予比较两个参数模板之间差异的权限。

read

instance

-

gaussdb:param:listAll

授予查询参数组列表的权限。

list

instance

-

gaussdb:param:reset

授予重置参数模板的权限。

write

instance

-

gaussdb:quota:update

授予修改配额的权限。

write

instance

-

gaussdb:task:listAll

授予查询任务列表的权限。

list

instance

-

gaussdb:task:delete

授予删除任务记录的权限。

write

instance

-

gaussdb:task:get

授予查询任务详情的权限。

read

instance

-

GaussDB的API通常对应着一个或多个授权项。如下表展示了API与授权项的关系,以及该API需要依赖的授权项。

表2 实例管理

权限

API

对应的授权项

依赖的授权项

创建数据库实例

POST /v3/{project_id}/instances

gaussdb:instance:createInstance

-

删除数据库实例

DELETE /v3/{project_id}/instances/{instance_id}

gaussdb:instance:delete

-

查询数据库实例列表

GET /v3/{project_id}/instances

gaussdb:instance:listAll

-

重置数据库密码

POST /v3/{project_id}/instances/{instance_id}/password

gaussdb:instance:resetPassword

-

修改实例名称

PUT /v3/{project_id}/instances/{instance_id}/name

gaussdb:instance:rename

-

重启数据库实例

POST /v3/{project_id}/instances/{instance_id}/restart

gaussdb:instance:restart

-

分片节点主备切换

POST /v3/{project_id}/instances/{instance_id}/switch-shard

gaussdb:instance:switchShard

-

查询实例的组件列表

GET /v3/{project_id}/instances/{instance_id}/components

gaussdb:instance:listComponents

-

规格变更

PUT /v3/{project_id}/instance/{instance_id}/flavor

gaussdb:instance:resizeFlavor

-

查询实例主备平衡状态

GET /v3/{project_id}/instances/{instance_id}/balance

gaussdb:instance:getBalanceStatus

-

查询解决方案模板配置

GET /v3/{project_id}/deployment-form

gaussdb:instance:listAll

-

查询已绑定的EIP列表

GET /v3/{project_id}/instances/{instance_id}/public-ips?offset={offset}&limit={limit}

gaussdb:instance:listPublicIps

-

弱密码校验

POST /v3/{project_id}/weak-password-verification

gaussdb:instance:check

-

绑定/解绑弹性公网IP

POST /v3/{project_id}/instances/{instance_id}/nodes/{node_id}/public-ip

gaussdb:instance:bindPublicIp

-

查询实例SSL证书下载地址

GET /v3/{project_id}/instances/{instance_id}/ssl-cert/download-link

gaussdb:instance:downloadSslCert

-

查询租户的实例配额

GET /v3/{project_id}/project-quotas?type={type}

gaussdb:quota:listAll

-

表3 参数配置

权限

API

对应的授权项

依赖的授权项

获取参数模板列表

GET /v3/{project_id}/configurations?offset={offset}&limit={limit}

gaussdb:param:listAll

-

获取指定实例的参数

GET /v3/{project_id}/instances/{instance_id}/configurations

gaussdb:instance:get

-

修改指定实例的参数

PUT /v3/{project_id}/instances/{instance_id}/configurations

gaussdb:param:update

-

创建参数模板

POST /v3/{project_id}/configurations

gaussdb:param:createParam

-

删除参数模板

DELETE /v3/{project_id}/configurations/{config_id}

gaussdb:param:delete

-

查询参数模板详情

GET /v3/{project_id}/configurations/{config_id}

gaussdb:param:get

-

复制参数模板

POST /v3/{project_id}/configurations/{config_id}/copy

gaussdb:param:copy

-

重置参数组

POST /v3/{project_id}/configurations/{config_id}/reset

gaussdb:param:reset

-

比较两个参数组模板之间的差异

POST /v3/{project_id}/configurations/comparison

gaussdb:param:compare

-

查询可应用实例列表

GET /v3/{project_id}/configurations/{config_id}/applicable-instances

gaussdb:instance:listAll

-

校验参数组名称是否存在

GET /v3/{project_id}/configurations/name-validation?name={name}

gaussdb:param:check

-

应用参数模板

PUT /v3/{project_id}/configurations/{config_id}/apply

gaussdb:param:apply

-

查询参数模板的应用记录

GET /v3/{project_id}/configurations/{config_id}/applied-histories

gaussdb:param:listAll

-

查询参数模板的修改历史

GET /v3/{project_id}/configurations/{config_id}/histories

gaussdb:param:listAll

-

表4 备份管理

权限

API

对应的授权项

依赖的授权项

设置自动备份策略

PUT /v3/{project_id}/instances/{instance_id}/backups/policy

gaussdb:instance:updateBackupPolicy

-

查询自动备份策略

GET /v3/{project_id}/instances/{instance_id}/backups/policy

gaussdb:instance:getBackupPolicy

-

查询备份列表

GET /v3/{project_id}/backups?instance_id={instance_id}&backup_id={backup_id}&backup_type={backup_type}&offset={offset}&limit={limit}&begin_time={begin_time}&end_time={end_time}

gaussdb:backup:listAll

-

创建手动备份

POST /v3/{project_id}/backups

gaussdb:backup:create

-

删除手动备份

DELETE /v3/{project_id}/backups/{backup_id}

gaussdb:backup:delete

-

查询可恢复时间段

GET /v3/{project_id}/instances/{instance_id}/restore-time?date={date}

gaussdb:instance:listRecoverableTimes

-

恢复到新实例

POST /v3/{project_id}/instances

gaussdb:instance:createInstance

-

查询可用于备份恢复的实例列表

GET /v3/{project_id}/restorable-instances

gaussdb:instance:listAll

-

根据时间点或者备份文件查询原实例信息

GET /v3/{project_id}/instance-snapshot?instance_id={instance_id}&backup_id={backup_id}&restore_time={restore_time}

gaussdb:instance:get

-

表5 引擎版本和规格

权限

API

对应的授权项

依赖的授权项

查询数据库引擎的版本

GET /v3/{project_id}/datastore/versions

gaussdb:instance:listAll

-

查询数据库规格

GET /v3/{project_id}/flavors?limit={limit}&offset={offset}&ha_mode={ha_mode}&version={version}&spec_code={spec_code}

gaussdb:instance:listAll

-

查询引擎列表

GET /v3/{project_id}/datastores

gaussdb:instance:listAll

-

查询实例可变更规格

GET /v3/{project_id}/instances/{instance_id}/available-flavors

gaussdb:instance:listAll

-

表6 管理数据库和用户

权限

API

对应的授权项

依赖的授权项

创建数据库

POST /v3/{project_id}/instances/{instance_id}/database

gaussdb:instance:createDatabase

-

创建数据库用户

POST /v3/{project_id}/instances/{instance_id}/db-user

gaussdb:instance:createDatabaseUser

-

创建数据库SCHEMA

POST /v3/{project_id}/instances/{instance_id}/schema

gaussdb:instance:createDatabaseSchema

-

授权数据库账号

POST /v3/{project_id}/instances/{instance_id}/db-privilege

gaussdb:instance:grantDatabasePrivilege

-

重置数据库账号密码

PUT /v3/{project_id}/instances/{instance_id}/db-user/password

gaussdb:instance:resetPassword

-

查询数据库列表

GET /v3/{project_id}/instances/{instance_id}/databases

gaussdb:instance:listDatabases

-

查询数据库用户列表

GET /v3/{project_id}/instances/{instance_id}/db-users

gaussdb:instance:listDatabaseUsers

-

查询数据库SCHEMA列表

GET /v3/{project_id}/instances/{instance_id}/schemas

gaussdb:instance:listSchemas

-

表7 标签管理

权限

API

对应的授权项

依赖的授权项

查询实例标签

GET /v3/{project_id}/instances/{instance_id}/tags

gaussdb:tag:listAll

-

查询项目标签

GET /v3/{project_id}/tags

gaussdb:tag:listAll

-

查询预定义标签

GET /v3/{project_id}/predefined-tags

gaussdb:tag:listAll

-

添加实例标签

POST /v3/{project_id}/instances/{instance_id}/tags

gaussdb:tag:create

-

表8 磁盘管理

权限

API

对应的授权项

依赖的授权项

查询实例存储空间使用信息

GET /v3/{project_id}/instances/{instance_id}/volume-usage

gaussdb:instance:getDiskUsage

-

查询数据库磁盘类型

GET /v3/{project_id}/storage-type?version={version}&ha_mode={ha_mode}

gaussdb:instance:listAll

-

表9 配额管理

权限

API

对应的授权项

依赖的授权项

修改企业项目配额

PUT /v3/{project_id}/enterprise-projects/quotas

gaussdb:quota:update

-

查询企业项目配额组

GET /v3/{project_id}/enterprise-projects/quotas

gaussdb:quota:listAll

-

表10 任务管理

权限

API

对应的授权项

依赖的授权项

获取任务信息

GET /v3/{project_id}/jobs?id={id}

gaussdb:task:get

-

查询任务列表

GET /v3/{project_id}/tasks

gaussdb:task:listAll

-

删除任务记录

DELETE /v3/{project_id}/jobs/{job_id}

gaussdb:task:delete

-

表11 回收站

权限

API

对应的授权项

依赖的授权项

设置回收站策略

PUT /v3/{project_id}/recycle-policy

gaussdb:instance:setRecyclePolicy

-

查看回收站策略

GET /v3/{project_id}/recycle-policy

gaussdb:instance:getRecyclePolicy

-

查询回收站所有引擎实例列表

GET /v3/{project_id}/recycle-instances

gaussdb:instance:listAll

-

资源类型(Resource)

资源类型(Resource)表示SCP所作用的资源。如表3中的某些操作指定了可以在该操作指定的资源类型,则必须在具有该操作的SCP语句中指定该资源的URN,SCP仅作用于此资源;如未指定,Resource默认为“*”,则SCP将应用到所有资源。您也可以在SCP中设置条件,从而指定资源类型。

GaussDB定义了以下可以在SCP的Resource元素中使用的资源类型。

表12 GaussDB支持的资源类型

资源类型

URN

instance

gaussdb:<region>:<account-id>:instance:<instance-id>

条件(Condition)

条件(Condition)是SCP生效的特定条件,包括条件键运算符

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

GaussDB定义了以下可以在SCP的Condition元素中使用的条件键,您可以使用这些条件键进一步细化SCP语句应用的条件。

表13 GaussDB支持的服务级条件键

服务级条件键

类型

单值/多值

说明

gaussdb:BackupEnabled

boolean

单值

按照请求参数中传递的是否开启备份策略标签键筛选访问权限。限定词选择“默认”。

gaussdb:Encrypted

boolean

单值

按照请求参数中传递的是否开启磁盘加密标签键筛选访问权限。限定词选择“默认”。