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

com.pulumi.kubernetes.policy.v1beta1.inputs.RunAsUserStrategyOptionsArgs 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.kubernetes.policy.v1beta1.inputs;

import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import com.pulumi.kubernetes.policy.v1beta1.inputs.IDRangeArgs;
import java.lang.String;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;


/**
 * RunAsUserStrategyOptions defines the strategy type and any options used to create the strategy.
 * 
 */
public final class RunAsUserStrategyOptionsArgs extends com.pulumi.resources.ResourceArgs {

    public static final RunAsUserStrategyOptionsArgs Empty = new RunAsUserStrategyOptionsArgs();

    /**
     * ranges are the allowed ranges of uids that may be used. If you would like to force a single uid then supply a single range with the same start and end. Required for MustRunAs.
     * 
     */
    @Import(name="ranges")
    private @Nullable Output> ranges;

    /**
     * @return ranges are the allowed ranges of uids that may be used. If you would like to force a single uid then supply a single range with the same start and end. Required for MustRunAs.
     * 
     */
    public Optional>> ranges() {
        return Optional.ofNullable(this.ranges);
    }

    /**
     * rule is the strategy that will dictate the allowable RunAsUser values that may be set.
     * 
     */
    @Import(name="rule", required=true)
    private Output rule;

    /**
     * @return rule is the strategy that will dictate the allowable RunAsUser values that may be set.
     * 
     */
    public Output rule() {
        return this.rule;
    }

    private RunAsUserStrategyOptionsArgs() {}

    private RunAsUserStrategyOptionsArgs(RunAsUserStrategyOptionsArgs $) {
        this.ranges = $.ranges;
        this.rule = $.rule;
    }

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

    public static final class Builder {
        private RunAsUserStrategyOptionsArgs $;

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

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

        /**
         * @param ranges ranges are the allowed ranges of uids that may be used. If you would like to force a single uid then supply a single range with the same start and end. Required for MustRunAs.
         * 
         * @return builder
         * 
         */
        public Builder ranges(@Nullable Output> ranges) {
            $.ranges = ranges;
            return this;
        }

        /**
         * @param ranges ranges are the allowed ranges of uids that may be used. If you would like to force a single uid then supply a single range with the same start and end. Required for MustRunAs.
         * 
         * @return builder
         * 
         */
        public Builder ranges(List ranges) {
            return ranges(Output.of(ranges));
        }

        /**
         * @param ranges ranges are the allowed ranges of uids that may be used. If you would like to force a single uid then supply a single range with the same start and end. Required for MustRunAs.
         * 
         * @return builder
         * 
         */
        public Builder ranges(IDRangeArgs... ranges) {
            return ranges(List.of(ranges));
        }

        /**
         * @param rule rule is the strategy that will dictate the allowable RunAsUser values that may be set.
         * 
         * @return builder
         * 
         */
        public Builder rule(Output rule) {
            $.rule = rule;
            return this;
        }

        /**
         * @param rule rule is the strategy that will dictate the allowable RunAsUser values that may be set.
         * 
         * @return builder
         * 
         */
        public Builder rule(String rule) {
            return rule(Output.of(rule));
        }

        public RunAsUserStrategyOptionsArgs build() {
            if ($.rule == null) {
                throw new MissingRequiredPropertyException("RunAsUserStrategyOptionsArgs", "rule");
            }
            return $;
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy