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

com.pulumi.azurenative.scheduler.inputs.JobRecurrenceArgs Maven / Gradle / Ivy

There is a newer version: 2.82.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.azurenative.scheduler.inputs;

import com.pulumi.azurenative.scheduler.enums.RecurrenceFrequency;
import com.pulumi.azurenative.scheduler.inputs.JobRecurrenceScheduleArgs;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
import java.lang.Integer;
import java.lang.String;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;


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

    public static final JobRecurrenceArgs Empty = new JobRecurrenceArgs();

    /**
     * Gets or sets the maximum number of times that the job should run.
     * 
     */
    @Import(name="count")
    private @Nullable Output count;

    /**
     * @return Gets or sets the maximum number of times that the job should run.
     * 
     */
    public Optional> count() {
        return Optional.ofNullable(this.count);
    }

    /**
     * Gets or sets the time at which the job will complete.
     * 
     */
    @Import(name="endTime")
    private @Nullable Output endTime;

    /**
     * @return Gets or sets the time at which the job will complete.
     * 
     */
    public Optional> endTime() {
        return Optional.ofNullable(this.endTime);
    }

    /**
     * Gets or sets the frequency of recurrence (second, minute, hour, day, week, month).
     * 
     */
    @Import(name="frequency")
    private @Nullable Output frequency;

    /**
     * @return Gets or sets the frequency of recurrence (second, minute, hour, day, week, month).
     * 
     */
    public Optional> frequency() {
        return Optional.ofNullable(this.frequency);
    }

    /**
     * Gets or sets the interval between retries.
     * 
     */
    @Import(name="interval")
    private @Nullable Output interval;

    /**
     * @return Gets or sets the interval between retries.
     * 
     */
    public Optional> interval() {
        return Optional.ofNullable(this.interval);
    }

    @Import(name="schedule")
    private @Nullable Output schedule;

    public Optional> schedule() {
        return Optional.ofNullable(this.schedule);
    }

    private JobRecurrenceArgs() {}

    private JobRecurrenceArgs(JobRecurrenceArgs $) {
        this.count = $.count;
        this.endTime = $.endTime;
        this.frequency = $.frequency;
        this.interval = $.interval;
        this.schedule = $.schedule;
    }

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

    public static final class Builder {
        private JobRecurrenceArgs $;

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

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

        /**
         * @param count Gets or sets the maximum number of times that the job should run.
         * 
         * @return builder
         * 
         */
        public Builder count(@Nullable Output count) {
            $.count = count;
            return this;
        }

        /**
         * @param count Gets or sets the maximum number of times that the job should run.
         * 
         * @return builder
         * 
         */
        public Builder count(Integer count) {
            return count(Output.of(count));
        }

        /**
         * @param endTime Gets or sets the time at which the job will complete.
         * 
         * @return builder
         * 
         */
        public Builder endTime(@Nullable Output endTime) {
            $.endTime = endTime;
            return this;
        }

        /**
         * @param endTime Gets or sets the time at which the job will complete.
         * 
         * @return builder
         * 
         */
        public Builder endTime(String endTime) {
            return endTime(Output.of(endTime));
        }

        /**
         * @param frequency Gets or sets the frequency of recurrence (second, minute, hour, day, week, month).
         * 
         * @return builder
         * 
         */
        public Builder frequency(@Nullable Output frequency) {
            $.frequency = frequency;
            return this;
        }

        /**
         * @param frequency Gets or sets the frequency of recurrence (second, minute, hour, day, week, month).
         * 
         * @return builder
         * 
         */
        public Builder frequency(RecurrenceFrequency frequency) {
            return frequency(Output.of(frequency));
        }

        /**
         * @param interval Gets or sets the interval between retries.
         * 
         * @return builder
         * 
         */
        public Builder interval(@Nullable Output interval) {
            $.interval = interval;
            return this;
        }

        /**
         * @param interval Gets or sets the interval between retries.
         * 
         * @return builder
         * 
         */
        public Builder interval(Integer interval) {
            return interval(Output.of(interval));
        }

        public Builder schedule(@Nullable Output schedule) {
            $.schedule = schedule;
            return this;
        }

        public Builder schedule(JobRecurrenceScheduleArgs schedule) {
            return schedule(Output.of(schedule));
        }

        public JobRecurrenceArgs build() {
            return $;
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy