com.aliyun.sdk.service.ecs20140526.models.CreatePrefixListRequest Maven / Gradle / Ivy
Show all versions of alibabacloud-ecs20140526 Show documentation
// This file is auto-generated, don't edit it. Thanks.
package com.aliyun.sdk.service.ecs20140526.models;
import com.aliyun.sdk.gateway.pop.*;
import darabonba.core.*;
import darabonba.core.async.*;
import darabonba.core.sync.*;
import darabonba.core.client.*;
import darabonba.core.RequestModel;
import darabonba.core.TeaModel;
import com.aliyun.sdk.gateway.pop.models.*;
/**
*
* {@link CreatePrefixListRequest} extends {@link RequestModel}
*
* CreatePrefixListRequest
*/
public class CreatePrefixListRequest extends Request {
@com.aliyun.core.annotation.Host
@com.aliyun.core.annotation.NameInMap("SourceRegionId")
private String sourceRegionId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("AddressFamily")
@com.aliyun.core.annotation.Validation(required = true)
private String addressFamily;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ClientToken")
private String clientToken;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("Description")
private String description;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("Entry")
private java.util.List entry;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("MaxEntries")
@com.aliyun.core.annotation.Validation(required = true, maximum = 200, minimum = 1)
private Integer maxEntries;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("OwnerAccount")
private String ownerAccount;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("OwnerId")
private Long ownerId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("PrefixListName")
@com.aliyun.core.annotation.Validation(required = true)
private String prefixListName;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("RegionId")
@com.aliyun.core.annotation.Validation(required = true)
private String regionId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ResourceOwnerAccount")
private String resourceOwnerAccount;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ResourceOwnerId")
private Long resourceOwnerId;
private CreatePrefixListRequest(Builder builder) {
super(builder);
this.sourceRegionId = builder.sourceRegionId;
this.addressFamily = builder.addressFamily;
this.clientToken = builder.clientToken;
this.description = builder.description;
this.entry = builder.entry;
this.maxEntries = builder.maxEntries;
this.ownerAccount = builder.ownerAccount;
this.ownerId = builder.ownerId;
this.prefixListName = builder.prefixListName;
this.regionId = builder.regionId;
this.resourceOwnerAccount = builder.resourceOwnerAccount;
this.resourceOwnerId = builder.resourceOwnerId;
}
public static Builder builder() {
return new Builder();
}
public static CreatePrefixListRequest create() {
return builder().build();
}
@Override
public Builder toBuilder() {
return new Builder(this);
}
/**
* @return sourceRegionId
*/
public String getSourceRegionId() {
return this.sourceRegionId;
}
/**
* @return addressFamily
*/
public String getAddressFamily() {
return this.addressFamily;
}
/**
* @return clientToken
*/
public String getClientToken() {
return this.clientToken;
}
/**
* @return description
*/
public String getDescription() {
return this.description;
}
/**
* @return entry
*/
public java.util.List getEntry() {
return this.entry;
}
/**
* @return maxEntries
*/
public Integer getMaxEntries() {
return this.maxEntries;
}
/**
* @return ownerAccount
*/
public String getOwnerAccount() {
return this.ownerAccount;
}
/**
* @return ownerId
*/
public Long getOwnerId() {
return this.ownerId;
}
/**
* @return prefixListName
*/
public String getPrefixListName() {
return this.prefixListName;
}
/**
* @return regionId
*/
public String getRegionId() {
return this.regionId;
}
/**
* @return resourceOwnerAccount
*/
public String getResourceOwnerAccount() {
return this.resourceOwnerAccount;
}
/**
* @return resourceOwnerId
*/
public Long getResourceOwnerId() {
return this.resourceOwnerId;
}
public static final class Builder extends Request.Builder {
private String sourceRegionId;
private String addressFamily;
private String clientToken;
private String description;
private java.util.List entry;
private Integer maxEntries;
private String ownerAccount;
private Long ownerId;
private String prefixListName;
private String regionId;
private String resourceOwnerAccount;
private Long resourceOwnerId;
private Builder() {
super();
}
private Builder(CreatePrefixListRequest request) {
super(request);
this.sourceRegionId = request.sourceRegionId;
this.addressFamily = request.addressFamily;
this.clientToken = request.clientToken;
this.description = request.description;
this.entry = request.entry;
this.maxEntries = request.maxEntries;
this.ownerAccount = request.ownerAccount;
this.ownerId = request.ownerId;
this.prefixListName = request.prefixListName;
this.regionId = request.regionId;
this.resourceOwnerAccount = request.resourceOwnerAccount;
this.resourceOwnerId = request.resourceOwnerId;
}
/**
* SourceRegionId.
*/
public Builder sourceRegionId(String sourceRegionId) {
this.putHostParameter("SourceRegionId", sourceRegionId);
this.sourceRegionId = sourceRegionId;
return this;
}
/**
* The IP address family. Valid values:
*
* - IPv4
* - IPv6
*
* This parameter is required.
*
* example:
* IPv4
*/
public Builder addressFamily(String addressFamily) {
this.putQueryParameter("AddressFamily", addressFamily);
this.addressFamily = addressFamily;
return this;
}
/**
* 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 and cannot exceed 64 characters in length. For more information, see How to ensure idempotence.
*
* example:
* 0c593ea1-3bea-11e9-b96b-88e9fe637760
*/
public Builder clientToken(String clientToken) {
this.putQueryParameter("ClientToken", clientToken);
this.clientToken = clientToken;
return this;
}
/**
* The description of the prefix list. The description must be 2 to 256 characters in length and cannot start with http://
or https://
.
*
* example:
* This is description.
*/
public Builder description(String description) {
this.putQueryParameter("Description", description);
this.description = description;
return this;
}
/**
* The details of entries in the prefix list.
*/
public Builder entry(java.util.List entry) {
this.putQueryParameter("Entry", entry);
this.entry = entry;
return this;
}
/**
* The maximum number of entries that the prefix list can contain. Valid values: 1 to 200.
* This parameter is required.
*
* example:
* 10
*/
public Builder maxEntries(Integer maxEntries) {
this.putQueryParameter("MaxEntries", maxEntries);
this.maxEntries = maxEntries;
return this;
}
/**
* OwnerAccount.
*/
public Builder ownerAccount(String ownerAccount) {
this.putQueryParameter("OwnerAccount", ownerAccount);
this.ownerAccount = ownerAccount;
return this;
}
/**
* OwnerId.
*/
public Builder ownerId(Long ownerId) {
this.putQueryParameter("OwnerId", ownerId);
this.ownerId = ownerId;
return this;
}
/**
* The name of the prefix list. The name must be 2 to 128 characters in length, and can contain letters, digits, colons (:), underscores (_), periods (.), and hyphens (-). It must start with a letter and cannot start with http://
, https://
, com.aliyun
, or com.alibabacloud
.
* This parameter is required.
*
* example:
* PrefixListNameSample
*/
public Builder prefixListName(String prefixListName) {
this.putQueryParameter("PrefixListName", prefixListName);
this.prefixListName = prefixListName;
return this;
}
/**
* The ID of the region in which to create the prefix list.
* This parameter is required.
*
* example:
* cn-chengdu
*/
public Builder regionId(String regionId) {
this.putQueryParameter("RegionId", regionId);
this.regionId = regionId;
return this;
}
/**
* ResourceOwnerAccount.
*/
public Builder resourceOwnerAccount(String resourceOwnerAccount) {
this.putQueryParameter("ResourceOwnerAccount", resourceOwnerAccount);
this.resourceOwnerAccount = resourceOwnerAccount;
return this;
}
/**
* ResourceOwnerId.
*/
public Builder resourceOwnerId(Long resourceOwnerId) {
this.putQueryParameter("ResourceOwnerId", resourceOwnerId);
this.resourceOwnerId = resourceOwnerId;
return this;
}
@Override
public CreatePrefixListRequest build() {
return new CreatePrefixListRequest(this);
}
}
/**
*
* {@link CreatePrefixListRequest} extends {@link TeaModel}
*
* CreatePrefixListRequest
*/
public static class Entry extends TeaModel {
@com.aliyun.core.annotation.NameInMap("Cidr")
@com.aliyun.core.annotation.Validation(required = true)
private String cidr;
@com.aliyun.core.annotation.NameInMap("Description")
private String description;
private Entry(Builder builder) {
this.cidr = builder.cidr;
this.description = builder.description;
}
public static Builder builder() {
return new Builder();
}
public static Entry create() {
return builder().build();
}
/**
* @return cidr
*/
public String getCidr() {
return this.cidr;
}
/**
* @return description
*/
public String getDescription() {
return this.description;
}
public static final class Builder {
private String cidr;
private String description;
/**
* The CIDR block in entry N. Valid values of N: 0 to 200. Take note of the following items:
*
* - The total number of entries cannot exceed the
MaxEntries
value.
* - CIDR block types are determined by the IP address family. You cannot combine IPv4 and IPv6 CIDR blocks in a single prefix list.
* - CIDR blocks must be unique across all entries in a prefix list. For example, you cannot specify 192.168.1.0/24 twice in the entries of the prefix list.
* - IP addresses are supported. The system converts IP addresses into CIDR blocks. For example, if you specify 192.168.1.100, the system converts it into the 192.168.1.100/32 CIDR block.
* - If an IPv6 CIDR block is used, the system converts it into the zero compression format and changes uppercase letters into lowercase ones. For example, if you specify 2001:0DB8:0000:0000:0000:0000:0000:0000/32, the system converts it into 2001:db8::/32.
*
* For more information about CIDR blocks, see the What is CIDR? section in the "Network FAQ" topic.
* This parameter is empty by default.
* This parameter is required.
*
* example:
* 192.168.1.0/24
*/
public Builder cidr(String cidr) {
this.cidr = cidr;
return this;
}
/**
* The description in entry N. The description must be 2 to 32 characters in length and cannot start with http://
or https://
. Valid values of N: 0 to 200.
*
* example:
* Description Sample 01
*/
public Builder description(String description) {
this.description = description;
return this;
}
public Entry build() {
return new Entry(this);
}
}
}
}