io.fabric8.knative.eventing.contrib.kafka.v1beta1.KafkaChannelSpec Maven / Gradle / Ivy
package io.fabric8.knative.eventing.contrib.kafka.v1beta1;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.fasterxml.jackson.annotation.JsonAnyGetter;
import com.fasterxml.jackson.annotation.JsonAnySetter;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import io.fabric8.knative.internal.eventing.pkg.apis.duck.v1.DeliverySpec;
import io.fabric8.knative.internal.eventing.pkg.apis.duck.v1.SubscriberSpec;
import io.fabric8.kubernetes.api.model.Container;
import io.fabric8.kubernetes.api.model.ContainerPort;
import io.fabric8.kubernetes.api.model.EnvVar;
import io.fabric8.kubernetes.api.model.IntOrString;
import io.fabric8.kubernetes.api.model.KubernetesResource;
import io.fabric8.kubernetes.api.model.LabelSelector;
import io.fabric8.kubernetes.api.model.LocalObjectReference;
import io.fabric8.kubernetes.api.model.ObjectMeta;
import io.fabric8.kubernetes.api.model.ObjectReference;
import io.fabric8.kubernetes.api.model.PersistentVolumeClaim;
import io.fabric8.kubernetes.api.model.PodTemplateSpec;
import io.fabric8.kubernetes.api.model.ResourceRequirements;
import io.fabric8.kubernetes.api.model.Volume;
import io.fabric8.kubernetes.api.model.VolumeMount;
import io.sundr.builder.annotations.Buildable;
import io.sundr.builder.annotations.BuildableReference;
import lombok.EqualsAndHashCode;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
@JsonDeserialize(using = com.fasterxml.jackson.databind.JsonDeserializer.None.class)
@JsonInclude(JsonInclude.Include.NON_NULL)
@JsonPropertyOrder({
"apiVersion",
"kind",
"metadata",
"delivery",
"numPartitions",
"replicationFactor",
"retentionDuration",
"subscribers"
})
@ToString
@EqualsAndHashCode
@Setter
@Accessors(prefix = {
"_",
""
})
@Buildable(editableEnabled = false, validationEnabled = false, generateBuilderPackage = false, lazyCollectionInitEnabled = false, builderPackage = "io.fabric8.kubernetes.api.builder", refs = {
@BuildableReference(ObjectMeta.class),
@BuildableReference(LabelSelector.class),
@BuildableReference(Container.class),
@BuildableReference(PodTemplateSpec.class),
@BuildableReference(ResourceRequirements.class),
@BuildableReference(IntOrString.class),
@BuildableReference(ObjectReference.class),
@BuildableReference(LocalObjectReference.class),
@BuildableReference(PersistentVolumeClaim.class),
@BuildableReference(EnvVar.class),
@BuildableReference(ContainerPort.class),
@BuildableReference(Volume.class),
@BuildableReference(VolumeMount.class)
})
public class KafkaChannelSpec implements KubernetesResource
{
@JsonProperty("delivery")
private DeliverySpec delivery;
@JsonProperty("numPartitions")
private Integer numPartitions;
@JsonProperty("replicationFactor")
private Integer replicationFactor;
@JsonProperty("retentionDuration")
private String retentionDuration;
@JsonProperty("subscribers")
@JsonInclude(JsonInclude.Include.NON_EMPTY)
private List subscribers = new ArrayList();
@JsonIgnore
private Map additionalProperties = new HashMap();
/**
* No args constructor for use in serialization
*
*/
public KafkaChannelSpec() {
}
/**
*
* @param delivery
* @param replicationFactor
* @param subscribers
* @param numPartitions
* @param retentionDuration
*/
public KafkaChannelSpec(DeliverySpec delivery, Integer numPartitions, Integer replicationFactor, String retentionDuration, List subscribers) {
super();
this.delivery = delivery;
this.numPartitions = numPartitions;
this.replicationFactor = replicationFactor;
this.retentionDuration = retentionDuration;
this.subscribers = subscribers;
}
@JsonProperty("delivery")
public DeliverySpec getDelivery() {
return delivery;
}
@JsonProperty("delivery")
public void setDelivery(DeliverySpec delivery) {
this.delivery = delivery;
}
@JsonProperty("numPartitions")
public Integer getNumPartitions() {
return numPartitions;
}
@JsonProperty("numPartitions")
public void setNumPartitions(Integer numPartitions) {
this.numPartitions = numPartitions;
}
@JsonProperty("replicationFactor")
public Integer getReplicationFactor() {
return replicationFactor;
}
@JsonProperty("replicationFactor")
public void setReplicationFactor(Integer replicationFactor) {
this.replicationFactor = replicationFactor;
}
@JsonProperty("retentionDuration")
public String getRetentionDuration() {
return retentionDuration;
}
@JsonProperty("retentionDuration")
public void setRetentionDuration(String retentionDuration) {
this.retentionDuration = retentionDuration;
}
@JsonProperty("subscribers")
public List getSubscribers() {
return subscribers;
}
@JsonProperty("subscribers")
public void setSubscribers(List subscribers) {
this.subscribers = subscribers;
}
@JsonAnyGetter
public Map getAdditionalProperties() {
return this.additionalProperties;
}
@JsonAnySetter
public void setAdditionalProperty(String name, Object value) {
this.additionalProperties.put(name, value);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy