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

com.pulumi.azurenative.cdn.TunnelPolicyArgs Maven / Gradle / Ivy

There is a newer version: 2.78.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.cdn;

import com.pulumi.azurenative.cdn.enums.TunnelType;
import com.pulumi.azurenative.cdn.inputs.ActivatedResourceReferenceArgs;
import com.pulumi.azurenative.cdn.inputs.ResourceReferenceArgs;
import com.pulumi.core.Either;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
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;


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

    public static final TunnelPolicyArgs Empty = new TunnelPolicyArgs();

    /**
     * Domains referenced by this tunnel policy.
     * 
     */
    @Import(name="domains", required=true)
    private Output> domains;

    /**
     * @return Domains referenced by this tunnel policy.
     * 
     */
    public Output> domains() {
        return this.domains;
    }

    /**
     * Name of the Azure Front Door Standard or Azure Front Door Premium which is unique within the resource group.
     * 
     */
    @Import(name="profileName", required=true)
    private Output profileName;

    /**
     * @return Name of the Azure Front Door Standard or Azure Front Door Premium which is unique within the resource group.
     * 
     */
    public Output profileName() {
        return this.profileName;
    }

    /**
     * Name of the Resource group within the Azure subscription.
     * 
     */
    @Import(name="resourceGroupName", required=true)
    private Output resourceGroupName;

    /**
     * @return Name of the Resource group within the Azure subscription.
     * 
     */
    public Output resourceGroupName() {
        return this.resourceGroupName;
    }

    /**
     * Target Groups referenced by this tunnel policy.
     * 
     */
    @Import(name="targetGroups")
    private @Nullable Output> targetGroups;

    /**
     * @return Target Groups referenced by this tunnel policy.
     * 
     */
    public Optional>> targetGroups() {
        return Optional.ofNullable(this.targetGroups);
    }

    /**
     * Name of the Tunnel Policy under the profile.
     * 
     */
    @Import(name="tunnelPolicyName")
    private @Nullable Output tunnelPolicyName;

    /**
     * @return Name of the Tunnel Policy under the profile.
     * 
     */
    public Optional> tunnelPolicyName() {
        return Optional.ofNullable(this.tunnelPolicyName);
    }

    /**
     * Protocol this tunnel will use for allowing traffic to backends.
     * 
     */
    @Import(name="tunnelType")
    private @Nullable Output> tunnelType;

    /**
     * @return Protocol this tunnel will use for allowing traffic to backends.
     * 
     */
    public Optional>> tunnelType() {
        return Optional.ofNullable(this.tunnelType);
    }

    private TunnelPolicyArgs() {}

    private TunnelPolicyArgs(TunnelPolicyArgs $) {
        this.domains = $.domains;
        this.profileName = $.profileName;
        this.resourceGroupName = $.resourceGroupName;
        this.targetGroups = $.targetGroups;
        this.tunnelPolicyName = $.tunnelPolicyName;
        this.tunnelType = $.tunnelType;
    }

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

    public static final class Builder {
        private TunnelPolicyArgs $;

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

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

        /**
         * @param domains Domains referenced by this tunnel policy.
         * 
         * @return builder
         * 
         */
        public Builder domains(Output> domains) {
            $.domains = domains;
            return this;
        }

        /**
         * @param domains Domains referenced by this tunnel policy.
         * 
         * @return builder
         * 
         */
        public Builder domains(List domains) {
            return domains(Output.of(domains));
        }

        /**
         * @param domains Domains referenced by this tunnel policy.
         * 
         * @return builder
         * 
         */
        public Builder domains(ActivatedResourceReferenceArgs... domains) {
            return domains(List.of(domains));
        }

        /**
         * @param profileName Name of the Azure Front Door Standard or Azure Front Door Premium which is unique within the resource group.
         * 
         * @return builder
         * 
         */
        public Builder profileName(Output profileName) {
            $.profileName = profileName;
            return this;
        }

        /**
         * @param profileName Name of the Azure Front Door Standard or Azure Front Door Premium which is unique within the resource group.
         * 
         * @return builder
         * 
         */
        public Builder profileName(String profileName) {
            return profileName(Output.of(profileName));
        }

        /**
         * @param resourceGroupName Name of the Resource group within the Azure subscription.
         * 
         * @return builder
         * 
         */
        public Builder resourceGroupName(Output resourceGroupName) {
            $.resourceGroupName = resourceGroupName;
            return this;
        }

        /**
         * @param resourceGroupName Name of the Resource group within the Azure subscription.
         * 
         * @return builder
         * 
         */
        public Builder resourceGroupName(String resourceGroupName) {
            return resourceGroupName(Output.of(resourceGroupName));
        }

        /**
         * @param targetGroups Target Groups referenced by this tunnel policy.
         * 
         * @return builder
         * 
         */
        public Builder targetGroups(@Nullable Output> targetGroups) {
            $.targetGroups = targetGroups;
            return this;
        }

        /**
         * @param targetGroups Target Groups referenced by this tunnel policy.
         * 
         * @return builder
         * 
         */
        public Builder targetGroups(List targetGroups) {
            return targetGroups(Output.of(targetGroups));
        }

        /**
         * @param targetGroups Target Groups referenced by this tunnel policy.
         * 
         * @return builder
         * 
         */
        public Builder targetGroups(ResourceReferenceArgs... targetGroups) {
            return targetGroups(List.of(targetGroups));
        }

        /**
         * @param tunnelPolicyName Name of the Tunnel Policy under the profile.
         * 
         * @return builder
         * 
         */
        public Builder tunnelPolicyName(@Nullable Output tunnelPolicyName) {
            $.tunnelPolicyName = tunnelPolicyName;
            return this;
        }

        /**
         * @param tunnelPolicyName Name of the Tunnel Policy under the profile.
         * 
         * @return builder
         * 
         */
        public Builder tunnelPolicyName(String tunnelPolicyName) {
            return tunnelPolicyName(Output.of(tunnelPolicyName));
        }

        /**
         * @param tunnelType Protocol this tunnel will use for allowing traffic to backends.
         * 
         * @return builder
         * 
         */
        public Builder tunnelType(@Nullable Output> tunnelType) {
            $.tunnelType = tunnelType;
            return this;
        }

        /**
         * @param tunnelType Protocol this tunnel will use for allowing traffic to backends.
         * 
         * @return builder
         * 
         */
        public Builder tunnelType(Either tunnelType) {
            return tunnelType(Output.of(tunnelType));
        }

        /**
         * @param tunnelType Protocol this tunnel will use for allowing traffic to backends.
         * 
         * @return builder
         * 
         */
        public Builder tunnelType(String tunnelType) {
            return tunnelType(Either.ofLeft(tunnelType));
        }

        /**
         * @param tunnelType Protocol this tunnel will use for allowing traffic to backends.
         * 
         * @return builder
         * 
         */
        public Builder tunnelType(TunnelType tunnelType) {
            return tunnelType(Either.ofRight(tunnelType));
        }

        public TunnelPolicyArgs build() {
            if ($.domains == null) {
                throw new MissingRequiredPropertyException("TunnelPolicyArgs", "domains");
            }
            if ($.profileName == null) {
                throw new MissingRequiredPropertyException("TunnelPolicyArgs", "profileName");
            }
            if ($.resourceGroupName == null) {
                throw new MissingRequiredPropertyException("TunnelPolicyArgs", "resourceGroupName");
            }
            return $;
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy