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

com.pulumi.azurenative.authorization.inputs.PolicyDefinitionReferenceArgs 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.azurenative.authorization.inputs;

import com.pulumi.azurenative.authorization.inputs.ParameterValuesValueArgs;
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.Map;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;


/**
 * The policy definition reference.
 * 
 */
public final class PolicyDefinitionReferenceArgs extends com.pulumi.resources.ResourceArgs {

    public static final PolicyDefinitionReferenceArgs Empty = new PolicyDefinitionReferenceArgs();

    /**
     * The version of the policy definition to use.
     * 
     */
    @Import(name="definitionVersion")
    private @Nullable Output definitionVersion;

    /**
     * @return The version of the policy definition to use.
     * 
     */
    public Optional> definitionVersion() {
        return Optional.ofNullable(this.definitionVersion);
    }

    /**
     * The name of the groups that this policy definition reference belongs to.
     * 
     */
    @Import(name="groupNames")
    private @Nullable Output> groupNames;

    /**
     * @return The name of the groups that this policy definition reference belongs to.
     * 
     */
    public Optional>> groupNames() {
        return Optional.ofNullable(this.groupNames);
    }

    /**
     * The parameter values for the referenced policy rule. The keys are the parameter names.
     * 
     */
    @Import(name="parameters")
    private @Nullable Output> parameters;

    /**
     * @return The parameter values for the referenced policy rule. The keys are the parameter names.
     * 
     */
    public Optional>> parameters() {
        return Optional.ofNullable(this.parameters);
    }

    /**
     * The ID of the policy definition or policy set definition.
     * 
     */
    @Import(name="policyDefinitionId", required=true)
    private Output policyDefinitionId;

    /**
     * @return The ID of the policy definition or policy set definition.
     * 
     */
    public Output policyDefinitionId() {
        return this.policyDefinitionId;
    }

    /**
     * A unique id (within the policy set definition) for this policy definition reference.
     * 
     */
    @Import(name="policyDefinitionReferenceId")
    private @Nullable Output policyDefinitionReferenceId;

    /**
     * @return A unique id (within the policy set definition) for this policy definition reference.
     * 
     */
    public Optional> policyDefinitionReferenceId() {
        return Optional.ofNullable(this.policyDefinitionReferenceId);
    }

    private PolicyDefinitionReferenceArgs() {}

    private PolicyDefinitionReferenceArgs(PolicyDefinitionReferenceArgs $) {
        this.definitionVersion = $.definitionVersion;
        this.groupNames = $.groupNames;
        this.parameters = $.parameters;
        this.policyDefinitionId = $.policyDefinitionId;
        this.policyDefinitionReferenceId = $.policyDefinitionReferenceId;
    }

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

    public static final class Builder {
        private PolicyDefinitionReferenceArgs $;

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

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

        /**
         * @param definitionVersion The version of the policy definition to use.
         * 
         * @return builder
         * 
         */
        public Builder definitionVersion(@Nullable Output definitionVersion) {
            $.definitionVersion = definitionVersion;
            return this;
        }

        /**
         * @param definitionVersion The version of the policy definition to use.
         * 
         * @return builder
         * 
         */
        public Builder definitionVersion(String definitionVersion) {
            return definitionVersion(Output.of(definitionVersion));
        }

        /**
         * @param groupNames The name of the groups that this policy definition reference belongs to.
         * 
         * @return builder
         * 
         */
        public Builder groupNames(@Nullable Output> groupNames) {
            $.groupNames = groupNames;
            return this;
        }

        /**
         * @param groupNames The name of the groups that this policy definition reference belongs to.
         * 
         * @return builder
         * 
         */
        public Builder groupNames(List groupNames) {
            return groupNames(Output.of(groupNames));
        }

        /**
         * @param groupNames The name of the groups that this policy definition reference belongs to.
         * 
         * @return builder
         * 
         */
        public Builder groupNames(String... groupNames) {
            return groupNames(List.of(groupNames));
        }

        /**
         * @param parameters The parameter values for the referenced policy rule. The keys are the parameter names.
         * 
         * @return builder
         * 
         */
        public Builder parameters(@Nullable Output> parameters) {
            $.parameters = parameters;
            return this;
        }

        /**
         * @param parameters The parameter values for the referenced policy rule. The keys are the parameter names.
         * 
         * @return builder
         * 
         */
        public Builder parameters(Map parameters) {
            return parameters(Output.of(parameters));
        }

        /**
         * @param policyDefinitionId The ID of the policy definition or policy set definition.
         * 
         * @return builder
         * 
         */
        public Builder policyDefinitionId(Output policyDefinitionId) {
            $.policyDefinitionId = policyDefinitionId;
            return this;
        }

        /**
         * @param policyDefinitionId The ID of the policy definition or policy set definition.
         * 
         * @return builder
         * 
         */
        public Builder policyDefinitionId(String policyDefinitionId) {
            return policyDefinitionId(Output.of(policyDefinitionId));
        }

        /**
         * @param policyDefinitionReferenceId A unique id (within the policy set definition) for this policy definition reference.
         * 
         * @return builder
         * 
         */
        public Builder policyDefinitionReferenceId(@Nullable Output policyDefinitionReferenceId) {
            $.policyDefinitionReferenceId = policyDefinitionReferenceId;
            return this;
        }

        /**
         * @param policyDefinitionReferenceId A unique id (within the policy set definition) for this policy definition reference.
         * 
         * @return builder
         * 
         */
        public Builder policyDefinitionReferenceId(String policyDefinitionReferenceId) {
            return policyDefinitionReferenceId(Output.of(policyDefinitionReferenceId));
        }

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

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy