com.pulumi.kubernetes.extensions.v1beta1.outputs.DaemonSetSpec Maven / Gradle / Ivy
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.kubernetes.extensions.v1beta1.outputs;
import com.pulumi.core.annotations.CustomType;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import com.pulumi.kubernetes.core.v1.outputs.PodTemplateSpec;
import com.pulumi.kubernetes.extensions.v1beta1.outputs.DaemonSetUpdateStrategy;
import com.pulumi.kubernetes.meta.v1.outputs.LabelSelector;
import java.lang.Integer;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;
@CustomType
public final class DaemonSetSpec {
/**
* @return The minimum number of seconds for which a newly created DaemonSet pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready).
*
*/
private @Nullable Integer minReadySeconds;
/**
* @return The number of old history to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 10.
*
*/
private @Nullable Integer revisionHistoryLimit;
/**
* @return A label query over pods that are managed by the daemon set. Must match in order to be controlled. If empty, defaulted to labels on Pod template. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors
*
*/
private @Nullable LabelSelector selector;
/**
* @return An object that describes the pod that will be created. The DaemonSet will create exactly one copy of this pod on every node that matches the template's node selector (or on every node if no node selector is specified). More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template
*
*/
private PodTemplateSpec template;
/**
* @return DEPRECATED. A sequence number representing a specific generation of the template. Populated by the system. It can be set only during the creation.
*
*/
private @Nullable Integer templateGeneration;
/**
* @return An update strategy to replace existing DaemonSet pods with new pods.
*
*/
private @Nullable DaemonSetUpdateStrategy updateStrategy;
private DaemonSetSpec() {}
/**
* @return The minimum number of seconds for which a newly created DaemonSet pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready).
*
*/
public Optional minReadySeconds() {
return Optional.ofNullable(this.minReadySeconds);
}
/**
* @return The number of old history to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 10.
*
*/
public Optional revisionHistoryLimit() {
return Optional.ofNullable(this.revisionHistoryLimit);
}
/**
* @return A label query over pods that are managed by the daemon set. Must match in order to be controlled. If empty, defaulted to labels on Pod template. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors
*
*/
public Optional selector() {
return Optional.ofNullable(this.selector);
}
/**
* @return An object that describes the pod that will be created. The DaemonSet will create exactly one copy of this pod on every node that matches the template's node selector (or on every node if no node selector is specified). More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template
*
*/
public PodTemplateSpec template() {
return this.template;
}
/**
* @return DEPRECATED. A sequence number representing a specific generation of the template. Populated by the system. It can be set only during the creation.
*
*/
public Optional templateGeneration() {
return Optional.ofNullable(this.templateGeneration);
}
/**
* @return An update strategy to replace existing DaemonSet pods with new pods.
*
*/
public Optional updateStrategy() {
return Optional.ofNullable(this.updateStrategy);
}
public static Builder builder() {
return new Builder();
}
public static Builder builder(DaemonSetSpec defaults) {
return new Builder(defaults);
}
@CustomType.Builder
public static final class Builder {
private @Nullable Integer minReadySeconds;
private @Nullable Integer revisionHistoryLimit;
private @Nullable LabelSelector selector;
private PodTemplateSpec template;
private @Nullable Integer templateGeneration;
private @Nullable DaemonSetUpdateStrategy updateStrategy;
public Builder() {}
public Builder(DaemonSetSpec defaults) {
Objects.requireNonNull(defaults);
this.minReadySeconds = defaults.minReadySeconds;
this.revisionHistoryLimit = defaults.revisionHistoryLimit;
this.selector = defaults.selector;
this.template = defaults.template;
this.templateGeneration = defaults.templateGeneration;
this.updateStrategy = defaults.updateStrategy;
}
@CustomType.Setter
public Builder minReadySeconds(@Nullable Integer minReadySeconds) {
this.minReadySeconds = minReadySeconds;
return this;
}
@CustomType.Setter
public Builder revisionHistoryLimit(@Nullable Integer revisionHistoryLimit) {
this.revisionHistoryLimit = revisionHistoryLimit;
return this;
}
@CustomType.Setter
public Builder selector(@Nullable LabelSelector selector) {
this.selector = selector;
return this;
}
@CustomType.Setter
public Builder template(PodTemplateSpec template) {
if (template == null) {
throw new MissingRequiredPropertyException("DaemonSetSpec", "template");
}
this.template = template;
return this;
}
@CustomType.Setter
public Builder templateGeneration(@Nullable Integer templateGeneration) {
this.templateGeneration = templateGeneration;
return this;
}
@CustomType.Setter
public Builder updateStrategy(@Nullable DaemonSetUpdateStrategy updateStrategy) {
this.updateStrategy = updateStrategy;
return this;
}
public DaemonSetSpec build() {
final var _resultValue = new DaemonSetSpec();
_resultValue.minReadySeconds = minReadySeconds;
_resultValue.revisionHistoryLimit = revisionHistoryLimit;
_resultValue.selector = selector;
_resultValue.template = template;
_resultValue.templateGeneration = templateGeneration;
_resultValue.updateStrategy = updateStrategy;
return _resultValue;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy