/* * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with * the License. A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions * and limitations under the License. */ package com.amazonaws.services.ec2.model; import java.io.Serializable; import javax.annotation.Generated; /** *
* Describes the properties of a Dedicated Host. *
* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class HostProperties implements Serializable, Cloneable { /** ** The number of cores on the Dedicated Host. *
*/ private Integer cores; /** *
* The instance type supported by the Dedicated Host. For example, m5.large
. If the host supports
* multiple instance types, no instanceType is returned.
*
* The instance family supported by the Dedicated Host. For example, m5
.
*
* The number of sockets on the Dedicated Host. *
*/ private Integer sockets; /** ** The total number of vCPUs on the Dedicated Host. *
*/ private Integer totalVCpus; /** ** The number of cores on the Dedicated Host. *
* * @param cores * The number of cores on the Dedicated Host. */ public void setCores(Integer cores) { this.cores = cores; } /** ** The number of cores on the Dedicated Host. *
* * @return The number of cores on the Dedicated Host. */ public Integer getCores() { return this.cores; } /** ** The number of cores on the Dedicated Host. *
* * @param cores * The number of cores on the Dedicated Host. * @return Returns a reference to this object so that method calls can be chained together. */ public HostProperties withCores(Integer cores) { setCores(cores); return this; } /** *
* The instance type supported by the Dedicated Host. For example, m5.large
. If the host supports
* multiple instance types, no instanceType is returned.
*
m5.large
. If the host
* supports multiple instance types, no instanceType is returned.
*/
public void setInstanceType(String instanceType) {
this.instanceType = instanceType;
}
/**
*
* The instance type supported by the Dedicated Host. For example, m5.large
. If the host supports
* multiple instance types, no instanceType is returned.
*
m5.large
. If the host
* supports multiple instance types, no instanceType is returned.
*/
public String getInstanceType() {
return this.instanceType;
}
/**
*
* The instance type supported by the Dedicated Host. For example, m5.large
. If the host supports
* multiple instance types, no instanceType is returned.
*
m5.large
. If the host
* supports multiple instance types, no instanceType is returned.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public HostProperties withInstanceType(String instanceType) {
setInstanceType(instanceType);
return this;
}
/**
*
* The instance family supported by the Dedicated Host. For example, m5
.
*
m5
.
*/
public void setInstanceFamily(String instanceFamily) {
this.instanceFamily = instanceFamily;
}
/**
*
* The instance family supported by the Dedicated Host. For example, m5
.
*
m5
.
*/
public String getInstanceFamily() {
return this.instanceFamily;
}
/**
*
* The instance family supported by the Dedicated Host. For example, m5
.
*
m5
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public HostProperties withInstanceFamily(String instanceFamily) {
setInstanceFamily(instanceFamily);
return this;
}
/**
* * The number of sockets on the Dedicated Host. *
* * @param sockets * The number of sockets on the Dedicated Host. */ public void setSockets(Integer sockets) { this.sockets = sockets; } /** ** The number of sockets on the Dedicated Host. *
* * @return The number of sockets on the Dedicated Host. */ public Integer getSockets() { return this.sockets; } /** ** The number of sockets on the Dedicated Host. *
* * @param sockets * The number of sockets on the Dedicated Host. * @return Returns a reference to this object so that method calls can be chained together. */ public HostProperties withSockets(Integer sockets) { setSockets(sockets); return this; } /** ** The total number of vCPUs on the Dedicated Host. *
* * @param totalVCpus * The total number of vCPUs on the Dedicated Host. */ public void setTotalVCpus(Integer totalVCpus) { this.totalVCpus = totalVCpus; } /** ** The total number of vCPUs on the Dedicated Host. *
* * @return The total number of vCPUs on the Dedicated Host. */ public Integer getTotalVCpus() { return this.totalVCpus; } /** ** The total number of vCPUs on the Dedicated Host. *
* * @param totalVCpus * The total number of vCPUs on the Dedicated Host. * @return Returns a reference to this object so that method calls can be chained together. */ public HostProperties withTotalVCpus(Integer totalVCpus) { setTotalVCpus(totalVCpus); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getCores() != null) sb.append("Cores: ").append(getCores()).append(","); if (getInstanceType() != null) sb.append("InstanceType: ").append(getInstanceType()).append(","); if (getInstanceFamily() != null) sb.append("InstanceFamily: ").append(getInstanceFamily()).append(","); if (getSockets() != null) sb.append("Sockets: ").append(getSockets()).append(","); if (getTotalVCpus() != null) sb.append("TotalVCpus: ").append(getTotalVCpus()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof HostProperties == false) return false; HostProperties other = (HostProperties) obj; if (other.getCores() == null ^ this.getCores() == null) return false; if (other.getCores() != null && other.getCores().equals(this.getCores()) == false) return false; if (other.getInstanceType() == null ^ this.getInstanceType() == null) return false; if (other.getInstanceType() != null && other.getInstanceType().equals(this.getInstanceType()) == false) return false; if (other.getInstanceFamily() == null ^ this.getInstanceFamily() == null) return false; if (other.getInstanceFamily() != null && other.getInstanceFamily().equals(this.getInstanceFamily()) == false) return false; if (other.getSockets() == null ^ this.getSockets() == null) return false; if (other.getSockets() != null && other.getSockets().equals(this.getSockets()) == false) return false; if (other.getTotalVCpus() == null ^ this.getTotalVCpus() == null) return false; if (other.getTotalVCpus() != null && other.getTotalVCpus().equals(this.getTotalVCpus()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getCores() == null) ? 0 : getCores().hashCode()); hashCode = prime * hashCode + ((getInstanceType() == null) ? 0 : getInstanceType().hashCode()); hashCode = prime * hashCode + ((getInstanceFamily() == null) ? 0 : getInstanceFamily().hashCode()); hashCode = prime * hashCode + ((getSockets() == null) ? 0 : getSockets().hashCode()); hashCode = prime * hashCode + ((getTotalVCpus() == null) ? 0 : getTotalVCpus().hashCode()); return hashCode; } @Override public HostProperties clone() { try { return (HostProperties) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } }