文档首页/ 云连接 CC/ API参考/ API/ 中心网络管理/ 创建一个新版本的中心网络策略
更新时间:2024-11-25 GMT+08:00

创建一个新版本的中心网络策略

功能介绍

创建一份只读的中心网络的策略。如果您有策略文档内容改动,需要基于此版本重新创建一个新版本的策略。

调试

您可以在API Explorer中调试该接口,支持自动认证鉴权。API Explorer可以自动生成SDK代码示例,并提供SDK代码示例调试功能。

URI

POST /v3/{domain_id}/gcn/central-network/{central_network_id}/policies

表1 路径参数

参数

是否必选

参数类型

描述

domain_id

String

账号ID。

central_network_id

String

中心网络的ID。

请求参数

表2 请求Header参数

参数

是否必选

参数类型

描述

X-Auth-Token

String

用户Token。

表3 请求Body参数

参数

是否必选

参数类型

描述

central_network_policy_document

CentralNetworkPolicyDocument object

中心网络策略文档。

表4 CentralNetworkPolicyDocument

参数

是否必选

参数类型

描述

default_plane

String

中心网络默认平面的名字。

planes

Array of CentralNetworkPlaneDocument objects

中心网络平面列表。

er_instances

Array of AssociateErInstanceDocument objects

中心网络ER实例列表。

表5 CentralNetworkPlaneDocument

参数

是否必选

参数类型

描述

name

String

实例名称。

associate_er_tables

Array of AssociateErTableDocument objects

关联的中心网络ER实例列表。

exclude_er_connections

Array of ExcludeErConnectionDocument objects

当自动连接所有ER实例时,排除中心网络的ER实例的连接。

表6 AssociateErTableDocument

参数

是否必选

参数类型

描述

project_id

String

实例所属项目ID。

region_id

String

RegionID。

enterprise_router_id

String

企业路由器的ID。

enterprise_router_table_id

String

企业路由器的路由表ID。

表7 ExcludeErConnectionDocument

参数

是否必选

参数类型

描述

[数组元素]

Array of AssociateErInstanceDocument objects

中心网络平面管理的ER连接

表8 AssociateErInstanceDocument

参数

是否必选

参数类型

描述

enterprise_router_id

String

企业路由器的ID。

project_id

String

实例所属项目ID。

region_id

String

RegionID。

响应参数

状态码: 201

表9 响应Body参数

参数

参数类型

描述

request_id

String

请求ID。

central_network_policy

CentralNetworkPolicy object

中心网络策略详情。

表10 CentralNetworkPolicy

参数

参数类型

描述

id

String

实例ID。

created_at

String

实例创建时间。UTC时间格式,yyyy-MM-ddTHH:mm:ss。

domain_id

String

实例所属账号ID。

state

String

中心网络策略状态。

  • AVAILABLE (可用)

  • CANCELING (取消中)

  • APPLYING (应用中)

  • FAILED (失败)

  • DELETED (已刪除)

central_network_id

String

中心网络ID。

document_template_version

String

文档模板版本。

  • 2022.08.30 (2022.08.30)

is_applied

Boolean

是否被应用。

version

Integer

中心网络策略的版本。

document

CentralNetworkPolicyDocument object

中心网络策略文档。

表11 CentralNetworkPolicyDocument

参数

参数类型

描述

default_plane

String

中心网络默认平面的名字。

planes

Array of CentralNetworkPlaneDocument objects

中心网络平面列表。

er_instances

Array of AssociateErInstanceDocument objects

中心网络ER实例列表。

表12 CentralNetworkPlaneDocument

参数

参数类型

描述

name

String

实例名称。

associate_er_tables

Array of AssociateErTableDocument objects

关联的中心网络ER实例列表。

exclude_er_connections

Array of ExcludeErConnectionDocument objects

当自动连接所有ER实例时,排除中心网络的ER实例的连接。

表13 AssociateErTableDocument

参数

参数类型

描述

project_id

String

实例所属项目ID。

region_id

String

RegionID。

enterprise_router_id

String

企业路由器的ID。

enterprise_router_table_id

String

企业路由器的路由表ID。

表14 ExcludeErConnectionDocument

参数

参数类型

描述

[数组元素]

Array of AssociateErInstanceDocument objects

中心网络平面管理的ER连接

表15 AssociateErInstanceDocument

参数

参数类型

描述

enterprise_router_id

String

企业路由器的ID。

project_id

String

实例所属项目ID。

region_id

String

RegionID。

请求示例

创建中心网络策略

POST /v3/{domain_id}/gcn/central-network/{central_network_id}/policies

{
  "central_network_policy_document" : {
    "default_plane" : "default-plane",
    "planes" : [ {
      "name" : "default-plane"
    } ],
    "er_instances" : [ {
      "enterprise_router_id" : "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
      "project_id" : "XXX",
      "region_id" : "region-abc"
    } ]
  }
}

响应示例

状态码: 201

创建中心网络策略成功。

{
  "request_id" : "76bfd2b0d492d0e479fbbd3981869c12",
  "central_network_policy" : {
    "id" : "f03478aa-3975-4ca7-9fb2-b49428a01636",
    "created_at" : "2023-10-09T06:22:40.857Z",
    "domain_id" : "XXX",
    "state" : "AVAILABLE",
    "central_network_id" : "e096c86f-817c-418c-945c-6b1d8860a15d",
    "document_template_version" : "2022.08.30",
    "is_applied" : true,
    "version" : 1,
    "document" : {
      "default_plane" : "default-plane",
      "planes" : [ {
        "name" : "default-plane",
        "associate_er_tables" : [ {
          "project_id" : "XXX",
          "region_id" : "region-abc",
          "enterprise_router_id" : "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
          "enterprise_router_table_id" : "cc542128-5c2d-402a-8960-53bb2ed9484e"
        } ]
      } ],
      "er_instances" : [ {
        "enterprise_router_id" : "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
        "project_id" : "XXX",
        "region_id" : "region-abc"
      } ]
    }
  }
}

SDK代码示例

SDK代码示例如下。

创建中心网络策略

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
package com.huaweicloud.sdk.test;

import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.GlobalCredentials;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.cc.v3.region.CcRegion;
import com.huaweicloud.sdk.cc.v3.*;
import com.huaweicloud.sdk.cc.v3.model.*;

import java.util.List;
import java.util.ArrayList;

public class CreateCentralNetworkPolicySolution {

    public static void main(String[] args) {
        // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
        // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
        String ak = System.getenv("CLOUD_SDK_AK");
        String sk = System.getenv("CLOUD_SDK_SK");

        ICredential auth = new GlobalCredentials()
                .withAk(ak)
                .withSk(sk);

        CcClient client = CcClient.newBuilder()
                .withCredential(auth)
                .withRegion(CcRegion.valueOf("<YOUR REGION>"))
                .build();
        CreateCentralNetworkPolicyRequest request = new CreateCentralNetworkPolicyRequest();
        request.withCentralNetworkId("{central_network_id}");
        CreateCentralNetworkPolicyRequestBody body = new CreateCentralNetworkPolicyRequestBody();
        List<AssociateErInstanceDocument> listCentralNetworkPolicyDocumentErInstances = new ArrayList<>();
        listCentralNetworkPolicyDocumentErInstances.add(
            new AssociateErInstanceDocument()
                .withEnterpriseRouterId("395b0884-aab4-4bf0-8cb8-7f2da26708dd")
                .withRegionId("region-abc")
                .withProjectId("XXX")
        );
        List<CentralNetworkPlaneDocument> listCentralNetworkPolicyDocumentPlanes = new ArrayList<>();
        listCentralNetworkPolicyDocumentPlanes.add(
            new CentralNetworkPlaneDocument()
                .withName("default-plane")
        );
        CentralNetworkPolicyDocument centralNetworkPolicyDocumentbody = new CentralNetworkPolicyDocument();
        centralNetworkPolicyDocumentbody.withDefaultPlane("default-plane")
            .withPlanes(listCentralNetworkPolicyDocumentPlanes)
            .withErInstances(listCentralNetworkPolicyDocumentErInstances);
        body.withCentralNetworkPolicyDocument(centralNetworkPolicyDocumentbody);
        request.withBody(body);
        try {
            CreateCentralNetworkPolicyResponse response = client.createCentralNetworkPolicy(request);
            System.out.println(response.toString());
        } catch (ConnectionException e) {
            e.printStackTrace();
        } catch (RequestTimeoutException e) {
            e.printStackTrace();
        } catch (ServiceResponseException e) {
            e.printStackTrace();
            System.out.println(e.getHttpStatusCode());
            System.out.println(e.getRequestId());
            System.out.println(e.getErrorCode());
            System.out.println(e.getErrorMsg());
        }
    }
}

创建中心网络策略

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# coding: utf-8

import os
from huaweicloudsdkcore.auth.credentials import GlobalCredentials
from huaweicloudsdkcc.v3.region.cc_region import CcRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkcc.v3 import *

if __name__ == "__main__":
    # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak = os.environ["CLOUD_SDK_AK"]
    sk = os.environ["CLOUD_SDK_SK"]

    credentials = GlobalCredentials(ak, sk)

    client = CcClient.new_builder() \
        .with_credentials(credentials) \
        .with_region(CcRegion.value_of("<YOUR REGION>")) \
        .build()

    try:
        request = CreateCentralNetworkPolicyRequest()
        request.central_network_id = "{central_network_id}"
        listErInstancesCentralNetworkPolicyDocument = [
            AssociateErInstanceDocument(
                enterprise_router_id="395b0884-aab4-4bf0-8cb8-7f2da26708dd",
                region_id="region-abc",
                project_id="XXX"
            )
        ]
        listPlanesCentralNetworkPolicyDocument = [
            CentralNetworkPlaneDocument(
                name="default-plane"
            )
        ]
        centralNetworkPolicyDocumentbody = CentralNetworkPolicyDocument(
            default_plane="default-plane",
            planes=listPlanesCentralNetworkPolicyDocument,
            er_instances=listErInstancesCentralNetworkPolicyDocument
        )
        request.body = CreateCentralNetworkPolicyRequestBody(
            central_network_policy_document=centralNetworkPolicyDocumentbody
        )
        response = client.create_central_network_policy(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)

创建中心网络策略

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
    cc "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/cc/v3"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/cc/v3/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/cc/v3/region"
)

func main() {
    // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak := os.Getenv("CLOUD_SDK_AK")
    sk := os.Getenv("CLOUD_SDK_SK")

    auth := global.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        Build()

    client := cc.NewCcClient(
        cc.CcClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.CreateCentralNetworkPolicyRequest{}
	request.CentralNetworkId = "{central_network_id}"
	var listErInstancesCentralNetworkPolicyDocument = []model.AssociateErInstanceDocument{
        {
            EnterpriseRouterId: "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
            RegionId: "region-abc",
            ProjectId: "XXX",
        },
    }
	var listPlanesCentralNetworkPolicyDocument = []model.CentralNetworkPlaneDocument{
        {
            Name: "default-plane",
        },
    }
	centralNetworkPolicyDocumentbody := &model.CentralNetworkPolicyDocument{
		DefaultPlane: "default-plane",
		Planes: listPlanesCentralNetworkPolicyDocument,
		ErInstances: &listErInstancesCentralNetworkPolicyDocument,
	}
	request.Body = &model.CreateCentralNetworkPolicyRequestBody{
		CentralNetworkPolicyDocument: centralNetworkPolicyDocumentbody,
	}
	response, err := client.CreateCentralNetworkPolicy(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

更多编程语言的SDK代码示例,请参见API Explorer的代码示例页签,可生成自动对应的SDK代码示例。

状态码

状态码

描述

201

创建中心网络策略成功。

错误码

请参见错误码