
com.pulumi.azurenative.kusto.AttachedDatabaseConfiguration 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.kusto;
import com.pulumi.azurenative.Utilities;
import com.pulumi.azurenative.kusto.AttachedDatabaseConfigurationArgs;
import com.pulumi.azurenative.kusto.outputs.TableLevelSharingPropertiesResponse;
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.String;
import java.util.List;
import java.util.Optional;
import javax.annotation.Nullable;
/**
* Class representing an attached database configuration.
* Azure REST API version: 2022-12-29. Prior API version in Azure Native 1.x: 2021-01-01.
*
* Other available API versions: 2023-05-02, 2023-08-15, 2024-04-13.
*
* ## Example Usage
* ### AttachedDatabaseConfigurationsCreateOrUpdate
*
*
* {@code
* package generated_program;
*
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.azurenative.kusto.AttachedDatabaseConfiguration;
* import com.pulumi.azurenative.kusto.AttachedDatabaseConfigurationArgs;
* import com.pulumi.azurenative.kusto.inputs.TableLevelSharingPropertiesArgs;
* 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 attachedDatabaseConfiguration = new AttachedDatabaseConfiguration("attachedDatabaseConfiguration", AttachedDatabaseConfigurationArgs.builder()
* .attachedDatabaseConfigurationName("attachedDatabaseConfigurationsTest")
* .clusterName("kustoCluster2")
* .clusterResourceId("/subscriptions/12345678-1234-1234-1234-123456789098/resourceGroups/kustorptest/providers/Microsoft.Kusto/Clusters/kustoCluster2")
* .databaseName("kustodatabase")
* .databaseNameOverride("overridekustodatabase")
* .defaultPrincipalsModificationKind("Union")
* .location("westus")
* .resourceGroupName("kustorptest")
* .tableLevelSharingProperties(TableLevelSharingPropertiesArgs.builder()
* .externalTablesToExclude("ExternalTable2")
* .externalTablesToInclude("ExternalTable1")
* .materializedViewsToExclude("MaterializedViewTable2")
* .materializedViewsToInclude("MaterializedViewTable1")
* .tablesToExclude("Table2")
* .tablesToInclude("Table1")
* .build())
* .build());
*
* }
* }
*
* }
*
*
* ## Import
*
* An existing resource can be imported using its type token, name, and identifier, e.g.
*
* ```sh
* $ pulumi import azure-native:kusto:AttachedDatabaseConfiguration kustoCluster2/attachedDatabaseConfigurationsTest /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Kusto/clusters/{clusterName}/attachedDatabaseConfigurations/{attachedDatabaseConfigurationName}
* ```
*
*/
@ResourceType(type="azure-native:kusto:AttachedDatabaseConfiguration")
public class AttachedDatabaseConfiguration extends com.pulumi.resources.CustomResource {
/**
* The list of databases from the clusterResourceId which are currently attached to the cluster.
*
*/
@Export(name="attachedDatabaseNames", refs={List.class,String.class}, tree="[0,1]")
private Output> attachedDatabaseNames;
/**
* @return The list of databases from the clusterResourceId which are currently attached to the cluster.
*
*/
public Output> attachedDatabaseNames() {
return this.attachedDatabaseNames;
}
/**
* The resource id of the cluster where the databases you would like to attach reside.
*
*/
@Export(name="clusterResourceId", refs={String.class}, tree="[0]")
private Output clusterResourceId;
/**
* @return The resource id of the cluster where the databases you would like to attach reside.
*
*/
public Output clusterResourceId() {
return this.clusterResourceId;
}
/**
* The name of the database which you would like to attach, use * if you want to follow all current and future databases.
*
*/
@Export(name="databaseName", refs={String.class}, tree="[0]")
private Output databaseName;
/**
* @return The name of the database which you would like to attach, use * if you want to follow all current and future databases.
*
*/
public Output databaseName() {
return this.databaseName;
}
/**
* Overrides the original database name. Relevant only when attaching to a specific database.
*
*/
@Export(name="databaseNameOverride", refs={String.class}, tree="[0]")
private Output* @Nullable */ String> databaseNameOverride;
/**
* @return Overrides the original database name. Relevant only when attaching to a specific database.
*
*/
public Output> databaseNameOverride() {
return Codegen.optional(this.databaseNameOverride);
}
/**
* Adds a prefix to the attached databases name. When following an entire cluster, that prefix would be added to all of the databases original names from leader cluster.
*
*/
@Export(name="databaseNamePrefix", refs={String.class}, tree="[0]")
private Output* @Nullable */ String> databaseNamePrefix;
/**
* @return Adds a prefix to the attached databases name. When following an entire cluster, that prefix would be added to all of the databases original names from leader cluster.
*
*/
public Output> databaseNamePrefix() {
return Codegen.optional(this.databaseNamePrefix);
}
/**
* The default principals modification kind
*
*/
@Export(name="defaultPrincipalsModificationKind", refs={String.class}, tree="[0]")
private Output defaultPrincipalsModificationKind;
/**
* @return The default principals modification kind
*
*/
public Output defaultPrincipalsModificationKind() {
return this.defaultPrincipalsModificationKind;
}
/**
* Resource location.
*
*/
@Export(name="location", refs={String.class}, tree="[0]")
private Output* @Nullable */ String> location;
/**
* @return Resource location.
*
*/
public Output> location() {
return Codegen.optional(this.location);
}
/**
* The name of the resource
*
*/
@Export(name="name", refs={String.class}, tree="[0]")
private Output name;
/**
* @return The name of the resource
*
*/
public Output name() {
return this.name;
}
/**
* The provisioned state of the resource.
*
*/
@Export(name="provisioningState", refs={String.class}, tree="[0]")
private Output provisioningState;
/**
* @return The provisioned state of the resource.
*
*/
public Output provisioningState() {
return this.provisioningState;
}
/**
* Table level sharing specifications
*
*/
@Export(name="tableLevelSharingProperties", refs={TableLevelSharingPropertiesResponse.class}, tree="[0]")
private Output* @Nullable */ TableLevelSharingPropertiesResponse> tableLevelSharingProperties;
/**
* @return Table level sharing specifications
*
*/
public Output> tableLevelSharingProperties() {
return Codegen.optional(this.tableLevelSharingProperties);
}
/**
* The type of the resource. E.g. "Microsoft.Compute/virtualMachines" or "Microsoft.Storage/storageAccounts"
*
*/
@Export(name="type", refs={String.class}, tree="[0]")
private Output type;
/**
* @return The type of the resource. E.g. "Microsoft.Compute/virtualMachines" or "Microsoft.Storage/storageAccounts"
*
*/
public Output type() {
return this.type;
}
/**
*
* @param name The _unique_ name of the resulting resource.
*/
public AttachedDatabaseConfiguration(java.lang.String name) {
this(name, AttachedDatabaseConfigurationArgs.Empty);
}
/**
*
* @param name The _unique_ name of the resulting resource.
* @param args The arguments to use to populate this resource's properties.
*/
public AttachedDatabaseConfiguration(java.lang.String name, AttachedDatabaseConfigurationArgs 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 AttachedDatabaseConfiguration(java.lang.String name, AttachedDatabaseConfigurationArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) {
super("azure-native:kusto:AttachedDatabaseConfiguration", name, makeArgs(args, options), makeResourceOptions(options, Codegen.empty()), false);
}
private AttachedDatabaseConfiguration(java.lang.String name, Output id, @Nullable com.pulumi.resources.CustomResourceOptions options) {
super("azure-native:kusto:AttachedDatabaseConfiguration", name, null, makeResourceOptions(options, id), false);
}
private static AttachedDatabaseConfigurationArgs makeArgs(AttachedDatabaseConfigurationArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) {
if (options != null && options.getUrn().isPresent()) {
return null;
}
return args == null ? AttachedDatabaseConfigurationArgs.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:kusto/v20190907:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20191109:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20200215:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20200614:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20200918:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20210101:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20210827:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20220201:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20220707:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20221111:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20221229:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20230502:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20230815:AttachedDatabaseConfiguration").build()),
Output.of(Alias.builder().type("azure-native:kusto/v20240413:AttachedDatabaseConfiguration").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 AttachedDatabaseConfiguration get(java.lang.String name, Output id, @Nullable com.pulumi.resources.CustomResourceOptions options) {
return new AttachedDatabaseConfiguration(name, id, options);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy