io.fabric8.openshift.api.model.TLSConfigBuilder Maven / Gradle / Ivy
package io.fabric8.openshift.api.model;
import javax.validation.ConstraintViolation;
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.ValidatorFactory;
import javax.validation.ValidationException;
import java.util.Set;
import java.util.HashMap;
import java.io.Serializable;
import java.util.Map;
import java.util.Map;
import java.util.AbstractMap;
import io.fabric8.kubernetes.api.builder.Visitable;
import io.fabric8.kubernetes.api.builder.Builder;
import io.fabric8.kubernetes.api.builder.Fluent;
import io.fabric8.kubernetes.api.builder.VisitableBuilder;
import io.fabric8.kubernetes.api.builder.Visitable;
import io.fabric8.kubernetes.api.builder.BaseFluent;
public class TLSConfigBuilder extends TLSConfigFluentImpl implements VisitableBuilder{
TLSConfigFluent> fluent;
public TLSConfigBuilder(){
this(new TLSConfig());
}
public TLSConfigBuilder( TLSConfigFluent> fluent ){
this(fluent, new TLSConfig());
}
public TLSConfigBuilder( TLSConfigFluent> fluent , TLSConfig instance ){
this.fluent = fluent; fluent.withCaCertificate(instance.getCaCertificate()); fluent.withCertificate(instance.getCertificate()); fluent.withDestinationCACertificate(instance.getDestinationCACertificate()); fluent.withInsecureEdgeTerminationPolicy(instance.getInsecureEdgeTerminationPolicy()); fluent.withKey(instance.getKey()); fluent.withTermination(instance.getTermination());
}
public TLSConfigBuilder( TLSConfig instance ){
this.fluent = this; this.withCaCertificate(instance.getCaCertificate()); this.withCertificate(instance.getCertificate()); this.withDestinationCACertificate(instance.getDestinationCACertificate()); this.withInsecureEdgeTerminationPolicy(instance.getInsecureEdgeTerminationPolicy()); this.withKey(instance.getKey()); this.withTermination(instance.getTermination());
}
public EditableTLSConfig build(){
EditableTLSConfig buildable = new EditableTLSConfig(fluent.getCaCertificate(),fluent.getCertificate(),fluent.getDestinationCACertificate(),fluent.getInsecureEdgeTerminationPolicy(),fluent.getKey(),fluent.getTermination());
validate(buildable);
return buildable;
}
public boolean equals( Object o ){
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
if (!super.equals(o)) return false;
TLSConfigBuilder that = (TLSConfigBuilder) o;
if (fluent != null &&fluent != this ? !fluent.equals(that.fluent) :that.fluent != null &&fluent != this ) return false;
return true;
}
private void validate(T item) {
try {
ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
Validator validator = factory.getValidator();
Set> violations = validator.validate(item);
if (!violations.isEmpty()) {
StringBuilder sb = new StringBuilder();
sb.append("Constraint Violations:\n");
for (ConstraintViolation violation : violations) {
sb.append("\t").append(violation.getRootBeanClass().getSimpleName()).append(" ").append(violation.getPropertyPath()).append(":").append(violation.getMessage()).append("\n");
}
throw new IllegalStateException(sb.toString());
}
} catch(ValidationException e) {
//ignore
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy