SqlResourceSqlContainerArgs

data class SqlResourceSqlContainerArgs(val accountName: Output<String>? = null, val containerName: Output<String>? = null, val databaseName: Output<String>? = null, val location: Output<String>? = null, val options: Output<CreateUpdateOptionsArgs>? = null, val resource: Output<SqlContainerResourceArgs>? = null, val resourceGroupName: Output<String>? = null, val tags: Output<Map<String, String>>? = null) : ConvertibleToJava<SqlResourceSqlContainerArgs>

An Azure Cosmos DB container. Uses Azure REST API version 2023-04-15. In version 1.x of the Azure Native provider, it used API version 2021-03-15. Other available API versions: 2023-03-15-preview, 2023-09-15, 2023-09-15-preview, 2023-11-15, 2023-11-15-preview, 2024-02-15-preview, 2024-05-15, 2024-05-15-preview, 2024-08-15, 2024-09-01-preview, 2024-11-15, 2024-12-01-preview.

Example Usage

CosmosDBSqlContainerCreateUpdate

using System.Collections.Generic;
using System.Linq;
using Pulumi;
using AzureNative = Pulumi.AzureNative;
return await Deployment.RunAsync(() =>
{
var sqlResourceSqlContainer = new AzureNative.DocumentDB.SqlResourceSqlContainer("sqlResourceSqlContainer", new()
{
AccountName = "ddb1",
ContainerName = "containerName",
DatabaseName = "databaseName",
Location = "West US",
Options = null,
Resource = new AzureNative.DocumentDB.Inputs.SqlContainerResourceArgs
{
ClientEncryptionPolicy = new AzureNative.DocumentDB.Inputs.ClientEncryptionPolicyArgs
{
IncludedPaths = new[]
{
new AzureNative.DocumentDB.Inputs.ClientEncryptionIncludedPathArgs
{
ClientEncryptionKeyId = "keyId",
EncryptionAlgorithm = "AEAD_AES_256_CBC_HMAC_SHA256",
EncryptionType = "Deterministic",
Path = "/path",
},
},
PolicyFormatVersion = 2,
},
ConflictResolutionPolicy = new AzureNative.DocumentDB.Inputs.ConflictResolutionPolicyArgs
{
ConflictResolutionPath = "/path",
Mode = AzureNative.DocumentDB.ConflictResolutionMode.LastWriterWins,
},
DefaultTtl = 100,
Id = "containerName",
IndexingPolicy = new AzureNative.DocumentDB.Inputs.IndexingPolicyArgs
{
Automatic = true,
ExcludedPaths = new() { },
IncludedPaths = new[]
{
new AzureNative.DocumentDB.Inputs.IncludedPathArgs
{
Indexes = new[]
{
new AzureNative.DocumentDB.Inputs.IndexesArgs
{
DataType = AzureNative.DocumentDB.DataType.String,
Kind = AzureNative.DocumentDB.IndexKind.Range,
Precision = -1,
},
new AzureNative.DocumentDB.Inputs.IndexesArgs
{
DataType = AzureNative.DocumentDB.DataType.Number,
Kind = AzureNative.DocumentDB.IndexKind.Range,
Precision = -1,
},
},
Path = "/*",
},
},
IndexingMode = AzureNative.DocumentDB.IndexingMode.Consistent,
},
PartitionKey = new AzureNative.DocumentDB.Inputs.ContainerPartitionKeyArgs
{
Kind = AzureNative.DocumentDB.PartitionKind.Hash,
Paths = new[]
{
"/AccountNumber",
},
},
UniqueKeyPolicy = new AzureNative.DocumentDB.Inputs.UniqueKeyPolicyArgs
{
UniqueKeys = new[]
{
new AzureNative.DocumentDB.Inputs.UniqueKeyArgs
{
Paths = new[]
{
"/testPath",
},
},
},
},
},
ResourceGroupName = "rg1",
Tags = null,
});
});
package main
import (
documentdb "github.com/pulumi/pulumi-azure-native-sdk/documentdb/v2"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := documentdb.NewSqlResourceSqlContainer(ctx, "sqlResourceSqlContainer", &documentdb.SqlResourceSqlContainerArgs{
AccountName: pulumi.String("ddb1"),
ContainerName: pulumi.String("containerName"),
DatabaseName: pulumi.String("databaseName"),
Location: pulumi.String("West US"),
Options: &documentdb.CreateUpdateOptionsArgs{},
Resource: &documentdb.SqlContainerResourceArgs{
ClientEncryptionPolicy: &documentdb.ClientEncryptionPolicyArgs{
IncludedPaths: documentdb.ClientEncryptionIncludedPathArray{
&documentdb.ClientEncryptionIncludedPathArgs{
ClientEncryptionKeyId: pulumi.String("keyId"),
EncryptionAlgorithm: pulumi.String("AEAD_AES_256_CBC_HMAC_SHA256"),
EncryptionType: pulumi.String("Deterministic"),
Path: pulumi.String("/path"),
},
},
PolicyFormatVersion: pulumi.Int(2),
},
ConflictResolutionPolicy: &documentdb.ConflictResolutionPolicyArgs{
ConflictResolutionPath: pulumi.String("/path"),
Mode: pulumi.String(documentdb.ConflictResolutionModeLastWriterWins),
},
DefaultTtl: pulumi.Int(100),
Id: pulumi.String("containerName"),
IndexingPolicy: &documentdb.IndexingPolicyArgs{
Automatic: pulumi.Bool(true),
ExcludedPaths: documentdb.ExcludedPathArray{},
IncludedPaths: documentdb.IncludedPathArray{
&documentdb.IncludedPathArgs{
Indexes: documentdb.IndexesArray{
&documentdb.IndexesArgs{
DataType: pulumi.String(documentdb.DataTypeString),
Kind: pulumi.String(documentdb.IndexKindRange),
Precision: pulumi.Int(-1),
},
&documentdb.IndexesArgs{
DataType: pulumi.String(documentdb.DataTypeNumber),
Kind: pulumi.String(documentdb.IndexKindRange),
Precision: pulumi.Int(-1),
},
},
Path: pulumi.String("/*"),
},
},
IndexingMode: pulumi.String(documentdb.IndexingModeConsistent),
},
PartitionKey: &documentdb.ContainerPartitionKeyArgs{
Kind: pulumi.String(documentdb.PartitionKindHash),
Paths: pulumi.StringArray{
pulumi.String("/AccountNumber"),
},
},
UniqueKeyPolicy: &documentdb.UniqueKeyPolicyArgs{
UniqueKeys: documentdb.UniqueKeyArray{
&documentdb.UniqueKeyArgs{
Paths: pulumi.StringArray{
pulumi.String("/testPath"),
},
},
},
},
},
ResourceGroupName: pulumi.String("rg1"),
Tags: pulumi.StringMap{},
})
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azurenative.documentdb.SqlResourceSqlContainer;
import com.pulumi.azurenative.documentdb.SqlResourceSqlContainerArgs;
import com.pulumi.azurenative.documentdb.inputs.CreateUpdateOptionsArgs;
import com.pulumi.azurenative.documentdb.inputs.SqlContainerResourceArgs;
import com.pulumi.azurenative.documentdb.inputs.ClientEncryptionPolicyArgs;
import com.pulumi.azurenative.documentdb.inputs.ConflictResolutionPolicyArgs;
import com.pulumi.azurenative.documentdb.inputs.IndexingPolicyArgs;
import com.pulumi.azurenative.documentdb.inputs.ContainerPartitionKeyArgs;
import com.pulumi.azurenative.documentdb.inputs.UniqueKeyPolicyArgs;
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 sqlResourceSqlContainer = new SqlResourceSqlContainer("sqlResourceSqlContainer", SqlResourceSqlContainerArgs.builder()
.accountName("ddb1")
.containerName("containerName")
.databaseName("databaseName")
.location("West US")
.options()
.resource(SqlContainerResourceArgs.builder()
.clientEncryptionPolicy(ClientEncryptionPolicyArgs.builder()
.includedPaths(ClientEncryptionIncludedPathArgs.builder()
.clientEncryptionKeyId("keyId")
.encryptionAlgorithm("AEAD_AES_256_CBC_HMAC_SHA256")
.encryptionType("Deterministic")
.path("/path")
.build())
.policyFormatVersion(2)
.build())
.conflictResolutionPolicy(ConflictResolutionPolicyArgs.builder()
.conflictResolutionPath("/path")
.mode("LastWriterWins")
.build())
.defaultTtl(100)
.id("containerName")
.indexingPolicy(IndexingPolicyArgs.builder()
.automatic(true)
.excludedPaths()
.includedPaths(IncludedPathArgs.builder()
.indexes(
IndexesArgs.builder()
.dataType("String")
.kind("Range")
.precision(-1)
.build(),
IndexesArgs.builder()
.dataType("Number")
.kind("Range")
.precision(-1)
.build())
.path("/*")
.build())
.indexingMode("consistent")
.build())
.partitionKey(ContainerPartitionKeyArgs.builder()
.kind("Hash")
.paths("/AccountNumber")
.build())
.uniqueKeyPolicy(UniqueKeyPolicyArgs.builder()
.uniqueKeys(UniqueKeyArgs.builder()
.paths("/testPath")
.build())
.build())
.build())
.resourceGroupName("rg1")
.tags()
.build());
}
}

Import

An existing resource can be imported using its type token, name, and identifier, e.g.

$ pulumi import azure-native:documentdb:SqlResourceSqlContainer containerName /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DocumentDB/databaseAccounts/{accountName}/sqlDatabases/{databaseName}/containers/{containerName}

Constructors

Link copied to clipboard
constructor(accountName: Output<String>? = null, containerName: Output<String>? = null, databaseName: Output<String>? = null, location: Output<String>? = null, options: Output<CreateUpdateOptionsArgs>? = null, resource: Output<SqlContainerResourceArgs>? = null, resourceGroupName: Output<String>? = null, tags: Output<Map<String, String>>? = null)

Properties

Link copied to clipboard
val accountName: Output<String>? = null

Cosmos DB database account name.

Link copied to clipboard
val containerName: Output<String>? = null

Cosmos DB container name.

Link copied to clipboard
val databaseName: Output<String>? = null

Cosmos DB database name.

Link copied to clipboard
val location: Output<String>? = null

The location of the resource group to which the resource belongs.

Link copied to clipboard
val options: Output<CreateUpdateOptionsArgs>? = null

A key-value pair of options to be applied for the request. This corresponds to the headers sent with the request.

Link copied to clipboard
val resource: Output<SqlContainerResourceArgs>? = null

The standard JSON format of a container

Link copied to clipboard
val resourceGroupName: Output<String>? = null

The name of the resource group. The name is case insensitive.

Link copied to clipboard
val tags: Output<Map<String, String>>? = null

Tags are a list of key-value pairs that describe the resource. These tags can be used in viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key no greater than 128 characters and value no greater than 256 characters. For example, the default experience for a template type is set with "defaultExperience": "Cassandra". Current "defaultExperience" values also include "Table", "Graph", "DocumentDB", and "MongoDB". //*/

Functions

Link copied to clipboard
open override fun toJava(): SqlResourceSqlContainerArgs