CustomDatasetArgs

data class CustomDatasetArgs(val additionalProperties: Output<Map<String, String>>? = null, val annotations: Output<List<String>>? = null, val dataFactoryId: Output<String>? = null, val description: Output<String>? = null, val folder: Output<String>? = null, val linkedService: Output<CustomDatasetLinkedServiceArgs>? = null, val name: Output<String>? = null, val parameters: Output<Map<String, String>>? = null, val schemaJson: Output<String>? = null, val type: Output<String>? = null, val typePropertiesJson: Output<String>? = null) : ConvertibleToJava<CustomDatasetArgs>

Manages a Dataset inside an Azure Data Factory. This is a generic resource that supports all different Dataset Types.

Example Usage

import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
name: "example-resources",
location: "West Europe",
});
const exampleFactory = new azure.datafactory.Factory("example", {
name: "example",
location: example.location,
resourceGroupName: example.name,
identity: {
type: "SystemAssigned",
},
});
const exampleAccount = new azure.storage.Account("example", {
name: "example",
resourceGroupName: example.name,
location: example.location,
accountKind: "BlobStorage",
accountTier: "Standard",
accountReplicationType: "LRS",
});
const exampleLinkedCustomService = new azure.datafactory.LinkedCustomService("example", {
name: "example",
dataFactoryId: exampleFactory.id,
type: "AzureBlobStorage",
typePropertiesJson: pulumi.interpolate`{
"connectionString":"${exampleAccount.primaryConnectionString}"
}
`,
});
const exampleContainer = new azure.storage.Container("example", {
name: "content",
storageAccountName: exampleAccount.name,
containerAccessType: "private",
});
const exampleCustomDataset = new azure.datafactory.CustomDataset("example", {
name: "example",
dataFactoryId: exampleFactory.id,
type: "Json",
linkedService: {
name: exampleLinkedCustomService.name,
parameters: {
key1: "value1",
},
},
typePropertiesJson: pulumi.interpolate`{
"location": {
"container":"${exampleContainer.name}",
"fileName":"foo.txt",
"folderPath": "foo/bar/",
"type":"AzureBlobStorageLocation"
},
"encodingName":"UTF-8"
}
`,
description: "test description",
annotations: [
"test1",
"test2",
"test3",
],
folder: "testFolder",
parameters: {
foo: "test1",
Bar: "Test2",
},
additionalProperties: {
foo: "test1",
bar: "test2",
},
schemaJson: `{
"type": "object",
"properties": {
"name": {
"type": "object",
"properties": {
"firstName": {
"type": "string"
},
"lastName": {
"type": "string"
}
}
},
"age": {
"type": "integer"
}
}
}
`,
});
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
name="example-resources",
location="West Europe")
example_factory = azure.datafactory.Factory("example",
name="example",
location=example.location,
resource_group_name=example.name,
identity={
"type": "SystemAssigned",
})
example_account = azure.storage.Account("example",
name="example",
resource_group_name=example.name,
location=example.location,
account_kind="BlobStorage",
account_tier="Standard",
account_replication_type="LRS")
example_linked_custom_service = azure.datafactory.LinkedCustomService("example",
name="example",
data_factory_id=example_factory.id,
type="AzureBlobStorage",
type_properties_json=example_account.primary_connection_string.apply(lambda primary_connection_string: f"""{{
"connectionString":"{primary_connection_string}"
}}
"""))
example_container = azure.storage.Container("example",
name="content",
storage_account_name=example_account.name,
container_access_type="private")
example_custom_dataset = azure.datafactory.CustomDataset("example",
name="example",
data_factory_id=example_factory.id,
type="Json",
linked_service={
"name": example_linked_custom_service.name,
"parameters": {
"key1": "value1",
},
},
type_properties_json=example_container.name.apply(lambda name: f"""{{
"location": {{
"container":"{name}",
"fileName":"foo.txt",
"folderPath": "foo/bar/",
"type":"AzureBlobStorageLocation"
}},
"encodingName":"UTF-8"
}}
"""),
description="test description",
annotations=[
"test1",
"test2",
"test3",
],
folder="testFolder",
parameters={
"foo": "test1",
"Bar": "Test2",
},
additional_properties={
"foo": "test1",
"bar": "test2",
},
schema_json="""{
"type": "object",
"properties": {
"name": {
"type": "object",
"properties": {
"firstName": {
"type": "string"
},
"lastName": {
"type": "string"
}
}
},
"age": {
"type": "integer"
}
}
}
""")
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
return await Deployment.RunAsync(() =>
{
var example = new Azure.Core.ResourceGroup("example", new()
{
Name = "example-resources",
Location = "West Europe",
});
var exampleFactory = new Azure.DataFactory.Factory("example", new()
{
Name = "example",
Location = example.Location,
ResourceGroupName = example.Name,
Identity = new Azure.DataFactory.Inputs.FactoryIdentityArgs
{
Type = "SystemAssigned",
},
});
var exampleAccount = new Azure.Storage.Account("example", new()
{
Name = "example",
ResourceGroupName = example.Name,
Location = example.Location,
AccountKind = "BlobStorage",
AccountTier = "Standard",
AccountReplicationType = "LRS",
});
var exampleLinkedCustomService = new Azure.DataFactory.LinkedCustomService("example", new()
{
Name = "example",
DataFactoryId = exampleFactory.Id,
Type = "AzureBlobStorage",
TypePropertiesJson = exampleAccount.PrimaryConnectionString.Apply(primaryConnectionString => @$"{{
""connectionString"":""{primaryConnectionString}""
}}
"),
});
var exampleContainer = new Azure.Storage.Container("example", new()
{
Name = "content",
StorageAccountName = exampleAccount.Name,
ContainerAccessType = "private",
});
var exampleCustomDataset = new Azure.DataFactory.CustomDataset("example", new()
{
Name = "example",
DataFactoryId = exampleFactory.Id,
Type = "Json",
LinkedService = new Azure.DataFactory.Inputs.CustomDatasetLinkedServiceArgs
{
Name = exampleLinkedCustomService.Name,
Parameters =
{
{ "key1", "value1" },
},
},
TypePropertiesJson = exampleContainer.Name.Apply(name => @$"{{
""location"": {{
""container"":""{name}"",
""fileName"":""foo.txt"",
""folderPath"": ""foo/bar/"",
""type"":""AzureBlobStorageLocation""
}},
""encodingName"":""UTF-8""
}}
"),
Description = "test description",
Annotations = new[]
{
"test1",
"test2",
"test3",
},
Folder = "testFolder",
Parameters =
{
{ "foo", "test1" },
{ "Bar", "Test2" },
},
AdditionalProperties =
{
{ "foo", "test1" },
{ "bar", "test2" },
},
SchemaJson = @"{
""type"": ""object"",
""properties"": {
""name"": {
""type"": ""object"",
""properties"": {
""firstName"": {
""type"": ""string""
},
""lastName"": {
""type"": ""string""
}
}
},
""age"": {
""type"": ""integer""
}
}
}
",
});
});
package main
import (
"fmt"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/datafactory"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/storage"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
Name: pulumi.String("example-resources"),
Location: pulumi.String("West Europe"),
})
if err != nil {
return err
}
exampleFactory, err := datafactory.NewFactory(ctx, "example", &datafactory.FactoryArgs{
Name: pulumi.String("example"),
Location: example.Location,
ResourceGroupName: example.Name,
Identity: &datafactory.FactoryIdentityArgs{
Type: pulumi.String("SystemAssigned"),
},
})
if err != nil {
return err
}
exampleAccount, err := storage.NewAccount(ctx, "example", &storage.AccountArgs{
Name: pulumi.String("example"),
ResourceGroupName: example.Name,
Location: example.Location,
AccountKind: pulumi.String("BlobStorage"),
AccountTier: pulumi.String("Standard"),
AccountReplicationType: pulumi.String("LRS"),
})
if err != nil {
return err
}
exampleLinkedCustomService, err := datafactory.NewLinkedCustomService(ctx, "example", &datafactory.LinkedCustomServiceArgs{
Name: pulumi.String("example"),
DataFactoryId: exampleFactory.ID(),
Type: pulumi.String("AzureBlobStorage"),
TypePropertiesJson: exampleAccount.PrimaryConnectionString.ApplyT(func(primaryConnectionString string) (string, error) {
return fmt.Sprintf("{\n \"connectionString\":\"%v\"\n}\n", primaryConnectionString), nil
}).(pulumi.StringOutput),
})
if err != nil {
return err
}
exampleContainer, err := storage.NewContainer(ctx, "example", &storage.ContainerArgs{
Name: pulumi.String("content"),
StorageAccountName: exampleAccount.Name,
ContainerAccessType: pulumi.String("private"),
})
if err != nil {
return err
}
_, err = datafactory.NewCustomDataset(ctx, "example", &datafactory.CustomDatasetArgs{
Name: pulumi.String("example"),
DataFactoryId: exampleFactory.ID(),
Type: pulumi.String("Json"),
LinkedService: &datafactory.CustomDatasetLinkedServiceArgs{
Name: exampleLinkedCustomService.Name,
Parameters: pulumi.StringMap{
"key1": pulumi.String("value1"),
},
},
TypePropertiesJson: exampleContainer.Name.ApplyT(func(name string) (string, error) {
return fmt.Sprintf(`{
"location": {
"container":"%v",
"fileName":"foo.txt",
"folderPath": "foo/bar/",
"type":"AzureBlobStorageLocation"
},
"encodingName":"UTF-8"
}
`, name), nil
}).(pulumi.StringOutput),
Description: pulumi.String("test description"),
Annotations: pulumi.StringArray{
pulumi.String("test1"),
pulumi.String("test2"),
pulumi.String("test3"),
},
Folder: pulumi.String("testFolder"),
Parameters: pulumi.StringMap{
"foo": pulumi.String("test1"),
"Bar": pulumi.String("Test2"),
},
AdditionalProperties: pulumi.StringMap{
"foo": pulumi.String("test1"),
"bar": pulumi.String("test2"),
},
SchemaJson: pulumi.String(`{
"type": "object",
"properties": {
"name": {
"type": "object",
"properties": {
"firstName": {
"type": "string"
},
"lastName": {
"type": "string"
}
}
},
"age": {
"type": "integer"
}
}
}
`),
})
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.azure.core.ResourceGroup;
import com.pulumi.azure.core.ResourceGroupArgs;
import com.pulumi.azure.datafactory.Factory;
import com.pulumi.azure.datafactory.FactoryArgs;
import com.pulumi.azure.datafactory.inputs.FactoryIdentityArgs;
import com.pulumi.azure.storage.Account;
import com.pulumi.azure.storage.AccountArgs;
import com.pulumi.azure.datafactory.LinkedCustomService;
import com.pulumi.azure.datafactory.LinkedCustomServiceArgs;
import com.pulumi.azure.storage.Container;
import com.pulumi.azure.storage.ContainerArgs;
import com.pulumi.azure.datafactory.CustomDataset;
import com.pulumi.azure.datafactory.CustomDatasetArgs;
import com.pulumi.azure.datafactory.inputs.CustomDatasetLinkedServiceArgs;
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 example = new ResourceGroup("example", ResourceGroupArgs.builder()
.name("example-resources")
.location("West Europe")
.build());
var exampleFactory = new Factory("exampleFactory", FactoryArgs.builder()
.name("example")
.location(example.location())
.resourceGroupName(example.name())
.identity(FactoryIdentityArgs.builder()
.type("SystemAssigned")
.build())
.build());
var exampleAccount = new Account("exampleAccount", AccountArgs.builder()
.name("example")
.resourceGroupName(example.name())
.location(example.location())
.accountKind("BlobStorage")
.accountTier("Standard")
.accountReplicationType("LRS")
.build());
var exampleLinkedCustomService = new LinkedCustomService("exampleLinkedCustomService", LinkedCustomServiceArgs.builder()
.name("example")
.dataFactoryId(exampleFactory.id())
.type("AzureBlobStorage")
.typePropertiesJson(exampleAccount.primaryConnectionString().applyValue(primaryConnectionString -> """
{
"connectionString":"%s"
}
", primaryConnectionString)))
.build());
var exampleContainer = new Container("exampleContainer", ContainerArgs.builder()
.name("content")
.storageAccountName(exampleAccount.name())
.containerAccessType("private")
.build());
var exampleCustomDataset = new CustomDataset("exampleCustomDataset", CustomDatasetArgs.builder()
.name("example")
.dataFactoryId(exampleFactory.id())
.type("Json")
.linkedService(CustomDatasetLinkedServiceArgs.builder()
.name(exampleLinkedCustomService.name())
.parameters(Map.of("key1", "value1"))
.build())
.typePropertiesJson(exampleContainer.name().applyValue(name -> """
{
"location": {
"container":"%s",
"fileName":"foo.txt",
"folderPath": "foo/bar/",
"type":"AzureBlobStorageLocation"
},
"encodingName":"UTF-8"
}
", name)))
.description("test description")
.annotations(
"test1",
"test2",
"test3")
.folder("testFolder")
.parameters(Map.ofEntries(
Map.entry("foo", "test1"),
Map.entry("Bar", "Test2")
))
.additionalProperties(Map.ofEntries(
Map.entry("foo", "test1"),
Map.entry("bar", "test2")
))
.schemaJson("""
{
"type": "object",
"properties": {
"name": {
"type": "object",
"properties": {
"firstName": {
"type": "string"
},
"lastName": {
"type": "string"
}
}
},
"age": {
"type": "integer"
}
}
}
""")
.build());
}
}
resources:
example:
type: azure:core:ResourceGroup
properties:
name: example-resources
location: West Europe
exampleFactory:
type: azure:datafactory:Factory
name: example
properties:
name: example
location: ${example.location}
resourceGroupName: ${example.name}
identity:
type: SystemAssigned
exampleAccount:
type: azure:storage:Account
name: example
properties:
name: example
resourceGroupName: ${example.name}
location: ${example.location}
accountKind: BlobStorage
accountTier: Standard
accountReplicationType: LRS
exampleLinkedCustomService:
type: azure:datafactory:LinkedCustomService
name: example
properties:
name: example
dataFactoryId: ${exampleFactory.id}
type: AzureBlobStorage
typePropertiesJson: |
{
"connectionString":"${exampleAccount.primaryConnectionString}"
}
exampleContainer:
type: azure:storage:Container
name: example
properties:
name: content
storageAccountName: ${exampleAccount.name}
containerAccessType: private
exampleCustomDataset:
type: azure:datafactory:CustomDataset
name: example
properties:
name: example
dataFactoryId: ${exampleFactory.id}
type: Json
linkedService:
name: ${exampleLinkedCustomService.name}
parameters:
key1: value1
typePropertiesJson: |
{
"location": {
"container":"${exampleContainer.name}",
"fileName":"foo.txt",
"folderPath": "foo/bar/",
"type":"AzureBlobStorageLocation"
},
"encodingName":"UTF-8"
}
description: test description
annotations:
- test1
- test2
- test3
folder: testFolder
parameters:
foo: test1
Bar: Test2
additionalProperties:
foo: test1
bar: test2
schemaJson: |
{
"type": "object",
"properties": {
"name": {
"type": "object",
"properties": {
"firstName": {
"type": "string"
},
"lastName": {
"type": "string"
}
}
},
"age": {
"type": "integer"
}
}
}

Import

Data Factory Datasets can be imported using the resource id, e.g.

$ pulumi import azure:datafactory/customDataset:CustomDataset example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/example/providers/Microsoft.DataFactory/factories/example/datasets/example

Constructors

Link copied to clipboard
constructor(additionalProperties: Output<Map<String, String>>? = null, annotations: Output<List<String>>? = null, dataFactoryId: Output<String>? = null, description: Output<String>? = null, folder: Output<String>? = null, linkedService: Output<CustomDatasetLinkedServiceArgs>? = null, name: Output<String>? = null, parameters: Output<Map<String, String>>? = null, schemaJson: Output<String>? = null, type: Output<String>? = null, typePropertiesJson: Output<String>? = null)

Properties

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

A map of additional properties to associate with the Data Factory Dataset.

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

List of tags that can be used for describing the Data Factory Dataset.

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

The Data Factory ID in which to associate the Dataset with. Changing this forces a new resource.

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

The description for the Data Factory Dataset.

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

The folder that this Dataset is in. If not specified, the Dataset will appear at the root level.

Link copied to clipboard

A linked_service block as defined below.

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

Specifies the name of the Data Factory Dataset. Changing this forces a new resource to be created. Must be globally unique. See the Microsoft documentation for all restrictions.

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

A map of parameters to associate with the Data Factory Dataset.

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

A JSON object that contains the schema of the Data Factory Dataset.

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

The type of dataset that will be associated with Data Factory. Changing this forces a new resource to be created.

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

A JSON object that contains the properties of the Data Factory Dataset.

Functions

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