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

com.pulumi.kubernetes.policy.v1beta1.inputs.FSGroupStrategyOptionsArgs Maven / Gradle / Ivy

There is a newer version: 4.19.0-alpha.1730750641
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.policy.v1beta1.inputs;

import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
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;


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

    public static final FSGroupStrategyOptionsArgs Empty = new FSGroupStrategyOptionsArgs();

    /**
     * ranges are the allowed ranges of fs groups.  If you would like to force a single fs group 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 fs groups.  If you would like to force a single fs group 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 what FSGroup is used in the SecurityContext.
     * 
     */
    @Import(name="rule")
    private @Nullable Output rule;

    /**
     * @return rule is the strategy that will dictate what FSGroup is used in the SecurityContext.
     * 
     */
    public Optional> rule() {
        return Optional.ofNullable(this.rule);
    }

    private FSGroupStrategyOptionsArgs() {}

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

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

    public static final class Builder {
        private FSGroupStrategyOptionsArgs $;

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

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

        /**
         * @param ranges ranges are the allowed ranges of fs groups.  If you would like to force a single fs group 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 fs groups.  If you would like to force a single fs group 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 fs groups.  If you would like to force a single fs group 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 what FSGroup is used in the SecurityContext.
         * 
         * @return builder
         * 
         */
        public Builder rule(@Nullable Output rule) {
            $.rule = rule;
            return this;
        }

        /**
         * @param rule rule is the strategy that will dictate what FSGroup is used in the SecurityContext.
         * 
         * @return builder
         * 
         */
        public Builder rule(String rule) {
            return rule(Output.of(rule));
        }

        public FSGroupStrategyOptionsArgs build() {
            return $;
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy