Creates an IPsec server.
Operation description
-
Before you create an IPsec server, you must create a VPN gateway and enable the SSL-VPN feature for the VPN gateway. For more information, see CreateVpnGateway .
-
Before you create an IPsec server, make sure that no IPsec-VPN connection exists on the VPN gateway. For more information, see DeleteVpnConnection .
-
CreateIpsecServer is an asynchronous operation. After a request is sent, the system returns a request ID and runs the task in the background. You can call DescribeVpnGateway to query the status of the task.
- If the VPN gateway is in the updating state, the IPsec server is being created.
- If the VPN gateway is in the active state, the IPsec server is created.
-
You cannot repeatedly call CreateIpsecServer within the specified period of time.
Debugging
Authorization information
The following table shows the authorization information corresponding to the API. The authorization information can be used in the Action
policy element to grant a RAM user or RAM role the permissions to call this API operation. Description:
- Operation: the value that you can use in the Action element to specify the operation on a resource.
- Access level: the access level of each operation. The levels are read, write, and list.
- Resource type: the type of the resource on which you can authorize the RAM user or the RAM role to perform the operation. Take note of the following items:
- The required resource types are displayed in bold characters.
- If the permissions cannot be granted at the resource level,
All Resources
is used in the Resource type column of the operation.
- Condition Key: the condition key that is defined by the cloud service.
- Associated operation: other operations that the RAM user or the RAM role must have permissions to perform to complete the operation. To complete the operation, the RAM user or the RAM role must have the permissions to perform the associated operations.
Operation | Access level | Resource type | Condition key | Associated operation |
---|---|---|---|---|
vpc:CreateIpsecServer | create | *All Resources * |
| none |
Request parameters
Parameter | Type | Required | Description | Example |
---|---|---|---|---|
RegionId | string | Yes | The ID of the region where the VPN gateway is deployed. | cn-hangzhou |
VpnGatewayId | string | Yes | The ID of the VPN gateway. | vpn-bp17lofy9fd0dnvzv**** |
LocalSubnet | string | Yes | The local CIDR blocks, which are the CIDR blocks of the virtual private cloud (VPC) for the client to access. Multiple CIDR blocks are separated with commas (,). Example: 192.168.1.0/24,192.168.2.0/24. | 192.168.0.0/24 |
ClientIpPool | string | Yes | The client CIDR block from which an IP address is allocated to the virtual network interface controller (NIC) of the client. Note
The client CIDR block must not overlap with the CIDR blocks of the VPC.
| 10.0.0.0/24 |
IpSecServerName | string | No | The name of the IPsec server. The name must be 1 to 100 characters in length. | test |
EffectImmediately | boolean | No | Specify whether to start connection negotiations immediately. Valid values:
| true |
IkeConfig | string | No | The configuration of Phase 1 negotiation. Valid values:
| {"IkeVersion":"ikev2","IkeMode":"main","IkeEncAlg":"aes","IkeAuthAlg":"sha1","IkePfs":"group2","IkeLifetime":86400} |
IpsecConfig | string | No | The configuration of Phase 2 negotiation. Valid values:
| {"IpsecEncAlg":"aes","IpsecAuthAlg":"sha1","IpsecPfs":"group2","IpsecLifetime":86400} |
PskEnabled | boolean | No | Indicates whether pre-shared key authentication is enabled. If you set the value to true, pre-shared key authentication is enabled. Note
This parameter is required.
| true |
Psk | string | No | The pre-shared key. The pre-shared key is used for identity authentication between the IPsec server and the client. The key must be 1 to 100 characters in length. If you do not specify a pre-shared key, the system randomly generates a 16-character string as the pre-shared key. You can call the ListIpsecServers operation to query the pre-shared keys that are generated by the system. Note
The pre-shared key of the IPsec server must be the same as the client key. Otherwise, the IPsec server cannot be connected to the client.
| Cfd123**** |
ClientToken | string | No | The client token that is used to ensure the idempotence of the request. You can use the client to generate the token, but you must make sure that the token is unique among different requests. The token can contain only ASCII characters. Note
If you do not specify this parameter, the system automatically uses the request ID as the client token. The request ID may be different for each request.
| d7d24a21-f4ba-4454-9173-b38**** |
DryRun | string | No | Specifies whether to only precheck this request. Valid values:
| false |
Response parameters
Examples
Sample success responses
JSON
format
{
"CreationTime": "2021-02-22T03:24:28Z",
"IpsecServerId": "iss-bp1jougp8cfsbo8y9****",
"RequestId": "690A967E-D4CD-4B69-8C78-94FE828BA10B",
"IpsecServerName": "test",
"VpnGatewayId": "vpn-bp17lofy9fd0dnvzv****",
"RegionId": "cn-hangzhou"
}
Error codes
HTTP status code | Error code | Error message | Description |
---|---|---|---|
400 | OperationUnsupported.IPsecServer | The current version of the VPN gateway does not support IPsec server. | The current version of the VPN gateway does not support IPsec server. |
400 | VpnGateway.SslVpnDisabled | The VPN gateway has not enabled SSL VPN. | The SSL-VPN feature is disabled for the VPN gateway. |
400 | VpnGateway.Configuring | The specified service is configuring. | The service is being configured. Try again later. |
400 | VpnGateway.FinancialLocked | The specified service is financial locked. | The service is suspended due to overdue payments. Top up your account first. |
400 | OperationFailed.IPsecServerExist | An IPsec server already exists in the VPN gateway. | An IPsec server already exists in the VPN gateway. |
400 | OperationUnsupported.IpsecPfs | The specified IPsec Pfs is unsupported. | The specified IPsec PFS property is not supported. |
400 | IllegalParam.AuthMethod | One authentication method (Psk or IDaaS) should be specified at least. | You must specify at least one authentication method, such as PSK or IDaaS. |
400 | IllegalParam.LocalSubnet | The specified "LocalSubnet" (%s) is invalid. | The specified "LocalSubnet" (%s) is invalid. |
400 | IllegalParam.ClientIpPool | The specified ClientIpPool (%s) is invalid. | The client CIDR block (%s) is invalid. |
400 | MissingParam.IDaaSInstanceId | The input parameter IDaaSInstanceId is mandatory when enable multi-factor authentication. | You must specify the IDaaS instance ID when two-factor authentication is enabled. |
400 | OperationFailed.NoRamPermission | Vpn Service has no permission to operate your IDaaS instances. | The VPN service does not have the permissions to manage your IDaaS instance. |
400 | ClientIpPool.NetmaskInvalid | The netmask length of client IP pool must be greater than or equal to 16 and less than or equal to 29. | The subnet mask of the client IP pool must range from 16 to 29. |
400 | VpnRouteEntry.Conflict | The specified client IP pool conflicts with VPN connection or SSL server. | The specified client IP pool conflicts with the VPN connection or the SSL server. |
400 | ClientIpPool.SubnetInvalid | The specified client IP pool cannot be used. | The client CIDR block is unavailable. |
400 | InvalidClientIpPool.Conflict | The specified client IP pool conflicts with other resources in the same VPC. | The client CIDR block conflicts with resources in the VPC. |
400 | OperationFailed.AddVpcRoute | It is failed to add VPC route after this operation. | VPC routes failed to be added after the operation is performed. |
400 | QuotaExceeded.VpnRouteEntry | The number of route entries to the VPN gateway in the VPC routing table has reached the quota limit. | The number of route entries to the VPN gateway in the VPC routing table has reached the quota limit. |
400 | SystemBusy | The system is busy. Please try again later. | The system is busy. Please try again later. |
400 | EnableHaCheck.IpsecServerCidrContainsVpcRouteDest | Ipsec server client cidr contains vpc route prefix. The vpc route prefix is %s. | The prefix %s in the VPC route table falls within the CIDR block of the IPsec client. |
400 | VpnGateway.IPsecServerAndVpnConnectionConflict | The IPSec connection and IPSec server cannot be configured on the same VPN gateway at the same time. | You cannot configure an IPsec server and an IPsec-VPN connection at the same time for one VPN gateway. |
403 | Forbidden | User not authorized to operate on the specified resource. | You do not have the permissions to manage the specified resource. Apply for the permissions and try again. |
404 | InvalidVpnGatewayInstanceId.NotFound | The specified vpn gateway instance id does not exist. | The specified VPN gateway does not exist. Check whether the specified VPN gateway is valid. |
404 | InvalidIDaaSInstanceId.NotFound | The specified IDaaS instance ID does not exist. | The specified IDaaS instance does not exist. |
409 | OperationConflict | The operation against this instance is too frequent, please try again later. | Operations are too frequently performed on the instance. Try again later. |
For a list of error codes, visit the Service error codes.
Change history
Change time | Summary of changes | Operation |
---|---|---|
2024-01-04 | The Error code has changed | View Change Details |
2023-10-19 | API Description Update. The Error code has changed | View Change Details |