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

com.pulumi.azurenative.management.HierarchySetting 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.management;

import com.pulumi.azurenative.Utilities;
import com.pulumi.azurenative.management.HierarchySettingArgs;
import com.pulumi.core.Alias;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Export;
import com.pulumi.core.annotations.ResourceType;
import com.pulumi.core.internal.Codegen;
import java.lang.Boolean;
import java.lang.String;
import java.util.List;
import java.util.Optional;
import javax.annotation.Nullable;

/**
 * Settings defined at the Management Group scope.
 * Azure REST API version: 2021-04-01. Prior API version in Azure Native 1.x: 2020-05-01.
 * 
 * Other available API versions: 2023-04-01.
 * 
 * ## Example Usage
 * ### GetGroupSettings
 * 
 * 
 * {@code
 * package generated_program;
 * 
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.azurenative.management.HierarchySetting;
 * import com.pulumi.azurenative.management.HierarchySettingArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * 
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 * 
 *     public static void stack(Context ctx) {
 *         var hierarchySetting = new HierarchySetting("hierarchySetting", HierarchySettingArgs.builder()
 *             .defaultManagementGroup("/providers/Microsoft.Management/managementGroups/DefaultGroup")
 *             .groupId("root")
 *             .requireAuthorizationForGroupCreation(true)
 *             .build());
 * 
 *     }
 * }
 * 
 * }
 * 
* * ## Import * * An existing resource can be imported using its type token, name, and identifier, e.g. * * ```sh * $ pulumi import azure-native:management:HierarchySetting root /providers/Microsoft.Management/managementGroups/{groupId}/settings/default * ``` * */ @ResourceType(type="azure-native:management:HierarchySetting") public class HierarchySetting extends com.pulumi.resources.CustomResource { /** * Settings that sets the default Management Group under which new subscriptions get added in this tenant. For example, /providers/Microsoft.Management/managementGroups/defaultGroup * */ @Export(name="defaultManagementGroup", refs={String.class}, tree="[0]") private Output defaultManagementGroup; /** * @return Settings that sets the default Management Group under which new subscriptions get added in this tenant. For example, /providers/Microsoft.Management/managementGroups/defaultGroup * */ public Output> defaultManagementGroup() { return Codegen.optional(this.defaultManagementGroup); } /** * The name of the object. In this case, default. * */ @Export(name="name", refs={String.class}, tree="[0]") private Output name; /** * @return The name of the object. In this case, default. * */ public Output name() { return this.name; } /** * Indicates whether RBAC access is required upon group creation under the root Management Group. If set to true, user will require Microsoft.Management/managementGroups/write action on the root Management Group scope in order to create new Groups directly under the root. This will prevent new users from creating new Management Groups, unless they are given access. * */ @Export(name="requireAuthorizationForGroupCreation", refs={Boolean.class}, tree="[0]") private Output requireAuthorizationForGroupCreation; /** * @return Indicates whether RBAC access is required upon group creation under the root Management Group. If set to true, user will require Microsoft.Management/managementGroups/write action on the root Management Group scope in order to create new Groups directly under the root. This will prevent new users from creating new Management Groups, unless they are given access. * */ public Output> requireAuthorizationForGroupCreation() { return Codegen.optional(this.requireAuthorizationForGroupCreation); } /** * The AAD Tenant ID associated with the hierarchy settings. For example, 00000000-0000-0000-0000-000000000000 * */ @Export(name="tenantId", refs={String.class}, tree="[0]") private Output tenantId; /** * @return The AAD Tenant ID associated with the hierarchy settings. For example, 00000000-0000-0000-0000-000000000000 * */ public Output> tenantId() { return Codegen.optional(this.tenantId); } /** * The type of the resource. For example, Microsoft.Management/managementGroups/settings. * */ @Export(name="type", refs={String.class}, tree="[0]") private Output type; /** * @return The type of the resource. For example, Microsoft.Management/managementGroups/settings. * */ public Output type() { return this.type; } /** * * @param name The _unique_ name of the resulting resource. */ public HierarchySetting(java.lang.String name) { this(name, HierarchySettingArgs.Empty); } /** * * @param name The _unique_ name of the resulting resource. * @param args The arguments to use to populate this resource's properties. */ public HierarchySetting(java.lang.String name, HierarchySettingArgs args) { this(name, args, null); } /** * * @param name The _unique_ name of the resulting resource. * @param args The arguments to use to populate this resource's properties. * @param options A bag of options that control this resource's behavior. */ public HierarchySetting(java.lang.String name, HierarchySettingArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) { super("azure-native:management:HierarchySetting", name, makeArgs(args, options), makeResourceOptions(options, Codegen.empty()), false); } private HierarchySetting(java.lang.String name, Output id, @Nullable com.pulumi.resources.CustomResourceOptions options) { super("azure-native:management:HierarchySetting", name, null, makeResourceOptions(options, id), false); } private static HierarchySettingArgs makeArgs(HierarchySettingArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) { if (options != null && options.getUrn().isPresent()) { return null; } return args == null ? HierarchySettingArgs.Empty : args; } private static com.pulumi.resources.CustomResourceOptions makeResourceOptions(@Nullable com.pulumi.resources.CustomResourceOptions options, @Nullable Output id) { var defaultOptions = com.pulumi.resources.CustomResourceOptions.builder() .version(Utilities.getVersion()) .aliases(List.of( Output.of(Alias.builder().type("azure-native:management/v20200201:HierarchySetting").build()), Output.of(Alias.builder().type("azure-native:management/v20200501:HierarchySetting").build()), Output.of(Alias.builder().type("azure-native:management/v20201001:HierarchySetting").build()), Output.of(Alias.builder().type("azure-native:management/v20210401:HierarchySetting").build()), Output.of(Alias.builder().type("azure-native:management/v20230401:HierarchySetting").build()) )) .build(); return com.pulumi.resources.CustomResourceOptions.merge(defaultOptions, options, id); } /** * Get an existing Host resource's state with the given name, ID, and optional extra * properties used to qualify the lookup. * * @param name The _unique_ name of the resulting resource. * @param id The _unique_ provider ID of the resource to lookup. * @param options Optional settings to control the behavior of the CustomResource. */ public static HierarchySetting get(java.lang.String name, Output id, @Nullable com.pulumi.resources.CustomResourceOptions options) { return new HierarchySetting(name, id, options); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy