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

com.pulumi.aws.backup.inputs.PlanRuleArgs 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.aws.backup.inputs;

import com.pulumi.aws.backup.inputs.PlanRuleCopyActionArgs;
import com.pulumi.aws.backup.inputs.PlanRuleLifecycleArgs;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import java.lang.Boolean;
import java.lang.Integer;
import java.lang.String;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;


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

    public static final PlanRuleArgs Empty = new PlanRuleArgs();

    /**
     * The amount of time in minutes AWS Backup attempts a backup before canceling the job and returning an error.
     * 
     */
    @Import(name="completionWindow")
    private @Nullable Output completionWindow;

    /**
     * @return The amount of time in minutes AWS Backup attempts a backup before canceling the job and returning an error.
     * 
     */
    public Optional> completionWindow() {
        return Optional.ofNullable(this.completionWindow);
    }

    /**
     * Configuration block(s) with copy operation settings. Detailed below.
     * 
     */
    @Import(name="copyActions")
    private @Nullable Output> copyActions;

    /**
     * @return Configuration block(s) with copy operation settings. Detailed below.
     * 
     */
    public Optional>> copyActions() {
        return Optional.ofNullable(this.copyActions);
    }

    /**
     * Enable continuous backups for supported resources.
     * 
     */
    @Import(name="enableContinuousBackup")
    private @Nullable Output enableContinuousBackup;

    /**
     * @return Enable continuous backups for supported resources.
     * 
     */
    public Optional> enableContinuousBackup() {
        return Optional.ofNullable(this.enableContinuousBackup);
    }

    /**
     * The lifecycle defines when a protected resource is transitioned to cold storage and when it expires.  Fields documented below.
     * 
     */
    @Import(name="lifecycle")
    private @Nullable Output lifecycle;

    /**
     * @return The lifecycle defines when a protected resource is transitioned to cold storage and when it expires.  Fields documented below.
     * 
     */
    public Optional> lifecycle() {
        return Optional.ofNullable(this.lifecycle);
    }

    /**
     * Metadata that you can assign to help organize the resources that you create.
     * 
     */
    @Import(name="recoveryPointTags")
    private @Nullable Output> recoveryPointTags;

    /**
     * @return Metadata that you can assign to help organize the resources that you create.
     * 
     */
    public Optional>> recoveryPointTags() {
        return Optional.ofNullable(this.recoveryPointTags);
    }

    /**
     * An display name for a backup rule.
     * 
     */
    @Import(name="ruleName", required=true)
    private Output ruleName;

    /**
     * @return An display name for a backup rule.
     * 
     */
    public Output ruleName() {
        return this.ruleName;
    }

    /**
     * A CRON expression specifying when AWS Backup initiates a backup job.
     * 
     */
    @Import(name="schedule")
    private @Nullable Output schedule;

    /**
     * @return A CRON expression specifying when AWS Backup initiates a backup job.
     * 
     */
    public Optional> schedule() {
        return Optional.ofNullable(this.schedule);
    }

    /**
     * The timezone in which the schedule expression is set. Default value: `"Etc/UTC"`.
     * 
     */
    @Import(name="scheduleExpressionTimezone")
    private @Nullable Output scheduleExpressionTimezone;

    /**
     * @return The timezone in which the schedule expression is set. Default value: `"Etc/UTC"`.
     * 
     */
    public Optional> scheduleExpressionTimezone() {
        return Optional.ofNullable(this.scheduleExpressionTimezone);
    }

    /**
     * The amount of time in minutes before beginning a backup.
     * 
     */
    @Import(name="startWindow")
    private @Nullable Output startWindow;

    /**
     * @return The amount of time in minutes before beginning a backup.
     * 
     */
    public Optional> startWindow() {
        return Optional.ofNullable(this.startWindow);
    }

    /**
     * The name of a logical container where backups are stored.
     * 
     */
    @Import(name="targetVaultName", required=true)
    private Output targetVaultName;

    /**
     * @return The name of a logical container where backups are stored.
     * 
     */
    public Output targetVaultName() {
        return this.targetVaultName;
    }

    private PlanRuleArgs() {}

    private PlanRuleArgs(PlanRuleArgs $) {
        this.completionWindow = $.completionWindow;
        this.copyActions = $.copyActions;
        this.enableContinuousBackup = $.enableContinuousBackup;
        this.lifecycle = $.lifecycle;
        this.recoveryPointTags = $.recoveryPointTags;
        this.ruleName = $.ruleName;
        this.schedule = $.schedule;
        this.scheduleExpressionTimezone = $.scheduleExpressionTimezone;
        this.startWindow = $.startWindow;
        this.targetVaultName = $.targetVaultName;
    }

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

    public static final class Builder {
        private PlanRuleArgs $;

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

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

        /**
         * @param completionWindow The amount of time in minutes AWS Backup attempts a backup before canceling the job and returning an error.
         * 
         * @return builder
         * 
         */
        public Builder completionWindow(@Nullable Output completionWindow) {
            $.completionWindow = completionWindow;
            return this;
        }

        /**
         * @param completionWindow The amount of time in minutes AWS Backup attempts a backup before canceling the job and returning an error.
         * 
         * @return builder
         * 
         */
        public Builder completionWindow(Integer completionWindow) {
            return completionWindow(Output.of(completionWindow));
        }

        /**
         * @param copyActions Configuration block(s) with copy operation settings. Detailed below.
         * 
         * @return builder
         * 
         */
        public Builder copyActions(@Nullable Output> copyActions) {
            $.copyActions = copyActions;
            return this;
        }

        /**
         * @param copyActions Configuration block(s) with copy operation settings. Detailed below.
         * 
         * @return builder
         * 
         */
        public Builder copyActions(List copyActions) {
            return copyActions(Output.of(copyActions));
        }

        /**
         * @param copyActions Configuration block(s) with copy operation settings. Detailed below.
         * 
         * @return builder
         * 
         */
        public Builder copyActions(PlanRuleCopyActionArgs... copyActions) {
            return copyActions(List.of(copyActions));
        }

        /**
         * @param enableContinuousBackup Enable continuous backups for supported resources.
         * 
         * @return builder
         * 
         */
        public Builder enableContinuousBackup(@Nullable Output enableContinuousBackup) {
            $.enableContinuousBackup = enableContinuousBackup;
            return this;
        }

        /**
         * @param enableContinuousBackup Enable continuous backups for supported resources.
         * 
         * @return builder
         * 
         */
        public Builder enableContinuousBackup(Boolean enableContinuousBackup) {
            return enableContinuousBackup(Output.of(enableContinuousBackup));
        }

        /**
         * @param lifecycle The lifecycle defines when a protected resource is transitioned to cold storage and when it expires.  Fields documented below.
         * 
         * @return builder
         * 
         */
        public Builder lifecycle(@Nullable Output lifecycle) {
            $.lifecycle = lifecycle;
            return this;
        }

        /**
         * @param lifecycle The lifecycle defines when a protected resource is transitioned to cold storage and when it expires.  Fields documented below.
         * 
         * @return builder
         * 
         */
        public Builder lifecycle(PlanRuleLifecycleArgs lifecycle) {
            return lifecycle(Output.of(lifecycle));
        }

        /**
         * @param recoveryPointTags Metadata that you can assign to help organize the resources that you create.
         * 
         * @return builder
         * 
         */
        public Builder recoveryPointTags(@Nullable Output> recoveryPointTags) {
            $.recoveryPointTags = recoveryPointTags;
            return this;
        }

        /**
         * @param recoveryPointTags Metadata that you can assign to help organize the resources that you create.
         * 
         * @return builder
         * 
         */
        public Builder recoveryPointTags(Map recoveryPointTags) {
            return recoveryPointTags(Output.of(recoveryPointTags));
        }

        /**
         * @param ruleName An display name for a backup rule.
         * 
         * @return builder
         * 
         */
        public Builder ruleName(Output ruleName) {
            $.ruleName = ruleName;
            return this;
        }

        /**
         * @param ruleName An display name for a backup rule.
         * 
         * @return builder
         * 
         */
        public Builder ruleName(String ruleName) {
            return ruleName(Output.of(ruleName));
        }

        /**
         * @param schedule A CRON expression specifying when AWS Backup initiates a backup job.
         * 
         * @return builder
         * 
         */
        public Builder schedule(@Nullable Output schedule) {
            $.schedule = schedule;
            return this;
        }

        /**
         * @param schedule A CRON expression specifying when AWS Backup initiates a backup job.
         * 
         * @return builder
         * 
         */
        public Builder schedule(String schedule) {
            return schedule(Output.of(schedule));
        }

        /**
         * @param scheduleExpressionTimezone The timezone in which the schedule expression is set. Default value: `"Etc/UTC"`.
         * 
         * @return builder
         * 
         */
        public Builder scheduleExpressionTimezone(@Nullable Output scheduleExpressionTimezone) {
            $.scheduleExpressionTimezone = scheduleExpressionTimezone;
            return this;
        }

        /**
         * @param scheduleExpressionTimezone The timezone in which the schedule expression is set. Default value: `"Etc/UTC"`.
         * 
         * @return builder
         * 
         */
        public Builder scheduleExpressionTimezone(String scheduleExpressionTimezone) {
            return scheduleExpressionTimezone(Output.of(scheduleExpressionTimezone));
        }

        /**
         * @param startWindow The amount of time in minutes before beginning a backup.
         * 
         * @return builder
         * 
         */
        public Builder startWindow(@Nullable Output startWindow) {
            $.startWindow = startWindow;
            return this;
        }

        /**
         * @param startWindow The amount of time in minutes before beginning a backup.
         * 
         * @return builder
         * 
         */
        public Builder startWindow(Integer startWindow) {
            return startWindow(Output.of(startWindow));
        }

        /**
         * @param targetVaultName The name of a logical container where backups are stored.
         * 
         * @return builder
         * 
         */
        public Builder targetVaultName(Output targetVaultName) {
            $.targetVaultName = targetVaultName;
            return this;
        }

        /**
         * @param targetVaultName The name of a logical container where backups are stored.
         * 
         * @return builder
         * 
         */
        public Builder targetVaultName(String targetVaultName) {
            return targetVaultName(Output.of(targetVaultName));
        }

        public PlanRuleArgs build() {
            if ($.ruleName == null) {
                throw new MissingRequiredPropertyException("PlanRuleArgs", "ruleName");
            }
            if ($.targetVaultName == null) {
                throw new MissingRequiredPropertyException("PlanRuleArgs", "targetVaultName");
            }
            return $;
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy