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

com.pulumi.kubernetes.helm.v3.Release Maven / Gradle / Ivy

There is a newer version: 4.19.0
Show newest version
// *** 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.helm.v3;

import com.pulumi.asset.AssetOrArchive;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Export;
import com.pulumi.core.annotations.ResourceType;
import com.pulumi.core.internal.Codegen;
import com.pulumi.kubernetes.Utilities;
import com.pulumi.kubernetes.helm.v3.ReleaseArgs;
import com.pulumi.kubernetes.helm.v3.outputs.ReleaseStatus;
import com.pulumi.kubernetes.helm.v3.outputs.RepositoryOpts;
import java.lang.Boolean;
import java.lang.Integer;
import java.lang.Object;
import java.lang.String;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import javax.annotation.Nullable;

/**
 * A `Release` is an instance of a chart running in a Kubernetes cluster. A `Chart` is a Helm package. It contains all the
 * resource definitions necessary to run an application, tool, or service inside a Kubernetes cluster.
 * 
 * This resource models a Helm Release as if it were created by the Helm CLI. The underlying implementation embeds Helm as
 * a library to perform the orchestration of the resources. As a result, the full spectrum of Helm features are supported
 * natively.
 * 
 * You may also want to consider the `Chart` resource as an alternative method for managing helm charts. For more information about the trade-offs between these options see: [Choosing the right Helm resource for your use case](https://www.pulumi.com/registry/packages/kubernetes/how-to-guides/choosing-the-right-helm-resource-for-your-use-case)
 * 
 * ## Example Usage
 * 
 * ## Import
 * 
 * An existing Helm Release resource can be imported using its `type token`, `name` and identifier, e.g.
 * 
 * ```sh
 * $ pulumi import kubernetes:helm.sh/v3:Release myRelease <namespace>/<releaseName>
 * ```
 * 
 */
@ResourceType(type="kubernetes:helm.sh/v3:Release")
public class Release extends com.pulumi.resources.CustomResource {
    /**
     * Whether to allow Null values in helm chart configs.
     * 
     */
    @Export(name="allowNullValues", refs={Boolean.class}, tree="[0]")
    private Output allowNullValues;

    /**
     * @return Whether to allow Null values in helm chart configs.
     * 
     */
    public Output> allowNullValues() {
        return Codegen.optional(this.allowNullValues);
    }
    /**
     * If set, installation process purges chart on fail. `skipAwait` will be disabled automatically if atomic is used.
     * 
     */
    @Export(name="atomic", refs={Boolean.class}, tree="[0]")
    private Output atomic;

    /**
     * @return If set, installation process purges chart on fail. `skipAwait` will be disabled automatically if atomic is used.
     * 
     */
    public Output> atomic() {
        return Codegen.optional(this.atomic);
    }
    /**
     * Chart name to be installed. A path may be used.
     * 
     */
    @Export(name="chart", refs={String.class}, tree="[0]")
    private Output chart;

    /**
     * @return Chart name to be installed. A path may be used.
     * 
     */
    public Output chart() {
        return this.chart;
    }
    /**
     * Allow deletion of new resources created in this upgrade when upgrade fails.
     * 
     */
    @Export(name="cleanupOnFail", refs={Boolean.class}, tree="[0]")
    private Output cleanupOnFail;

    /**
     * @return Allow deletion of new resources created in this upgrade when upgrade fails.
     * 
     */
    public Output> cleanupOnFail() {
        return Codegen.optional(this.cleanupOnFail);
    }
    /**
     * Create the namespace if it does not exist.
     * 
     */
    @Export(name="createNamespace", refs={Boolean.class}, tree="[0]")
    private Output createNamespace;

    /**
     * @return Create the namespace if it does not exist.
     * 
     */
    public Output> createNamespace() {
        return Codegen.optional(this.createNamespace);
    }
    /**
     * Run helm dependency update before installing the chart.
     * 
     */
    @Export(name="dependencyUpdate", refs={Boolean.class}, tree="[0]")
    private Output dependencyUpdate;

    /**
     * @return Run helm dependency update before installing the chart.
     * 
     */
    public Output> dependencyUpdate() {
        return Codegen.optional(this.dependencyUpdate);
    }
    /**
     * Add a custom description
     * 
     */
    @Export(name="description", refs={String.class}, tree="[0]")
    private Output description;

    /**
     * @return Add a custom description
     * 
     */
    public Output> description() {
        return Codegen.optional(this.description);
    }
    /**
     * Use chart development versions, too. Equivalent to version '>0.0.0-0'. If `version` is set, this is ignored.
     * 
     */
    @Export(name="devel", refs={Boolean.class}, tree="[0]")
    private Output devel;

    /**
     * @return Use chart development versions, too. Equivalent to version '>0.0.0-0'. If `version` is set, this is ignored.
     * 
     */
    public Output> devel() {
        return Codegen.optional(this.devel);
    }
    /**
     * Prevent CRD hooks from running, but run other hooks.  See helm install --no-crd-hook
     * 
     */
    @Export(name="disableCRDHooks", refs={Boolean.class}, tree="[0]")
    private Output disableCRDHooks;

    /**
     * @return Prevent CRD hooks from running, but run other hooks.  See helm install --no-crd-hook
     * 
     */
    public Output> disableCRDHooks() {
        return Codegen.optional(this.disableCRDHooks);
    }
    /**
     * If set, the installation process will not validate rendered templates against the Kubernetes OpenAPI Schema
     * 
     */
    @Export(name="disableOpenapiValidation", refs={Boolean.class}, tree="[0]")
    private Output disableOpenapiValidation;

    /**
     * @return If set, the installation process will not validate rendered templates against the Kubernetes OpenAPI Schema
     * 
     */
    public Output> disableOpenapiValidation() {
        return Codegen.optional(this.disableOpenapiValidation);
    }
    /**
     * Prevent hooks from running.
     * 
     */
    @Export(name="disableWebhooks", refs={Boolean.class}, tree="[0]")
    private Output disableWebhooks;

    /**
     * @return Prevent hooks from running.
     * 
     */
    public Output> disableWebhooks() {
        return Codegen.optional(this.disableWebhooks);
    }
    /**
     * Force resource update through delete/recreate if needed.
     * 
     */
    @Export(name="forceUpdate", refs={Boolean.class}, tree="[0]")
    private Output forceUpdate;

    /**
     * @return Force resource update through delete/recreate if needed.
     * 
     */
    public Output> forceUpdate() {
        return Codegen.optional(this.forceUpdate);
    }
    /**
     * Location of public keys used for verification. Used only if `verify` is true
     * 
     */
    @Export(name="keyring", refs={String.class}, tree="[0]")
    private Output keyring;

    /**
     * @return Location of public keys used for verification. Used only if `verify` is true
     * 
     */
    public Output> keyring() {
        return Codegen.optional(this.keyring);
    }
    /**
     * Run helm lint when planning.
     * 
     */
    @Export(name="lint", refs={Boolean.class}, tree="[0]")
    private Output lint;

    /**
     * @return Run helm lint when planning.
     * 
     */
    public Output> lint() {
        return Codegen.optional(this.lint);
    }
    /**
     * The rendered manifests as JSON. Not yet supported.
     * 
     */
    @Export(name="manifest", refs={Map.class,String.class,Object.class}, tree="[0,1,2]")
    private Output> manifest;

    /**
     * @return The rendered manifests as JSON. Not yet supported.
     * 
     */
    public Output>> manifest() {
        return Codegen.optional(this.manifest);
    }
    /**
     * Limit the maximum number of revisions saved per release. Use 0 for no limit.
     * 
     */
    @Export(name="maxHistory", refs={Integer.class}, tree="[0]")
    private Output maxHistory;

    /**
     * @return Limit the maximum number of revisions saved per release. Use 0 for no limit.
     * 
     */
    public Output> maxHistory() {
        return Codegen.optional(this.maxHistory);
    }
    /**
     * Release name.
     * 
     */
    @Export(name="name", refs={String.class}, tree="[0]")
    private Output name;

    /**
     * @return Release name.
     * 
     */
    public Output> name() {
        return Codegen.optional(this.name);
    }
    /**
     * Namespace to install the release into.
     * 
     */
    @Export(name="namespace", refs={String.class}, tree="[0]")
    private Output namespace;

    /**
     * @return Namespace to install the release into.
     * 
     */
    public Output> namespace() {
        return Codegen.optional(this.namespace);
    }
    /**
     * Postrender command to run.
     * 
     */
    @Export(name="postrender", refs={String.class}, tree="[0]")
    private Output postrender;

    /**
     * @return Postrender command to run.
     * 
     */
    public Output> postrender() {
        return Codegen.optional(this.postrender);
    }
    /**
     * Perform pods restart during upgrade/rollback.
     * 
     */
    @Export(name="recreatePods", refs={Boolean.class}, tree="[0]")
    private Output recreatePods;

    /**
     * @return Perform pods restart during upgrade/rollback.
     * 
     */
    public Output> recreatePods() {
        return Codegen.optional(this.recreatePods);
    }
    /**
     * If set, render subchart notes along with the parent.
     * 
     */
    @Export(name="renderSubchartNotes", refs={Boolean.class}, tree="[0]")
    private Output renderSubchartNotes;

    /**
     * @return If set, render subchart notes along with the parent.
     * 
     */
    public Output> renderSubchartNotes() {
        return Codegen.optional(this.renderSubchartNotes);
    }
    /**
     * Re-use the given name, even if that name is already used. This is unsafe in production
     * 
     */
    @Export(name="replace", refs={Boolean.class}, tree="[0]")
    private Output replace;

    /**
     * @return Re-use the given name, even if that name is already used. This is unsafe in production
     * 
     */
    public Output> replace() {
        return Codegen.optional(this.replace);
    }
    /**
     * Specification defining the Helm chart repository to use.
     * 
     */
    @Export(name="repositoryOpts", refs={RepositoryOpts.class}, tree="[0]")
    private Output repositoryOpts;

    /**
     * @return Specification defining the Helm chart repository to use.
     * 
     */
    public Output> repositoryOpts() {
        return Codegen.optional(this.repositoryOpts);
    }
    /**
     * When upgrading, reset the values to the ones built into the chart.
     * 
     */
    @Export(name="resetValues", refs={Boolean.class}, tree="[0]")
    private Output resetValues;

    /**
     * @return When upgrading, reset the values to the ones built into the chart.
     * 
     */
    public Output> resetValues() {
        return Codegen.optional(this.resetValues);
    }
    /**
     * Names of resources created by the release grouped by "kind/version".
     * 
     */
    @Export(name="resourceNames", refs={Map.class,String.class,List.class}, tree="[0,1,[2,1]]")
    private Output>> resourceNames;

    /**
     * @return Names of resources created by the release grouped by "kind/version".
     * 
     */
    public Output>>> resourceNames() {
        return Codegen.optional(this.resourceNames);
    }
    /**
     * When upgrading, reuse the last release's values and merge in any overrides. If 'resetValues' is specified, this is ignored
     * 
     */
    @Export(name="reuseValues", refs={Boolean.class}, tree="[0]")
    private Output reuseValues;

    /**
     * @return When upgrading, reuse the last release's values and merge in any overrides. If 'resetValues' is specified, this is ignored
     * 
     */
    public Output> reuseValues() {
        return Codegen.optional(this.reuseValues);
    }
    /**
     * By default, the provider waits until all resources are in a ready state before marking the release as successful. Setting this to true will skip such await logic.
     * 
     */
    @Export(name="skipAwait", refs={Boolean.class}, tree="[0]")
    private Output skipAwait;

    /**
     * @return By default, the provider waits until all resources are in a ready state before marking the release as successful. Setting this to true will skip such await logic.
     * 
     */
    public Output> skipAwait() {
        return Codegen.optional(this.skipAwait);
    }
    /**
     * If set, no CRDs will be installed. By default, CRDs are installed if not already present.
     * 
     */
    @Export(name="skipCrds", refs={Boolean.class}, tree="[0]")
    private Output skipCrds;

    /**
     * @return If set, no CRDs will be installed. By default, CRDs are installed if not already present.
     * 
     */
    public Output> skipCrds() {
        return Codegen.optional(this.skipCrds);
    }
    /**
     * Status of the deployed release.
     * 
     */
    @Export(name="status", refs={ReleaseStatus.class}, tree="[0]")
    private Output status;

    /**
     * @return Status of the deployed release.
     * 
     */
    public Output status() {
        return this.status;
    }
    /**
     * Time in seconds to wait for any individual kubernetes operation.
     * 
     */
    @Export(name="timeout", refs={Integer.class}, tree="[0]")
    private Output timeout;

    /**
     * @return Time in seconds to wait for any individual kubernetes operation.
     * 
     */
    public Output> timeout() {
        return Codegen.optional(this.timeout);
    }
    /**
     * List of assets (raw yaml files). Content is read and merged with values (with values taking precedence).
     * 
     */
    @Export(name="valueYamlFiles", refs={List.class,AssetOrArchive.class}, tree="[0,1]")
    private Output> valueYamlFiles;

    /**
     * @return List of assets (raw yaml files). Content is read and merged with values (with values taking precedence).
     * 
     */
    public Output>> valueYamlFiles() {
        return Codegen.optional(this.valueYamlFiles);
    }
    /**
     * Custom values set for the release.
     * 
     */
    @Export(name="values", refs={Map.class,String.class,Object.class}, tree="[0,1,2]")
    private Output> values;

    /**
     * @return Custom values set for the release.
     * 
     */
    public Output>> values() {
        return Codegen.optional(this.values);
    }
    /**
     * Verify the package before installing it.
     * 
     */
    @Export(name="verify", refs={Boolean.class}, tree="[0]")
    private Output verify;

    /**
     * @return Verify the package before installing it.
     * 
     */
    public Output> verify() {
        return Codegen.optional(this.verify);
    }
    /**
     * Specify the exact chart version to install. If this is not specified, the latest version is installed.
     * 
     */
    @Export(name="version", refs={String.class}, tree="[0]")
    private Output version;

    /**
     * @return Specify the exact chart version to install. If this is not specified, the latest version is installed.
     * 
     */
    public Output> version() {
        return Codegen.optional(this.version);
    }
    /**
     * Will wait until all Jobs have been completed before marking the release as successful. This is ignored if `skipAwait` is enabled.
     * 
     */
    @Export(name="waitForJobs", refs={Boolean.class}, tree="[0]")
    private Output waitForJobs;

    /**
     * @return Will wait until all Jobs have been completed before marking the release as successful. This is ignored if `skipAwait` is enabled.
     * 
     */
    public Output> waitForJobs() {
        return Codegen.optional(this.waitForJobs);
    }

    /**
     *
     * @param name The _unique_ name of the resulting resource.
     */
    public Release(String name) {
        this(name, ReleaseArgs.Empty);
    }
    /**
     *
     * @param name The _unique_ name of the resulting resource.
     * @param args The arguments to use to populate this resource's properties.
     */
    public Release(String name, ReleaseArgs args) {
        this(name, args, null);
    }
    /**
     *
     * @param name The _unique_ name of the resulting resource.
     * @param args The arguments to use to populate this resource's properties.
     * @param options A bag of options that control this resource's behavior.
     */
    public Release(String name, ReleaseArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) {
        super("kubernetes:helm.sh/v3:Release", name, makeArgs(args, options), makeResourceOptions(options, Codegen.empty()));
    }

    private Release(String name, Output id, @Nullable com.pulumi.resources.CustomResourceOptions options) {
        super("kubernetes:helm.sh/v3:Release", name, null, makeResourceOptions(options, id));
    }

    private static ReleaseArgs makeArgs(ReleaseArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) {
        if (options != null && options.getUrn().isPresent()) {
            return null;
        }
        var builder = args == null ? ReleaseArgs.builder() : ReleaseArgs.builder(args);
        return builder
            .compat("true")
            .build();
    }

    private static com.pulumi.resources.CustomResourceOptions makeResourceOptions(@Nullable com.pulumi.resources.CustomResourceOptions options, @Nullable Output id) {
        var defaultOptions = com.pulumi.resources.CustomResourceOptions.builder()
            .version(Utilities.getVersion())
            .build();
        return com.pulumi.resources.CustomResourceOptions.merge(defaultOptions, options, id);
    }

    /**
     * Get an existing Host resource's state with the given name, ID, and optional extra
     * properties used to qualify the lookup.
     *
     * @param name The _unique_ name of the resulting resource.
     * @param id The _unique_ provider ID of the resource to lookup.
     * @param options Optional settings to control the behavior of the CustomResource.
     */
    public static Release get(String name, Output id, @Nullable com.pulumi.resources.CustomResourceOptions options) {
        return new Release(name, id, options);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy