com.pulumi.kubernetes.apps.v1.outputs.DaemonSetSpec Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kubernetes Show documentation
Show all versions of kubernetes Show documentation
A Pulumi package for creating and managing Kubernetes resources.
// *** 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.apps.v1.outputs;
import com.pulumi.core.annotations.CustomType;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import com.pulumi.kubernetes.apps.v1.outputs.DaemonSetUpdateStrategy;
import com.pulumi.kubernetes.core.v1.outputs.PodTemplateSpec;
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. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors
*
*/
private 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). The only allowed template.spec.restartPolicy value is "Always". More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template
*
*/
private PodTemplateSpec template;
/**
* @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. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors
*
*/
public LabelSelector selector() {
return 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). The only allowed template.spec.restartPolicy value is "Always". More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template
*
*/
public PodTemplateSpec template() {
return this.template;
}
/**
* @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 LabelSelector selector;
private PodTemplateSpec template;
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.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(LabelSelector selector) {
if (selector == null) {
throw new MissingRequiredPropertyException("DaemonSetSpec", "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 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.updateStrategy = updateStrategy;
return _resultValue;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy