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

com.pulumi.azure.containerapp.inputs.JobTemplateContainerLivenessProbeArgs 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.azure.containerapp.inputs;

import com.pulumi.azure.containerapp.inputs.JobTemplateContainerLivenessProbeHeaderArgs;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import java.lang.Integer;
import java.lang.String;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;


public final class JobTemplateContainerLivenessProbeArgs extends com.pulumi.resources.ResourceArgs {

    public static final JobTemplateContainerLivenessProbeArgs Empty = new JobTemplateContainerLivenessProbeArgs();

    /**
     * The number of consecutive failures required to consider this probe as failed. Possible values are between `1` and `10`. Defaults to `3`.
     * 
     */
    @Import(name="failureCountThreshold")
    private @Nullable Output failureCountThreshold;

    /**
     * @return The number of consecutive failures required to consider this probe as failed. Possible values are between `1` and `10`. Defaults to `3`.
     * 
     */
    public Optional> failureCountThreshold() {
        return Optional.ofNullable(this.failureCountThreshold);
    }

    /**
     * A `header` block as detailed below.
     * 
     */
    @Import(name="headers")
    private @Nullable Output> headers;

    /**
     * @return A `header` block as detailed below.
     * 
     */
    public Optional>> headers() {
        return Optional.ofNullable(this.headers);
    }

    /**
     * The probe hostname. Defaults to the pod IP address. Setting a value for `Host` in `headers` can be used to override this for `HTTP` and `HTTPS` type probes.
     * 
     */
    @Import(name="host")
    private @Nullable Output host;

    /**
     * @return The probe hostname. Defaults to the pod IP address. Setting a value for `Host` in `headers` can be used to override this for `HTTP` and `HTTPS` type probes.
     * 
     */
    public Optional> host() {
        return Optional.ofNullable(this.host);
    }

    /**
     * The time in seconds to wait after the container has started before the probe is started.
     * 
     */
    @Import(name="initialDelay")
    private @Nullable Output initialDelay;

    /**
     * @return The time in seconds to wait after the container has started before the probe is started.
     * 
     */
    public Optional> initialDelay() {
        return Optional.ofNullable(this.initialDelay);
    }

    /**
     * How often, in seconds, the probe should run. Possible values are in the range `1` - `240`. Defaults to `10`.
     * 
     */
    @Import(name="intervalSeconds")
    private @Nullable Output intervalSeconds;

    /**
     * @return How often, in seconds, the probe should run. Possible values are in the range `1` - `240`. Defaults to `10`.
     * 
     */
    public Optional> intervalSeconds() {
        return Optional.ofNullable(this.intervalSeconds);
    }

    /**
     * The URI to use with the `host` for http type probes. Not valid for `TCP` type probes. Defaults to `/`.
     * 
     */
    @Import(name="path")
    private @Nullable Output path;

    /**
     * @return The URI to use with the `host` for http type probes. Not valid for `TCP` type probes. Defaults to `/`.
     * 
     */
    public Optional> path() {
        return Optional.ofNullable(this.path);
    }

    /**
     * The port number on which to connect. Possible values are between `1` and `65535`.
     * 
     */
    @Import(name="port", required=true)
    private Output port;

    /**
     * @return The port number on which to connect. Possible values are between `1` and `65535`.
     * 
     */
    public Output port() {
        return this.port;
    }

    /**
     * The time in seconds after the container is sent the termination signal before the process if forcibly killed.
     * 
     */
    @Import(name="terminationGracePeriodSeconds")
    private @Nullable Output terminationGracePeriodSeconds;

    /**
     * @return The time in seconds after the container is sent the termination signal before the process if forcibly killed.
     * 
     */
    public Optional> terminationGracePeriodSeconds() {
        return Optional.ofNullable(this.terminationGracePeriodSeconds);
    }

    /**
     * Time in seconds after which the probe times out. Possible values are in the range `1` - `240`. Defaults to `1`.
     * 
     */
    @Import(name="timeout")
    private @Nullable Output timeout;

    /**
     * @return Time in seconds after which the probe times out. Possible values are in the range `1` - `240`. Defaults to `1`.
     * 
     */
    public Optional> timeout() {
        return Optional.ofNullable(this.timeout);
    }

    /**
     * Type of probe. Possible values are `TCP`, `HTTP`, and `HTTPS`.
     * 
     */
    @Import(name="transport", required=true)
    private Output transport;

    /**
     * @return Type of probe. Possible values are `TCP`, `HTTP`, and `HTTPS`.
     * 
     */
    public Output transport() {
        return this.transport;
    }

    private JobTemplateContainerLivenessProbeArgs() {}

    private JobTemplateContainerLivenessProbeArgs(JobTemplateContainerLivenessProbeArgs $) {
        this.failureCountThreshold = $.failureCountThreshold;
        this.headers = $.headers;
        this.host = $.host;
        this.initialDelay = $.initialDelay;
        this.intervalSeconds = $.intervalSeconds;
        this.path = $.path;
        this.port = $.port;
        this.terminationGracePeriodSeconds = $.terminationGracePeriodSeconds;
        this.timeout = $.timeout;
        this.transport = $.transport;
    }

    public static Builder builder() {
        return new Builder();
    }
    public static Builder builder(JobTemplateContainerLivenessProbeArgs defaults) {
        return new Builder(defaults);
    }

    public static final class Builder {
        private JobTemplateContainerLivenessProbeArgs $;

        public Builder() {
            $ = new JobTemplateContainerLivenessProbeArgs();
        }

        public Builder(JobTemplateContainerLivenessProbeArgs defaults) {
            $ = new JobTemplateContainerLivenessProbeArgs(Objects.requireNonNull(defaults));
        }

        /**
         * @param failureCountThreshold The number of consecutive failures required to consider this probe as failed. Possible values are between `1` and `10`. Defaults to `3`.
         * 
         * @return builder
         * 
         */
        public Builder failureCountThreshold(@Nullable Output failureCountThreshold) {
            $.failureCountThreshold = failureCountThreshold;
            return this;
        }

        /**
         * @param failureCountThreshold The number of consecutive failures required to consider this probe as failed. Possible values are between `1` and `10`. Defaults to `3`.
         * 
         * @return builder
         * 
         */
        public Builder failureCountThreshold(Integer failureCountThreshold) {
            return failureCountThreshold(Output.of(failureCountThreshold));
        }

        /**
         * @param headers A `header` block as detailed below.
         * 
         * @return builder
         * 
         */
        public Builder headers(@Nullable Output> headers) {
            $.headers = headers;
            return this;
        }

        /**
         * @param headers A `header` block as detailed below.
         * 
         * @return builder
         * 
         */
        public Builder headers(List headers) {
            return headers(Output.of(headers));
        }

        /**
         * @param headers A `header` block as detailed below.
         * 
         * @return builder
         * 
         */
        public Builder headers(JobTemplateContainerLivenessProbeHeaderArgs... headers) {
            return headers(List.of(headers));
        }

        /**
         * @param host The probe hostname. Defaults to the pod IP address. Setting a value for `Host` in `headers` can be used to override this for `HTTP` and `HTTPS` type probes.
         * 
         * @return builder
         * 
         */
        public Builder host(@Nullable Output host) {
            $.host = host;
            return this;
        }

        /**
         * @param host The probe hostname. Defaults to the pod IP address. Setting a value for `Host` in `headers` can be used to override this for `HTTP` and `HTTPS` type probes.
         * 
         * @return builder
         * 
         */
        public Builder host(String host) {
            return host(Output.of(host));
        }

        /**
         * @param initialDelay The time in seconds to wait after the container has started before the probe is started.
         * 
         * @return builder
         * 
         */
        public Builder initialDelay(@Nullable Output initialDelay) {
            $.initialDelay = initialDelay;
            return this;
        }

        /**
         * @param initialDelay The time in seconds to wait after the container has started before the probe is started.
         * 
         * @return builder
         * 
         */
        public Builder initialDelay(Integer initialDelay) {
            return initialDelay(Output.of(initialDelay));
        }

        /**
         * @param intervalSeconds How often, in seconds, the probe should run. Possible values are in the range `1` - `240`. Defaults to `10`.
         * 
         * @return builder
         * 
         */
        public Builder intervalSeconds(@Nullable Output intervalSeconds) {
            $.intervalSeconds = intervalSeconds;
            return this;
        }

        /**
         * @param intervalSeconds How often, in seconds, the probe should run. Possible values are in the range `1` - `240`. Defaults to `10`.
         * 
         * @return builder
         * 
         */
        public Builder intervalSeconds(Integer intervalSeconds) {
            return intervalSeconds(Output.of(intervalSeconds));
        }

        /**
         * @param path The URI to use with the `host` for http type probes. Not valid for `TCP` type probes. Defaults to `/`.
         * 
         * @return builder
         * 
         */
        public Builder path(@Nullable Output path) {
            $.path = path;
            return this;
        }

        /**
         * @param path The URI to use with the `host` for http type probes. Not valid for `TCP` type probes. Defaults to `/`.
         * 
         * @return builder
         * 
         */
        public Builder path(String path) {
            return path(Output.of(path));
        }

        /**
         * @param port The port number on which to connect. Possible values are between `1` and `65535`.
         * 
         * @return builder
         * 
         */
        public Builder port(Output port) {
            $.port = port;
            return this;
        }

        /**
         * @param port The port number on which to connect. Possible values are between `1` and `65535`.
         * 
         * @return builder
         * 
         */
        public Builder port(Integer port) {
            return port(Output.of(port));
        }

        /**
         * @param terminationGracePeriodSeconds The time in seconds after the container is sent the termination signal before the process if forcibly killed.
         * 
         * @return builder
         * 
         */
        public Builder terminationGracePeriodSeconds(@Nullable Output terminationGracePeriodSeconds) {
            $.terminationGracePeriodSeconds = terminationGracePeriodSeconds;
            return this;
        }

        /**
         * @param terminationGracePeriodSeconds The time in seconds after the container is sent the termination signal before the process if forcibly killed.
         * 
         * @return builder
         * 
         */
        public Builder terminationGracePeriodSeconds(Integer terminationGracePeriodSeconds) {
            return terminationGracePeriodSeconds(Output.of(terminationGracePeriodSeconds));
        }

        /**
         * @param timeout Time in seconds after which the probe times out. Possible values are in the range `1` - `240`. Defaults to `1`.
         * 
         * @return builder
         * 
         */
        public Builder timeout(@Nullable Output timeout) {
            $.timeout = timeout;
            return this;
        }

        /**
         * @param timeout Time in seconds after which the probe times out. Possible values are in the range `1` - `240`. Defaults to `1`.
         * 
         * @return builder
         * 
         */
        public Builder timeout(Integer timeout) {
            return timeout(Output.of(timeout));
        }

        /**
         * @param transport Type of probe. Possible values are `TCP`, `HTTP`, and `HTTPS`.
         * 
         * @return builder
         * 
         */
        public Builder transport(Output transport) {
            $.transport = transport;
            return this;
        }

        /**
         * @param transport Type of probe. Possible values are `TCP`, `HTTP`, and `HTTPS`.
         * 
         * @return builder
         * 
         */
        public Builder transport(String transport) {
            return transport(Output.of(transport));
        }

        public JobTemplateContainerLivenessProbeArgs build() {
            if ($.port == null) {
                throw new MissingRequiredPropertyException("JobTemplateContainerLivenessProbeArgs", "port");
            }
            if ($.transport == null) {
                throw new MissingRequiredPropertyException("JobTemplateContainerLivenessProbeArgs", "transport");
            }
            return $;
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy