Updated on 2022-08-17 GMT+08:00

Modifying a DDM Account

Function

This API is used to modify permissions or associated schemas of a DDM account.

Constraints

At least one of the following parameters must be configured: extend_authority, base_authority, description, and databases.

URI

PUT /v1/{project_id}/instances/{instance_id}/users/{username}

Table 1 Path parameters

Parameter

Mandatory

Type

Description

project_id

Yes

String

Project ID

instance_id

Yes

String

DDM instance ID

username

Yes

String

Name of the DDM account

Request Parameters

Table 2 Request header parameters

Parameter

Mandatory

Type

Description

X-Auth-Token

Yes

String

User token

It can be obtained by calling the IAM API (value of X-Subject-Token in the response header).

Table 3 Request body parameters

Parameter

Mandatory

Type

Description

user

Yes

UpdateDDMUserDetailReq object

DDM account information

Table 4 Parameters for modifying a DDM account

Parameter

Mandatory

Type

Description

base_authority

No

Array of strings

Basic permissions of the DDM account. The default value is basic permissions of the original DDM account.

The value can be CREATE, DROP, ALTER, INDEX, INSERT, DELETE, UPDATE, or SELECT.

Possible values are as follows:

  • CREATE
  • DROP
  • ALTER
  • INDEX
  • INSERT
  • DELETE
  • UPDATE
  • SELECT

extend_authority

No

Array of strings

Extended permissions of the DDM account. This parameter is left blank by default.

The value can be fulltableDelete, fulltableSelect, or fulltableUpdate.

When configuring permissions, select at least one basic permission. The mappings between basic permissions and extended permissions are as follows:

  • If base_authority is set to SELECT, set extend_authority to fulltableSelect.
  • If base_authority is set to DELETE, set extend_authority to fulltableDelete.
  • If base_authority is set to UPDATE, set extend_authority to fulltableUpdate.

Possible values are as follows:

  • fulltableSelect
  • fulltableDelete
  • fulltableUpdate

description

No

String

Description of the DDM account, which cannot exceed 256 characters.

It is left blank by default.

Maximum length: 256

databases

No

Array of UpdateDDMUsersDatabases objects

DDM account information

Table 5 Parameters for modifying a DDM account

Parameter

Mandatory

Type

Description

name

No

String

Schema name, which is case-insensitive. The databases and name fields must be both or not specified at the same time.

It is left blank by default.

Response Parameters

Status code: 200

Table 6 Response body parameters

Parameter

Type

Description

name

String

Name of the DDM account

Status code: 400

Table 7 Response body parameters

Parameter

Type

Description

errCode

String

Service error code

externalMessage

String

Error message

Status code: 500

Table 8 Response body parameters

Parameter

Type

Description

errCode

String

Service error code

externalMessage

String

Error message

Example Request

PUT https://{endpoint}/v1/{project_id}/instances/{instance_id}/users/{username}

{
  "user" : {
    "base_authority" : [ "SELECT" ],
    "extend_authority" : [ "fulltableSelect" ],
    "description" : "test11",
    "databases" : [ {
      "name" : "db_7350"
    } ]
  }
}

Example Response

Status code: 200

OK

{
  "name" : "ddmtest"
}

Status code: 400

bad request

{
  "externalMessage" : "Parameter error.",
  "errCode" : "DBS.280001"
}

Status code: 500

server error

{
  "externalMessage" : "Parameter error.",
  "errCode" : "DBS.280001"
}

Status Codes

For details, see Status Codes.

Error Codes

For details, see Error Codes.