com.aliyun.sdk.service.ecs20140526.models.DescribeInstanceAttributeResponseBody 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 DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public class DescribeInstanceAttributeResponseBody extends TeaModel {
@com.aliyun.core.annotation.NameInMap("ClusterId")
private String clusterId;
@com.aliyun.core.annotation.NameInMap("Cpu")
private Integer cpu;
@com.aliyun.core.annotation.NameInMap("CreationTime")
private String creationTime;
@com.aliyun.core.annotation.NameInMap("CreditSpecification")
private String creditSpecification;
@com.aliyun.core.annotation.NameInMap("DedicatedHostAttribute")
private DedicatedHostAttribute dedicatedHostAttribute;
@com.aliyun.core.annotation.NameInMap("Description")
private String description;
@com.aliyun.core.annotation.NameInMap("EipAddress")
private EipAddress eipAddress;
@com.aliyun.core.annotation.NameInMap("EnableJumboFrame")
private Boolean enableJumboFrame;
@com.aliyun.core.annotation.NameInMap("ExpiredTime")
private String expiredTime;
@com.aliyun.core.annotation.NameInMap("HostName")
private String hostName;
@com.aliyun.core.annotation.NameInMap("ImageId")
private String imageId;
@com.aliyun.core.annotation.NameInMap("InnerIpAddress")
private InnerIpAddress innerIpAddress;
@com.aliyun.core.annotation.NameInMap("InstanceChargeType")
private String instanceChargeType;
@com.aliyun.core.annotation.NameInMap("InstanceId")
private String instanceId;
@com.aliyun.core.annotation.NameInMap("InstanceName")
private String instanceName;
@com.aliyun.core.annotation.NameInMap("InstanceNetworkType")
private String instanceNetworkType;
@com.aliyun.core.annotation.NameInMap("InstanceType")
private String instanceType;
@com.aliyun.core.annotation.NameInMap("InternetChargeType")
private String internetChargeType;
@com.aliyun.core.annotation.NameInMap("InternetMaxBandwidthIn")
private Integer internetMaxBandwidthIn;
@com.aliyun.core.annotation.NameInMap("InternetMaxBandwidthOut")
private Integer internetMaxBandwidthOut;
@com.aliyun.core.annotation.NameInMap("IoOptimized")
private String ioOptimized;
@com.aliyun.core.annotation.NameInMap("Memory")
private Integer memory;
@com.aliyun.core.annotation.NameInMap("OperationLocks")
private OperationLocks operationLocks;
@com.aliyun.core.annotation.NameInMap("PublicIpAddress")
private PublicIpAddress publicIpAddress;
@com.aliyun.core.annotation.NameInMap("RegionId")
private String regionId;
@com.aliyun.core.annotation.NameInMap("RequestId")
private String requestId;
@com.aliyun.core.annotation.NameInMap("SecurityGroupIds")
private SecurityGroupIds securityGroupIds;
@com.aliyun.core.annotation.NameInMap("SerialNumber")
private String serialNumber;
@com.aliyun.core.annotation.NameInMap("Status")
private String status;
@com.aliyun.core.annotation.NameInMap("StoppedMode")
private String stoppedMode;
@com.aliyun.core.annotation.NameInMap("VlanId")
private String vlanId;
@com.aliyun.core.annotation.NameInMap("VpcAttributes")
private VpcAttributes vpcAttributes;
@com.aliyun.core.annotation.NameInMap("ZoneId")
private String zoneId;
private DescribeInstanceAttributeResponseBody(Builder builder) {
this.clusterId = builder.clusterId;
this.cpu = builder.cpu;
this.creationTime = builder.creationTime;
this.creditSpecification = builder.creditSpecification;
this.dedicatedHostAttribute = builder.dedicatedHostAttribute;
this.description = builder.description;
this.eipAddress = builder.eipAddress;
this.enableJumboFrame = builder.enableJumboFrame;
this.expiredTime = builder.expiredTime;
this.hostName = builder.hostName;
this.imageId = builder.imageId;
this.innerIpAddress = builder.innerIpAddress;
this.instanceChargeType = builder.instanceChargeType;
this.instanceId = builder.instanceId;
this.instanceName = builder.instanceName;
this.instanceNetworkType = builder.instanceNetworkType;
this.instanceType = builder.instanceType;
this.internetChargeType = builder.internetChargeType;
this.internetMaxBandwidthIn = builder.internetMaxBandwidthIn;
this.internetMaxBandwidthOut = builder.internetMaxBandwidthOut;
this.ioOptimized = builder.ioOptimized;
this.memory = builder.memory;
this.operationLocks = builder.operationLocks;
this.publicIpAddress = builder.publicIpAddress;
this.regionId = builder.regionId;
this.requestId = builder.requestId;
this.securityGroupIds = builder.securityGroupIds;
this.serialNumber = builder.serialNumber;
this.status = builder.status;
this.stoppedMode = builder.stoppedMode;
this.vlanId = builder.vlanId;
this.vpcAttributes = builder.vpcAttributes;
this.zoneId = builder.zoneId;
}
public static Builder builder() {
return new Builder();
}
public static DescribeInstanceAttributeResponseBody create() {
return builder().build();
}
/**
* @return clusterId
*/
public String getClusterId() {
return this.clusterId;
}
/**
* @return cpu
*/
public Integer getCpu() {
return this.cpu;
}
/**
* @return creationTime
*/
public String getCreationTime() {
return this.creationTime;
}
/**
* @return creditSpecification
*/
public String getCreditSpecification() {
return this.creditSpecification;
}
/**
* @return dedicatedHostAttribute
*/
public DedicatedHostAttribute getDedicatedHostAttribute() {
return this.dedicatedHostAttribute;
}
/**
* @return description
*/
public String getDescription() {
return this.description;
}
/**
* @return eipAddress
*/
public EipAddress getEipAddress() {
return this.eipAddress;
}
/**
* @return enableJumboFrame
*/
public Boolean getEnableJumboFrame() {
return this.enableJumboFrame;
}
/**
* @return expiredTime
*/
public String getExpiredTime() {
return this.expiredTime;
}
/**
* @return hostName
*/
public String getHostName() {
return this.hostName;
}
/**
* @return imageId
*/
public String getImageId() {
return this.imageId;
}
/**
* @return innerIpAddress
*/
public InnerIpAddress getInnerIpAddress() {
return this.innerIpAddress;
}
/**
* @return instanceChargeType
*/
public String getInstanceChargeType() {
return this.instanceChargeType;
}
/**
* @return instanceId
*/
public String getInstanceId() {
return this.instanceId;
}
/**
* @return instanceName
*/
public String getInstanceName() {
return this.instanceName;
}
/**
* @return instanceNetworkType
*/
public String getInstanceNetworkType() {
return this.instanceNetworkType;
}
/**
* @return instanceType
*/
public String getInstanceType() {
return this.instanceType;
}
/**
* @return internetChargeType
*/
public String getInternetChargeType() {
return this.internetChargeType;
}
/**
* @return internetMaxBandwidthIn
*/
public Integer getInternetMaxBandwidthIn() {
return this.internetMaxBandwidthIn;
}
/**
* @return internetMaxBandwidthOut
*/
public Integer getInternetMaxBandwidthOut() {
return this.internetMaxBandwidthOut;
}
/**
* @return ioOptimized
*/
public String getIoOptimized() {
return this.ioOptimized;
}
/**
* @return memory
*/
public Integer getMemory() {
return this.memory;
}
/**
* @return operationLocks
*/
public OperationLocks getOperationLocks() {
return this.operationLocks;
}
/**
* @return publicIpAddress
*/
public PublicIpAddress getPublicIpAddress() {
return this.publicIpAddress;
}
/**
* @return regionId
*/
public String getRegionId() {
return this.regionId;
}
/**
* @return requestId
*/
public String getRequestId() {
return this.requestId;
}
/**
* @return securityGroupIds
*/
public SecurityGroupIds getSecurityGroupIds() {
return this.securityGroupIds;
}
/**
* @return serialNumber
*/
public String getSerialNumber() {
return this.serialNumber;
}
/**
* @return status
*/
public String getStatus() {
return this.status;
}
/**
* @return stoppedMode
*/
public String getStoppedMode() {
return this.stoppedMode;
}
/**
* @return vlanId
*/
public String getVlanId() {
return this.vlanId;
}
/**
* @return vpcAttributes
*/
public VpcAttributes getVpcAttributes() {
return this.vpcAttributes;
}
/**
* @return zoneId
*/
public String getZoneId() {
return this.zoneId;
}
public static final class Builder {
private String clusterId;
private Integer cpu;
private String creationTime;
private String creditSpecification;
private DedicatedHostAttribute dedicatedHostAttribute;
private String description;
private EipAddress eipAddress;
private Boolean enableJumboFrame;
private String expiredTime;
private String hostName;
private String imageId;
private InnerIpAddress innerIpAddress;
private String instanceChargeType;
private String instanceId;
private String instanceName;
private String instanceNetworkType;
private String instanceType;
private String internetChargeType;
private Integer internetMaxBandwidthIn;
private Integer internetMaxBandwidthOut;
private String ioOptimized;
private Integer memory;
private OperationLocks operationLocks;
private PublicIpAddress publicIpAddress;
private String regionId;
private String requestId;
private SecurityGroupIds securityGroupIds;
private String serialNumber;
private String status;
private String stoppedMode;
private String vlanId;
private VpcAttributes vpcAttributes;
private String zoneId;
/**
* The ID of the cluster to which the instance belongs.
*
* This parameter will be removed in the future. To ensure future compatibility, we recommend that you use other parameters.
*
*
* example:
* cls-bp67acfmxazb4p****
*/
public Builder clusterId(String clusterId) {
this.clusterId = clusterId;
return this;
}
/**
* The number of vCPUs.
*
* example:
* 8
*/
public Builder cpu(Integer cpu) {
this.cpu = cpu;
return this;
}
/**
* The time when the instance was created. The time follows the ISO 8601 standard in the yyyy-MM-ddTHH:mm:ssZ format. The time is displayed in UTC. For more information, see ISO 8601.
*
* example:
* 2017-12-10T04:04Z
*/
public Builder creationTime(String creationTime) {
this.creationTime = creationTime;
return this;
}
/**
* The performance mode of the burstable instance. Valid values:
*
* - Standard: the standard mode. For more information, see the Performance modes section of the "Overview of burstable instances" topic.
* - Unlimited: the unlimited mode. For more information, see the Performance modes section of the "Overview of burstable instances" topic.
*
*
* example:
* Standard
*/
public Builder creditSpecification(String creditSpecification) {
this.creditSpecification = creditSpecification;
return this;
}
/**
* Details about the dedicated host. It is an array that consists of the DedicatedHostClusterId, DedicatedHostId, and DedicatedHostName parameters.
*/
public Builder dedicatedHostAttribute(DedicatedHostAttribute dedicatedHostAttribute) {
this.dedicatedHostAttribute = dedicatedHostAttribute;
return this;
}
/**
* The description of the instance.
*
* example:
* testDescription
*/
public Builder description(String description) {
this.description = description;
return this;
}
/**
* The elastic IP address (EIP) associated with the instance.
*/
public Builder eipAddress(EipAddress eipAddress) {
this.eipAddress = eipAddress;
return this;
}
/**
* Indicates whether the Jumbo Frame feature is enabled for the instance. Valid values:
*
* - true
* - false
*
* For more information, see MTUs.
*
* example:
* false
*/
public Builder enableJumboFrame(Boolean enableJumboFrame) {
this.enableJumboFrame = enableJumboFrame;
return this;
}
/**
* The time when the instance expires. The time follows the ISO 8601 standard in the yyyy-MM-ddTHH:mm:ssZ format. The time is displayed in UTC. For more information, see ISO 8601.
*
* example:
* 2017-12-10T04:04Z
*/
public Builder expiredTime(String expiredTime) {
this.expiredTime = expiredTime;
return this;
}
/**
* The hostname of the instance.
*
* example:
* testHostName
*/
public Builder hostName(String hostName) {
this.hostName = hostName;
return this;
}
/**
* The ID of the image that the instance is running.
*
* example:
* m-bp1h46wfpjsjastc****
*/
public Builder imageId(String imageId) {
this.imageId = imageId;
return this;
}
/**
* The internal IP address of the instance located in the classic network.
*/
public Builder innerIpAddress(InnerIpAddress innerIpAddress) {
this.innerIpAddress = innerIpAddress;
return this;
}
/**
* The billing method of the instance. Valid values:
*
* - PrePaid: subscription.
* - PostPaid: pay-as-you-go
*
*
* example:
* PrePaid
*/
public Builder instanceChargeType(String instanceChargeType) {
this.instanceChargeType = instanceChargeType;
return this;
}
/**
* The instance ID
*
* example:
* i-uf6f5trc95ug8t33****
*/
public Builder instanceId(String instanceId) {
this.instanceId = instanceId;
return this;
}
/**
* The instance name.
*
* example:
* testInstanceName
*/
public Builder instanceName(String instanceName) {
this.instanceName = instanceName;
return this;
}
/**
* The network type of the instance. Valid values:
*
* - classic: classic network
* - vpc: VPC
*
*
* example:
* vpc
*/
public Builder instanceNetworkType(String instanceNetworkType) {
this.instanceNetworkType = instanceNetworkType;
return this;
}
/**
* The instance type.
*
* example:
* ecs.g5.large
*/
public Builder instanceType(String instanceType) {
this.instanceType = instanceType;
return this;
}
/**
* The billing method for network usage. Valid values:
*
* - PayByBandwidth
* - PayByTraffic
*
*
* When the pay-by-traffic billing method is used for network usage, the maximum inbound and outbound bandwidths are used as the upper limits of bandwidths instead of guaranteed performance specifications. In scenarios in which demands exceed resource supplies, the maximum bandwidths may not be reached. If you want guaranteed bandwidths for your instance, use the pay-by-bandwidth billing method for network usage.
*
*
* example:
* PayByTraffic
*/
public Builder internetChargeType(String internetChargeType) {
this.internetChargeType = internetChargeType;
return this;
}
/**
* The maximum inbound public bandwidth. Unit: Mbit/s.
*
* example:
* 50
*/
public Builder internetMaxBandwidthIn(Integer internetMaxBandwidthIn) {
this.internetMaxBandwidthIn = internetMaxBandwidthIn;
return this;
}
/**
* The maximum outbound public bandwidth. Unit: Mbit/s.
*
* example:
* 5
*/
public Builder internetMaxBandwidthOut(Integer internetMaxBandwidthOut) {
this.internetMaxBandwidthOut = internetMaxBandwidthOut;
return this;
}
/**
* Indicates whether the ECS instance is I/O optimized. Valid values:
*
* - optimized: The ECS instance is I/O optimized.
* - none: The ECS instance is not I/O optimized.
*
*
* example:
* true
*/
public Builder ioOptimized(String ioOptimized) {
this.ioOptimized = ioOptimized;
return this;
}
/**
* The memory size of the instance. Unit: MiB.
*
* example:
* 16384
*/
public Builder memory(Integer memory) {
this.memory = memory;
return this;
}
/**
* The reason why the instance was locked. Valid values:
*
* - financial: The dedicated host was locked due to overdue payments.
* - security: The instance was locked due to security reasons.
* - recycling: The preemptible instance was locked and pending release.
* - dedicatedhostfinancial: The instance was locked due to overdue payments for the dedicated host.
* - refunded: The instance was locked because a refund was made for the instance.
*
*/
public Builder operationLocks(OperationLocks operationLocks) {
this.operationLocks = operationLocks;
return this;
}
/**
* The public IP address of the instance.
*/
public Builder publicIpAddress(PublicIpAddress publicIpAddress) {
this.publicIpAddress = publicIpAddress;
return this;
}
/**
* The ID of the region in which the instance resides.
*
* example:
* cn-hangzhou
*/
public Builder regionId(String regionId) {
this.regionId = regionId;
return this;
}
/**
* The request ID.
*
* example:
* 473469C7-AA6F-4DC5-B3DB-A3DC0DE3****
*/
public Builder requestId(String requestId) {
this.requestId = requestId;
return this;
}
/**
* The IDs of the security groups to which the instance belongs.
*/
public Builder securityGroupIds(SecurityGroupIds securityGroupIds) {
this.securityGroupIds = securityGroupIds;
return this;
}
/**
* The serial number of the instance.
*
* example:
* 51d1353b-22bf-4567-a176-8b3e12e4****
*/
public Builder serialNumber(String serialNumber) {
this.serialNumber = serialNumber;
return this;
}
/**
* The status of the instance. Valid values:
*
* - Pending: The instance is being created.
* - Running: The instance is running.
* - Starting: The instance is being started.
* - Stopping: The instance is being stopped.
* - Stopped: The instance is stopped.
*
*
* example:
* Running
*/
public Builder status(String status) {
this.status = status;
return this;
}
/**
* Indicates whether the system implements billing after the instance is stopped. Valid values:
*
* - KeepCharging: The instance is stopped in standard mode. The billing of the instance continues after the instance is stopped, and resources are retained for the instance.
* - StopCharging: The instance is stopped in economical mode. The billing of some resources of the instance stops after the instance is stopped. When the instance is stopped, its resources such as vCPUs, memory, and public IP address are released. The instance may be unable to start again if some required resources are out of stock in the current region.
* - Not-applicable: The instance does not support economical mode.
*
*
* example:
* KeepCharging
*/
public Builder stoppedMode(String stoppedMode) {
this.stoppedMode = stoppedMode;
return this;
}
/**
* The virtual LAN (VLAN) ID of the instance.
*
* This parameter will be removed in the future. To ensure future compatibility, we recommend that you use other parameters.
*
*
* example:
* 10
*/
public Builder vlanId(String vlanId) {
this.vlanId = vlanId;
return this;
}
/**
* The VPC attributes of the instance.
*/
public Builder vpcAttributes(VpcAttributes vpcAttributes) {
this.vpcAttributes = vpcAttributes;
return this;
}
/**
* The ID of the zone in which the instance resides.
*
* example:
* cn-hangzhou-g
*/
public Builder zoneId(String zoneId) {
this.zoneId = zoneId;
return this;
}
public DescribeInstanceAttributeResponseBody build() {
return new DescribeInstanceAttributeResponseBody(this);
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class DedicatedHostAttribute extends TeaModel {
@com.aliyun.core.annotation.NameInMap("DedicatedHostId")
private String dedicatedHostId;
@com.aliyun.core.annotation.NameInMap("DedicatedHostName")
private String dedicatedHostName;
private DedicatedHostAttribute(Builder builder) {
this.dedicatedHostId = builder.dedicatedHostId;
this.dedicatedHostName = builder.dedicatedHostName;
}
public static Builder builder() {
return new Builder();
}
public static DedicatedHostAttribute create() {
return builder().build();
}
/**
* @return dedicatedHostId
*/
public String getDedicatedHostId() {
return this.dedicatedHostId;
}
/**
* @return dedicatedHostName
*/
public String getDedicatedHostName() {
return this.dedicatedHostName;
}
public static final class Builder {
private String dedicatedHostId;
private String dedicatedHostName;
/**
* The ID of the dedicated host.
*
* example:
* dh-2ze7qrzz6lvbfhr0****
*/
public Builder dedicatedHostId(String dedicatedHostId) {
this.dedicatedHostId = dedicatedHostId;
return this;
}
/**
* The name of the dedicated host.
*
* example:
* ecs-autoui-create-ddh-temp
*/
public Builder dedicatedHostName(String dedicatedHostName) {
this.dedicatedHostName = dedicatedHostName;
return this;
}
public DedicatedHostAttribute build() {
return new DedicatedHostAttribute(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class EipAddress extends TeaModel {
@com.aliyun.core.annotation.NameInMap("AllocationId")
private String allocationId;
@com.aliyun.core.annotation.NameInMap("Bandwidth")
private Integer bandwidth;
@com.aliyun.core.annotation.NameInMap("InternetChargeType")
private String internetChargeType;
@com.aliyun.core.annotation.NameInMap("IpAddress")
private String ipAddress;
private EipAddress(Builder builder) {
this.allocationId = builder.allocationId;
this.bandwidth = builder.bandwidth;
this.internetChargeType = builder.internetChargeType;
this.ipAddress = builder.ipAddress;
}
public static Builder builder() {
return new Builder();
}
public static EipAddress create() {
return builder().build();
}
/**
* @return allocationId
*/
public String getAllocationId() {
return this.allocationId;
}
/**
* @return bandwidth
*/
public Integer getBandwidth() {
return this.bandwidth;
}
/**
* @return internetChargeType
*/
public String getInternetChargeType() {
return this.internetChargeType;
}
/**
* @return ipAddress
*/
public String getIpAddress() {
return this.ipAddress;
}
public static final class Builder {
private String allocationId;
private Integer bandwidth;
private String internetChargeType;
private String ipAddress;
/**
* The ID of the EIP.
*
* example:
* eip-wz9uilio26dfscamm****
*/
public Builder allocationId(String allocationId) {
this.allocationId = allocationId;
return this;
}
/**
* The maximum public bandwidth of the EIP. Unit: Mbit/s.
*
* example:
* 8
*/
public Builder bandwidth(Integer bandwidth) {
this.bandwidth = bandwidth;
return this;
}
/**
* The billing method for network usage. Valid values:
*
* - PayByBandwidth
* - PayByTraffic
*
*
* When the pay-by-traffic billing method is used for network usage, the maximum inbound and outbound bandwidths are used as the upper limits of bandwidths instead of guaranteed performance specifications. In scenarios in which demands exceed resource supplies, the maximum bandwidths may not be reached. If you want guaranteed bandwidths for your instance, use the pay-by-bandwidth billing method for network usage.
*
*
* example:
* PayByTraffic
*/
public Builder internetChargeType(String internetChargeType) {
this.internetChargeType = internetChargeType;
return this;
}
/**
* The ID of the elastic IP address (EIP).
*
* example:
* 30.21.**.**
*/
public Builder ipAddress(String ipAddress) {
this.ipAddress = ipAddress;
return this;
}
public EipAddress build() {
return new EipAddress(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class InnerIpAddress extends TeaModel {
@com.aliyun.core.annotation.NameInMap("IpAddress")
private java.util.List ipAddress;
private InnerIpAddress(Builder builder) {
this.ipAddress = builder.ipAddress;
}
public static Builder builder() {
return new Builder();
}
public static InnerIpAddress create() {
return builder().build();
}
/**
* @return ipAddress
*/
public java.util.List getIpAddress() {
return this.ipAddress;
}
public static final class Builder {
private java.util.List ipAddress;
/**
* The ID of the elastic IP address (EIP).
*
* example:
* 30.21.**.**
*/
public Builder ipAddress(java.util.List ipAddress) {
this.ipAddress = ipAddress;
return this;
}
public InnerIpAddress build() {
return new InnerIpAddress(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class LockReason extends TeaModel {
@com.aliyun.core.annotation.NameInMap("LockReason")
private String lockReason;
private LockReason(Builder builder) {
this.lockReason = builder.lockReason;
}
public static Builder builder() {
return new Builder();
}
public static LockReason create() {
return builder().build();
}
/**
* @return lockReason
*/
public String getLockReason() {
return this.lockReason;
}
public static final class Builder {
private String lockReason;
/**
* The reason why the instance was locked. Valid values:
*
* - financial: The instance was locked due to overdue payments.
* - security: The instance was locked due to security reasons.
* - recycling: The preemptible instance was locked and pending release.
* - dedicatedhostfinancial: The instance was locked due to overdue payments for the dedicated host.
* - refunded: The instance was locked because a refund is made for the instance.
*
*
* example:
* financial
*/
public Builder lockReason(String lockReason) {
this.lockReason = lockReason;
return this;
}
public LockReason build() {
return new LockReason(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class OperationLocks extends TeaModel {
@com.aliyun.core.annotation.NameInMap("LockReason")
private java.util.List lockReason;
private OperationLocks(Builder builder) {
this.lockReason = builder.lockReason;
}
public static Builder builder() {
return new Builder();
}
public static OperationLocks create() {
return builder().build();
}
/**
* @return lockReason
*/
public java.util.List getLockReason() {
return this.lockReason;
}
public static final class Builder {
private java.util.List lockReason;
/**
* The reason why the instance was locked. Valid values:
*
* - financial: The instance was locked due to overdue payments.
* - security: The instance was locked due to security reasons.
* - recycling: The preemptible instance was locked and pending release.
* - dedicatedhostfinancial: The instance was locked due to overdue payments for the dedicated host.
* - refunded: The instance was locked because a refund is made for the instance.
*
*
* example:
* financial
*/
public Builder lockReason(java.util.List lockReason) {
this.lockReason = lockReason;
return this;
}
public OperationLocks build() {
return new OperationLocks(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class PublicIpAddress extends TeaModel {
@com.aliyun.core.annotation.NameInMap("IpAddress")
private java.util.List ipAddress;
private PublicIpAddress(Builder builder) {
this.ipAddress = builder.ipAddress;
}
public static Builder builder() {
return new Builder();
}
public static PublicIpAddress create() {
return builder().build();
}
/**
* @return ipAddress
*/
public java.util.List getIpAddress() {
return this.ipAddress;
}
public static final class Builder {
private java.util.List ipAddress;
/**
* The ID of the elastic IP address (EIP).
*
* example:
* 30.21.**.**
*/
public Builder ipAddress(java.util.List ipAddress) {
this.ipAddress = ipAddress;
return this;
}
public PublicIpAddress build() {
return new PublicIpAddress(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class SecurityGroupIds extends TeaModel {
@com.aliyun.core.annotation.NameInMap("SecurityGroupId")
private java.util.List securityGroupId;
private SecurityGroupIds(Builder builder) {
this.securityGroupId = builder.securityGroupId;
}
public static Builder builder() {
return new Builder();
}
public static SecurityGroupIds create() {
return builder().build();
}
/**
* @return securityGroupId
*/
public java.util.List getSecurityGroupId() {
return this.securityGroupId;
}
public static final class Builder {
private java.util.List securityGroupId;
/**
* SecurityGroupId.
*/
public Builder securityGroupId(java.util.List securityGroupId) {
this.securityGroupId = securityGroupId;
return this;
}
public SecurityGroupIds build() {
return new SecurityGroupIds(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class PrivateIpAddress extends TeaModel {
@com.aliyun.core.annotation.NameInMap("IpAddress")
private java.util.List ipAddress;
private PrivateIpAddress(Builder builder) {
this.ipAddress = builder.ipAddress;
}
public static Builder builder() {
return new Builder();
}
public static PrivateIpAddress create() {
return builder().build();
}
/**
* @return ipAddress
*/
public java.util.List getIpAddress() {
return this.ipAddress;
}
public static final class Builder {
private java.util.List ipAddress;
/**
* The ID of the elastic IP address (EIP).
*
* example:
* 30.21.**.**
*/
public Builder ipAddress(java.util.List ipAddress) {
this.ipAddress = ipAddress;
return this;
}
public PrivateIpAddress build() {
return new PrivateIpAddress(this);
}
}
}
/**
*
* {@link DescribeInstanceAttributeResponseBody} extends {@link TeaModel}
*
* DescribeInstanceAttributeResponseBody
*/
public static class VpcAttributes extends TeaModel {
@com.aliyun.core.annotation.NameInMap("NatIpAddress")
private String natIpAddress;
@com.aliyun.core.annotation.NameInMap("PrivateIpAddress")
private PrivateIpAddress privateIpAddress;
@com.aliyun.core.annotation.NameInMap("VSwitchId")
private String vSwitchId;
@com.aliyun.core.annotation.NameInMap("VpcId")
private String vpcId;
private VpcAttributes(Builder builder) {
this.natIpAddress = builder.natIpAddress;
this.privateIpAddress = builder.privateIpAddress;
this.vSwitchId = builder.vSwitchId;
this.vpcId = builder.vpcId;
}
public static Builder builder() {
return new Builder();
}
public static VpcAttributes create() {
return builder().build();
}
/**
* @return natIpAddress
*/
public String getNatIpAddress() {
return this.natIpAddress;
}
/**
* @return privateIpAddress
*/
public PrivateIpAddress getPrivateIpAddress() {
return this.privateIpAddress;
}
/**
* @return vSwitchId
*/
public String getVSwitchId() {
return this.vSwitchId;
}
/**
* @return vpcId
*/
public String getVpcId() {
return this.vpcId;
}
public static final class Builder {
private String natIpAddress;
private PrivateIpAddress privateIpAddress;
private String vSwitchId;
private String vpcId;
/**
* The NAT IP address of the instance. It is used by ECS instances in different VPCs for communication.
*
* example:
* 172.17.**.**
*/
public Builder natIpAddress(String natIpAddress) {
this.natIpAddress = natIpAddress;
return this;
}
/**
* The private IP address of the instance.
*/
public Builder privateIpAddress(PrivateIpAddress privateIpAddress) {
this.privateIpAddress = privateIpAddress;
return this;
}
/**
* The ID of the vSwitch to which the instance is connected.
*
* example:
* vsw-uf6ixacqz8osrwnqb****
*/
public Builder vSwitchId(String vSwitchId) {
this.vSwitchId = vSwitchId;
return this;
}
/**
* The ID of the VPC.
*
* example:
* vpc-wz9e4e9pmbcnj6ki6****
*/
public Builder vpcId(String vpcId) {
this.vpcId = vpcId;
return this;
}
public VpcAttributes build() {
return new VpcAttributes(this);
}
}
}
}