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

com.pulumi.azurenative.storage.inputs.NetworkRuleSetArgs 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.storage.inputs;

import com.pulumi.azurenative.storage.enums.Bypass;
import com.pulumi.azurenative.storage.enums.DefaultAction;
import com.pulumi.azurenative.storage.inputs.IPRuleArgs;
import com.pulumi.azurenative.storage.inputs.ResourceAccessRuleArgs;
import com.pulumi.azurenative.storage.inputs.VirtualNetworkRuleArgs;
import com.pulumi.core.Either;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
import com.pulumi.core.internal.Codegen;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import java.lang.String;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;


/**
 * Network rule set
 * 
 */
public final class NetworkRuleSetArgs extends com.pulumi.resources.ResourceArgs {

    public static final NetworkRuleSetArgs Empty = new NetworkRuleSetArgs();

    /**
     * Specifies whether traffic is bypassed for Logging/Metrics/AzureServices. Possible values are any combination of Logging|Metrics|AzureServices (For example, "Logging, Metrics"), or None to bypass none of those traffics.
     * 
     */
    @Import(name="bypass")
    private @Nullable Output> bypass;

    /**
     * @return Specifies whether traffic is bypassed for Logging/Metrics/AzureServices. Possible values are any combination of Logging|Metrics|AzureServices (For example, "Logging, Metrics"), or None to bypass none of those traffics.
     * 
     */
    public Optional>> bypass() {
        return Optional.ofNullable(this.bypass);
    }

    /**
     * Specifies the default action of allow or deny when no other rules match.
     * 
     */
    @Import(name="defaultAction", required=true)
    private Output defaultAction;

    /**
     * @return Specifies the default action of allow or deny when no other rules match.
     * 
     */
    public Output defaultAction() {
        return this.defaultAction;
    }

    /**
     * Sets the IP ACL rules
     * 
     */
    @Import(name="ipRules")
    private @Nullable Output> ipRules;

    /**
     * @return Sets the IP ACL rules
     * 
     */
    public Optional>> ipRules() {
        return Optional.ofNullable(this.ipRules);
    }

    /**
     * Sets the resource access rules
     * 
     */
    @Import(name="resourceAccessRules")
    private @Nullable Output> resourceAccessRules;

    /**
     * @return Sets the resource access rules
     * 
     */
    public Optional>> resourceAccessRules() {
        return Optional.ofNullable(this.resourceAccessRules);
    }

    /**
     * Sets the virtual network rules
     * 
     */
    @Import(name="virtualNetworkRules")
    private @Nullable Output> virtualNetworkRules;

    /**
     * @return Sets the virtual network rules
     * 
     */
    public Optional>> virtualNetworkRules() {
        return Optional.ofNullable(this.virtualNetworkRules);
    }

    private NetworkRuleSetArgs() {}

    private NetworkRuleSetArgs(NetworkRuleSetArgs $) {
        this.bypass = $.bypass;
        this.defaultAction = $.defaultAction;
        this.ipRules = $.ipRules;
        this.resourceAccessRules = $.resourceAccessRules;
        this.virtualNetworkRules = $.virtualNetworkRules;
    }

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

    public static final class Builder {
        private NetworkRuleSetArgs $;

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

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

        /**
         * @param bypass Specifies whether traffic is bypassed for Logging/Metrics/AzureServices. Possible values are any combination of Logging|Metrics|AzureServices (For example, "Logging, Metrics"), or None to bypass none of those traffics.
         * 
         * @return builder
         * 
         */
        public Builder bypass(@Nullable Output> bypass) {
            $.bypass = bypass;
            return this;
        }

        /**
         * @param bypass Specifies whether traffic is bypassed for Logging/Metrics/AzureServices. Possible values are any combination of Logging|Metrics|AzureServices (For example, "Logging, Metrics"), or None to bypass none of those traffics.
         * 
         * @return builder
         * 
         */
        public Builder bypass(Either bypass) {
            return bypass(Output.of(bypass));
        }

        /**
         * @param bypass Specifies whether traffic is bypassed for Logging/Metrics/AzureServices. Possible values are any combination of Logging|Metrics|AzureServices (For example, "Logging, Metrics"), or None to bypass none of those traffics.
         * 
         * @return builder
         * 
         */
        public Builder bypass(String bypass) {
            return bypass(Either.ofLeft(bypass));
        }

        /**
         * @param bypass Specifies whether traffic is bypassed for Logging/Metrics/AzureServices. Possible values are any combination of Logging|Metrics|AzureServices (For example, "Logging, Metrics"), or None to bypass none of those traffics.
         * 
         * @return builder
         * 
         */
        public Builder bypass(Bypass bypass) {
            return bypass(Either.ofRight(bypass));
        }

        /**
         * @param defaultAction Specifies the default action of allow or deny when no other rules match.
         * 
         * @return builder
         * 
         */
        public Builder defaultAction(Output defaultAction) {
            $.defaultAction = defaultAction;
            return this;
        }

        /**
         * @param defaultAction Specifies the default action of allow or deny when no other rules match.
         * 
         * @return builder
         * 
         */
        public Builder defaultAction(DefaultAction defaultAction) {
            return defaultAction(Output.of(defaultAction));
        }

        /**
         * @param ipRules Sets the IP ACL rules
         * 
         * @return builder
         * 
         */
        public Builder ipRules(@Nullable Output> ipRules) {
            $.ipRules = ipRules;
            return this;
        }

        /**
         * @param ipRules Sets the IP ACL rules
         * 
         * @return builder
         * 
         */
        public Builder ipRules(List ipRules) {
            return ipRules(Output.of(ipRules));
        }

        /**
         * @param ipRules Sets the IP ACL rules
         * 
         * @return builder
         * 
         */
        public Builder ipRules(IPRuleArgs... ipRules) {
            return ipRules(List.of(ipRules));
        }

        /**
         * @param resourceAccessRules Sets the resource access rules
         * 
         * @return builder
         * 
         */
        public Builder resourceAccessRules(@Nullable Output> resourceAccessRules) {
            $.resourceAccessRules = resourceAccessRules;
            return this;
        }

        /**
         * @param resourceAccessRules Sets the resource access rules
         * 
         * @return builder
         * 
         */
        public Builder resourceAccessRules(List resourceAccessRules) {
            return resourceAccessRules(Output.of(resourceAccessRules));
        }

        /**
         * @param resourceAccessRules Sets the resource access rules
         * 
         * @return builder
         * 
         */
        public Builder resourceAccessRules(ResourceAccessRuleArgs... resourceAccessRules) {
            return resourceAccessRules(List.of(resourceAccessRules));
        }

        /**
         * @param virtualNetworkRules Sets the virtual network rules
         * 
         * @return builder
         * 
         */
        public Builder virtualNetworkRules(@Nullable Output> virtualNetworkRules) {
            $.virtualNetworkRules = virtualNetworkRules;
            return this;
        }

        /**
         * @param virtualNetworkRules Sets the virtual network rules
         * 
         * @return builder
         * 
         */
        public Builder virtualNetworkRules(List virtualNetworkRules) {
            return virtualNetworkRules(Output.of(virtualNetworkRules));
        }

        /**
         * @param virtualNetworkRules Sets the virtual network rules
         * 
         * @return builder
         * 
         */
        public Builder virtualNetworkRules(VirtualNetworkRuleArgs... virtualNetworkRules) {
            return virtualNetworkRules(List.of(virtualNetworkRules));
        }

        public NetworkRuleSetArgs build() {
            $.bypass = Codegen.stringProp("bypass").left(Bypass.class).output().arg($.bypass).def("AzureServices").getNullable();
            $.defaultAction = Codegen.objectProp("defaultAction", DefaultAction.class).output().arg($.defaultAction).def(DefaultAction.Allow).require();
            return $;
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy