创建一个新版本的中心网络策略
功能介绍
创建一份只读的中心网络的策略。如果您有策略文档内容改动,需要基于此版本重新创建一个新版本的策略。
调试
您可以在API Explorer中调试该接口,支持自动认证鉴权。API Explorer可以自动生成SDK代码示例,并提供SDK代码示例调试功能。
URI
POST /v3/{domain_id}/gcn/central-network/{central_network_id}/policies
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
domain_id |
是 |
String |
账号ID。 |
central_network_id |
是 |
String |
中心网络的ID。 |
请求参数
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
X-Auth-Token |
否 |
String |
用户Token。 |
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
central_network_policy_document |
是 |
CentralNetworkPolicyDocument object |
中心网络策略文档。 |
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
default_plane |
是 |
String |
中心网络默认平面的名字。 |
planes |
是 |
Array of CentralNetworkPlaneDocument objects |
中心网络平面列表。 |
er_instances |
否 |
Array of AssociateErInstanceDocument objects |
中心网络ER实例列表。 |
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
name |
是 |
String |
实例名称。 |
associate_er_tables |
否 |
Array of AssociateErTableDocument objects |
关联的中心网络ER实例列表。 |
exclude_er_connections |
否 |
Array of ExcludeErConnectionDocument objects |
当自动连接所有ER实例时,排除中心网络的ER实例的连接。 |
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
project_id |
是 |
String |
实例所属项目ID。 |
region_id |
是 |
String |
RegionID。 |
enterprise_router_id |
是 |
String |
企业路由器的ID。 |
enterprise_router_table_id |
是 |
String |
企业路由器的路由表ID。 |
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
[数组元素] |
否 |
Array of AssociateErInstanceDocument objects |
中心网络平面管理的ER连接 |
响应参数
状态码: 201
参数 |
参数类型 |
描述 |
---|---|---|
request_id |
String |
请求ID。 |
central_network_policy |
CentralNetworkPolicy object |
中心网络策略详情。 |
参数 |
参数类型 |
描述 |
---|---|---|
id |
String |
实例ID。 |
created_at |
String |
实例创建时间。UTC时间格式,yyyy-MM-ddTHH:mm:ss。 |
domain_id |
String |
实例所属账号ID。 |
state |
String |
中心网络策略状态。
|
central_network_id |
String |
中心网络ID。 |
document_template_version |
String |
文档模板版本。
|
is_applied |
Boolean |
是否被应用。 |
version |
Integer |
中心网络策略的版本。 |
document |
CentralNetworkPolicyDocument object |
中心网络策略文档。 |
参数 |
参数类型 |
描述 |
---|---|---|
default_plane |
String |
中心网络默认平面的名字。 |
planes |
Array of CentralNetworkPlaneDocument objects |
中心网络平面列表。 |
er_instances |
Array of AssociateErInstanceDocument objects |
中心网络ER实例列表。 |
参数 |
参数类型 |
描述 |
---|---|---|
name |
String |
实例名称。 |
associate_er_tables |
Array of AssociateErTableDocument objects |
关联的中心网络ER实例列表。 |
exclude_er_connections |
Array of ExcludeErConnectionDocument objects |
当自动连接所有ER实例时,排除中心网络的ER实例的连接。 |
参数 |
参数类型 |
描述 |
---|---|---|
project_id |
String |
实例所属项目ID。 |
region_id |
String |
RegionID。 |
enterprise_router_id |
String |
企业路由器的ID。 |
enterprise_router_table_id |
String |
企业路由器的路由表ID。 |
参数 |
参数类型 |
描述 |
---|---|---|
[数组元素] |
Array of AssociateErInstanceDocument objects |
中心网络平面管理的ER连接 |
请求示例
创建中心网络策略
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 |
创建中心网络策略成功。 |
错误码
请参见错误码。