Help Center/ Cloud Backup and Recovery/ API Reference/ CBR APIs/ Vaults/ Creating a Yearly/Monthly Vault
Updated on 2025-08-25 GMT+08:00

Creating a Yearly/Monthly Vault

Function

Creating a Yearly/Monthly Vault

Debugging

You can debug this API through automatic authentication in API Explorer or use the SDK sample code generated by API Explorer.

URI

POST /v3/{project_id}/vaults/order

Table 1 Path Parameters

Parameter

Mandatory

Type

Description

project_id

Yes

String

Project ID.

For details about how to obtain the project ID, see Obtaining a Project ID.

Request Parameters

Table 2 Request header parameters

Parameter

Mandatory

Type

Description

X-Auth-Token

Yes

String

User token

The token can be obtained by calling the IAM API used to obtain a user token. The value of X-Subject-Token in the response header is the user token.

Table 3 Request body parameters

Parameter

Mandatory

Type

Description

vault

Yes

VaultOrder object

Vaults

Table 4 VaultOrder

Parameter

Mandatory

Type

Description

name

No

String

Vault name. The value can contain a maximum of 64 characters, including letters, digits, underscores (_), and hyphens (-).

billing

Yes

BillingCreate object

Billing parameter for creating a vault.

resources

Yes

Array of ResourceCreate objects

Associated resources. Set this parameter to [] if no resources are associated when creating a vault.

description

No

String

Description

Minimum length: 0 characters

Maximum length: 255 characters

backup_policy_id

No

String

Backup policy ID. The default value is null, indicating that automatic backup is not supported.

For details about how to obtain the backup policy ID, see Obtaining a Backup Policy ID.

tags

No

Array of Tag objects

Tag list. This list cannot be an empty list.The list can contain up to 10 keys.Keys in this list must be unique.

enterprise_project_id

No

String

Enterprise project ID. Its default value is 0.

For details, see Obtaining an Enterprise Project ID.

auto_bind

No

Boolean

Whether automatic association is supported. Default value: false.

The options are as follows:

  • true: Automatic association is supported.

  • false: Automatic association is not supported.

bind_rules

No

VaultBindRules object

Rules for automatic association

threshold

No

Integer

Vault capacity threshold. If the vault usage exceeds this threshold and smn_notify is true, a notification will be sent.

Value range: 1 to 100. The default value is 80.

smn_notify

No

Boolean

Whether to send SMN notifications. The default value is true.

The options are as follows:

  • true: SMN notifications will be sent.

  • false: SMN notifications will not be sent.

parameters

No

VaultCreateParameters object

Vault order combined parameters

auto_expand

No

Boolean

Whether to enable automatic capacity expansion (supported for pay-per-use vaults only). The default value is false.

The options are as follows:

  • true: Automatic capacity expansion is supported.

  • false: Automatic capacity expansion is not supported.

locked

No

Boolean

Whether the vault is locked. A locked vault cannot be unlocked.

For details about backup locking, see Enabling Backup Locking.

The options are as follows:

  • true: The vault is locked.

  • false: The vault is not locked.

Table 5 BillingCreate

Parameter

Mandatory

Type

Description

cloud_type

No

String

Cloud type. The default value is public. The following types are supported:

public: public cloud; hybrid: hybrid cloud

consistent_level

Yes

String

Vault specifications. app_consistent: application consistency; crash_consistent: crash consistency

object_type

Yes

String

Object type. The value can be server, disk, turbo, workspace, vmware, rds, or file. server: cloud server; disk: EVS disk; turbo: file system; workspace: Workspace; vmware: VMware; rds: RDS; file: file

protect_type

Yes

String

Protection type. The value can be:

backup or replication

size

Yes

Integer

Resource capacity, in GB. The value ranges from 10 to 10485760.

charging_mode

No

String

description: |-

Billing mode. The default value is post_paid. post_paid: pay-per-use; pre_paid: yearly/monthly

period_type

No

String

The unit of the subscription term. This parameter is mandatory only when charging_mode is pre_paid.

The options are as follows:

  • month: monthly subscription

  • year: yearly subscription

period_num

No

Integer

Subscription term. This parameter is mandatory only when charging_mode is pre_paid.

Value range: [1-9]

is_auto_renew

No

Boolean

Specifies whether to automatically renew the subscription upon expiration. The default value is false.

The options are as follows:

  • true: The subscription is automatically renewed upon expiration.

  • false: The subscription is not automatically renewed upon expiration.

is_auto_pay

No

Boolean

Specifies whether to automatically pay for the order. The default value is false.

The options are as follows:

  • true: The payment is automatically made after the order is placed.

  • false: The payment is not automatically made after the order is placed.

console_url

No

String

Cloud service console URL. The URL used to switch to the cloud service console to view information after the subscription is complete. (This parameter is used only for manual payment.)

is_multi_az

No

Boolean

Specifies whether the vault has the multi-AZ attribute, that is, whether the underlying backup is a multi-AZ backup. The default value is false.

The options are as follows:

  • true: The vault has the multi-AZ attribute.

  • false: The vault does not have the multi-AZ attribute.

Table 6 ResourceCreate

Parameter

Mandatory

Type

Description

extra_info

No

ResourceExtraInfo object

Extra information of the resource

id

Yes

String

ID of the resource to be backed up. The resource must have been associated with the vault and can be backed up.

For details about how to obtain the ID, see Querying Information About the Resources Associated with a Vault and Querying Protectable Resources.

type

Yes

String

Type of the resource to be backed up: OS::Nova::Server: ECS; OS::Cinder::Volume: EVS disks; OS::Ironic::BareMetalServer: Bare Metal Servers; OS::Sfs::Turbo: SFS Turbo file systems; OS::Workspace::DesktopV2: Workspaces

name

No

String

Backup name

Table 7 ResourceExtraInfo

Parameter

Mandatory

Type

Description

exclude_volumes

No

Array of strings

IDs of the disks that will not be backed up. This parameter is used when servers are added to a vault, which include all server disks. But some disks do not need to be backed up. Or in case that a server was previously added and some disks on this server do not need to be backed up.

Table 8 Tag

Parameter

Mandatory

Type

Description

key

Yes

String

Key

It can contain a maximum of 36 characters.

It cannot be an empty string.

Spaces before and after a key will be discarded.

It cannot contain non-printable ASCII characters (0–31) and the following characters: =*<>,|/

It can contain only letters, digits, hyphens (-), and underscores (_).

value

Yes

String

Value

It is mandatory when a tag is added and optional when a tag is deleted.

It can contain a maximum of 43 characters.

It can be an empty string.

Spaces before and after a value will be discarded.

It cannot contain non-printable ASCII characters (0–31) and the following characters: =*<>,|/

It can contain only letters, digits, hyphens (-), underscores (_), and periods (.).

Table 9 VaultBindRules

Parameter

Mandatory

Type

Description

tags

No

Array of BindRulesTags objects

Filters automatically associated resources by tag.

Minimum length: 0 characters

Maximum length: 5 characters

Table 10 BindRulesTags

Parameter

Mandatory

Type

Description

key

Yes

String

The key cannot contain non-printable ASCII characters (0–31) and the following characters: =*<>,|/

The key can contain only letters, digits, hyphens (-), and underscores (_).

value

Yes

String

The value cannot contain non-printable ASCII characters (0–31) and the following characters: =*<>,|/

The value can contain only letters, digits, periods (.), hyphens (-), and underscores (_).

Table 11 VaultCreateParameters

Parameter

Mandatory

Type

Description

combined_order

No

CombinedOrder object

Combined order

Table 12 CombinedOrder

Parameter

Mandatory

Type

Description

combined_order_id

No

String

Combined order ID

combined_order_ecs_num

No

Integer

Number of ECSs in the combined order. Maximum ECSs allowed in the current batch: 500

Minimum value: 1

Maximum value: 1000

combined_order_num

No

Integer

Number of combined orders

Minimum value: 1

Maximum value: 1000

Response Parameters

Status code: 200

Table 13 Response body parameters

Parameter

Type

Description

orders

Array of CbcOrderResult objects

Order details

retCode

Integer

Result code

0: success

errText

String

Creation results

error_code

String

Error code

0: no error

Table 14 CbcOrderResult

Parameter

Type

Description

cloudServiceId

String

Cloud service ID

orderId

String

Order ID

subscribeResult

Integer

Subscription result. 1: succeeded; 0: Failed

resourceId

String

ID of a pre-generated yearly/monthly resource

Status code: 400

Table 15 Response body parameters

Parameter

Type

Description

error_code

String

For details, see Error Codes.

error_msg

String

Error message

Example Requests

  • Creating an 80-GB yearly/monthly server backup vault, setting the duration to 1 month, and associating a resource with the vault

    POST https://{endpoint}/v3/f841e01fd2b14e7fa41b6ae7aa6b0594/vaults/order
    
    {
      "vault" : {
        "name" : "vault_name",
        "billing" : {
          "consistent_level" : "app_consistent",
          "object_type" : "server",
          "protect_type" : "backup",
          "size" : 80,
          "charging_mode" : "pre_paid",
          "period_type" : "month",
          "period_num" : 1
        },
        "resources" : [ {
          "id" : "23a320a5-3efd-4568-b1aa-8dd9183cc64c",
          "type" : "OS::Nova::Server"
        } ]
      }
    }
  • Creating an 80-GB yearly/monthly server backup vault using the combined purchase (allowing up to 5 servers in an order), setting the duration to 1 month, associating a resource, and adding tags

    POST https://{endpoint}/v3/f841e01fd2b14e7fa41b6ae7aa6b0594/vaults/order
    
    {
      "vault" : {
        "name" : "123",
        "description" : "description",
        "backup_policy_id" : "70e9c916-7109-472d-94e7-120900e4ba61",
        "tags" : [ {
          "key" : "key",
          "value" : "value"
        } ],
        "auto_bind" : false,
        "threshold" : 80,
        "smn_notify" : true,
        "parameters" : {
          "combined_order" : {
            "combined_order_id" : "CS2303030959MR1IT",
            "combined_order_ecs_num" : 5,
            "combined_order_num" : 5
          }
        },
        "bind_rules" : {
          "tags" : [ {
            "key" : "bind_rules_key",
            "value" : "bind_rules_value"
          } ]
        },
        "billing" : {
          "cloud_type" : "public",
          "is_auto_renew" : false,
          "is_auto_pay" : false,
          "console_url" : "https://www.com",
          "consistent_level" : "app_consistent",
          "object_type" : "server",
          "protect_type" : "backup",
          "size" : 80,
          "charging_mode" : "pre_paid",
          "period_type" : "month",
          "period_num" : 1
        },
        "resources" : [ {
          "id" : "8ef08ba1-81f7-4e41-ae49-d3e2fb0ba388",
          "type" : "OS::Nova::Server",
          "name" : "server_name",
          "extra_info" : {
            "exclude_volumes" : [ "1855eb9a-2b5e-4938-a9f0-aea08b6f9243" ]
          }
        } ]
      }
    }

Example Responses

Status code: 200

OK

{
  "orders" : [ {
    "orderId" : "CS2303030941NJJIW",
    "cloudServiceId" : "cbr",
    "subscribeResult" : 1,
    "resourceId" : "ef3bf6bb-1ffb-46c0-8b23-f935ded5024a"
  } ],
  "retCode" : 0,
  "errText" : "success",
  "error_code" : 0
}

Status Codes

Status Code

Description

200

OK

400

Bad Request

Error Codes

See Error Codes.