All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.fabric8.openshift.api.model.TLSConfigBuilder Maven / Gradle / Ivy

The newest version!
package io.fabric8.openshift.api.model;

import io.fabric8.kubernetes.api.builder.VisitableBuilder;
import java.lang.Boolean;
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.ValidatorFactory;
import javax.validation.ValidationException;
import javax.validation.ConstraintViolation;
import javax.validation.ConstraintViolationException;
import java.util.Set;
import java.lang.Object;

public class TLSConfigBuilder extends TLSConfigFluentImpl implements VisitableBuilder{

    TLSConfigFluent fluent;
    Boolean validationEnabled;

    public TLSConfigBuilder(){
            this(true);
    }
    public TLSConfigBuilder(Boolean validationEnabled){
            this(new TLSConfig(), validationEnabled);
    }
    public TLSConfigBuilder(TLSConfigFluent fluent){
            this(fluent, true);
    }
    public TLSConfigBuilder(TLSConfigFluent fluent,Boolean validationEnabled){
            this(fluent, new TLSConfig(), validationEnabled);
    }
    public TLSConfigBuilder(TLSConfigFluent fluent,TLSConfig instance){
            this(fluent, instance, true);
    }
    public TLSConfigBuilder(TLSConfigFluent fluent,TLSConfig instance,Boolean validationEnabled){
            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()); 
            this.validationEnabled = validationEnabled; 
    }
    public TLSConfigBuilder(TLSConfig instance){
            this(instance,true);
    }
    public TLSConfigBuilder(TLSConfig instance,Boolean validationEnabled){
            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()); 
            this.validationEnabled = validationEnabled; 
    }

    public TLSConfig build(){
            TLSConfig buildable = new TLSConfig(fluent.getCaCertificate(),fluent.getCertificate(),fluent.getDestinationCACertificate(),fluent.getInsecureEdgeTerminationPolicy(),fluent.getKey(),fluent.getTermination());
            validate(buildable);
            return buildable;
    }

    private void validate(T item){
            if (!validationEnabled) { return; }
            Validator validator = null;
            try {
                ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
                validator = factory.getValidator();
            } catch(ValidationException e) {return;}
            Set> violations = validator.validate(item);
            if (!violations.isEmpty()) {
            throw new ConstraintViolationException(violations);
             }
    }

    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;

            if (validationEnabled != null ? !validationEnabled.equals(that.validationEnabled) :that.validationEnabled != null) return false;
            return true;
    }




}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy