com.spotinst.sdkjava.model.bl.ocean.ecs.ClusterStrategyConfiguration Maven / Gradle / Ivy
package com.spotinst.sdkjava.model.bl.ocean.ecs;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import java.util.HashSet;
import java.util.Set;
@JsonIgnoreProperties(ignoreUnknown = true)
@JsonInclude(JsonInclude.Include.NON_NULL)
public class ClusterStrategyConfiguration {
@JsonIgnore
private Set isSet;
private Boolean fallbackToOd;
private Boolean utilizeReservedInstances;
private Integer drainingTimeout;
private Integer spotPercentage;
private ClusterStrategyConfiguration() {
isSet = new HashSet<>();
}
public Set getIsSet() {
return isSet;
}
public void setIsSet(Set isSet) {
this.isSet = isSet;
}
public Integer getDrainingTimeout() {
return drainingTimeout;
}
public void setDrainingTimeout(Integer drainingTimeout) {
isSet.add("drainingTimeout");
this.drainingTimeout = drainingTimeout;
}
public Boolean getUtilizeReservedInstances() {
return utilizeReservedInstances;
}
public void setUtilizeReservedInstances(Boolean utilizeReservedInstances) {
isSet.add("utilizeReservedInstances");
this.utilizeReservedInstances = utilizeReservedInstances;
}
public Boolean getFallbackToOd() {
return fallbackToOd;
}
public void setFallbackToOd(Boolean fallbackToOd) {
isSet.add("fallbackToOd");
this.fallbackToOd = fallbackToOd;
}
public Integer getspotPercentage() {
return spotPercentage;
}
public void setspotPercentage(Integer spotPercentage) {
isSet.add("spotPercentage");
this.spotPercentage = spotPercentage;
}
public static class Builder {
private ClusterStrategyConfiguration strategy;
private Builder() {
this.strategy = new ClusterStrategyConfiguration();
}
public static Builder get() {
return new Builder();
}
public Builder setFallbackToOnDemand(final Boolean fallbackToOnDemand) {
strategy.setFallbackToOd(fallbackToOnDemand);
return this;
}
public Builder setUtilizeReservedInstances(final Boolean utilizeReservedInstances) {
strategy.setUtilizeReservedInstances(utilizeReservedInstances);
return this;
}
public Builder setDrainingTimeout(final Integer drainingTimeout) {
strategy.setDrainingTimeout(drainingTimeout);
return this;
}
public Builder setspotPercentage(final Integer spotPercentage) {
strategy.setspotPercentage(spotPercentage);
return this;
}
public ClusterStrategyConfiguration build() {
return strategy;
}
}
@JsonIgnore
public boolean isFallbackToOdSet() {
return isSet.contains("fallbackToOd");
}
@JsonIgnore
public boolean isDrainingTimeoutSet() {
return isSet.contains("drainingTimeout");
}
@JsonIgnore
public boolean isUtilizeReservedInstancesSet() {
return isSet.contains("utilizeReservedInstances");
}
@JsonIgnore
public boolean isspotPercentageSet() {
return isSet.contains("spotPercentage");
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy