LinkedServiceAzureBlobStorageArgs

data class LinkedServiceAzureBlobStorageArgs(val additionalProperties: Output<Map<String, String>>? = null, val annotations: Output<List<String>>? = null, val connectionString: Output<String>? = null, val connectionStringInsecure: Output<String>? = null, val dataFactoryId: Output<String>? = null, val description: Output<String>? = null, val integrationRuntimeName: Output<String>? = null, val keyVaultSasToken: Output<LinkedServiceAzureBlobStorageKeyVaultSasTokenArgs>? = null, val name: Output<String>? = null, val parameters: Output<Map<String, String>>? = null, val sasUri: Output<String>? = null, val serviceEndpoint: Output<String>? = null, val servicePrincipalId: Output<String>? = null, val servicePrincipalKey: Output<String>? = null, val servicePrincipalLinkedKeyVaultKey: Output<LinkedServiceAzureBlobStorageServicePrincipalLinkedKeyVaultKeyArgs>? = null, val storageKind: Output<String>? = null, val tenantId: Output<String>? = null, val useManagedIdentity: Output<Boolean>? = null) : ConvertibleToJava<LinkedServiceAzureBlobStorageArgs>

Manages a Linked Service (connection) between an Azure Blob Storage Account and Azure Data Factory.

Example Usage

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.storage.StorageFunctions;
import com.pulumi.azure.storage.inputs.GetAccountArgs;
import com.pulumi.azure.datafactory.Factory;
import com.pulumi.azure.datafactory.FactoryArgs;
import com.pulumi.azure.datafactory.LinkedServiceAzureBlobStorage;
import com.pulumi.azure.datafactory.LinkedServiceAzureBlobStorageArgs;
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 exampleResourceGroup = new ResourceGroup("exampleResourceGroup", ResourceGroupArgs.builder()
.location("West Europe")
.build());
final var exampleAccount = StorageFunctions.getAccount(GetAccountArgs.builder()
.name("storageaccountname")
.resourceGroupName(exampleResourceGroup.name())
.build());
var exampleFactory = new Factory("exampleFactory", FactoryArgs.builder()
.location(exampleResourceGroup.location())
.resourceGroupName(exampleResourceGroup.name())
.build());
var exampleLinkedServiceAzureBlobStorage = new LinkedServiceAzureBlobStorage("exampleLinkedServiceAzureBlobStorage", LinkedServiceAzureBlobStorageArgs.builder()
.dataFactoryId(exampleFactory.id())
.connectionString(exampleAccount.applyValue(getAccountResult -> getAccountResult).applyValue(exampleAccount -> exampleAccount.applyValue(getAccountResult -> getAccountResult.primaryConnectionString())))
.build());
}
}

With SAS URI And SAS Token

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.core.CoreFunctions;
import com.pulumi.azure.datafactory.Factory;
import com.pulumi.azure.datafactory.FactoryArgs;
import com.pulumi.azure.keyvault.KeyVault;
import com.pulumi.azure.keyvault.KeyVaultArgs;
import com.pulumi.azure.datafactory.LinkedServiceKeyVault;
import com.pulumi.azure.datafactory.LinkedServiceKeyVaultArgs;
import com.pulumi.azure.datafactory.LinkedServiceAzureBlobStorage;
import com.pulumi.azure.datafactory.LinkedServiceAzureBlobStorageArgs;
import com.pulumi.azure.datafactory.inputs.LinkedServiceAzureBlobStorageKeyVaultSasTokenArgs;
import com.pulumi.azure.datafactory.inputs.LinkedServiceAzureBlobStorageServicePrincipalLinkedKeyVaultKeyArgs;
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()
.location("West Europe")
.build());
final var current = CoreFunctions.getClientConfig();
var testFactory = new Factory("testFactory", FactoryArgs.builder()
.location(example.location())
.resourceGroupName(example.name())
.build());
var testKeyVault = new KeyVault("testKeyVault", KeyVaultArgs.builder()
.location(example.location())
.resourceGroupName(example.name())
.tenantId(current.applyValue(getClientConfigResult -> getClientConfigResult.tenantId()))
.skuName("standard")
.build());
var testLinkedServiceKeyVault = new LinkedServiceKeyVault("testLinkedServiceKeyVault", LinkedServiceKeyVaultArgs.builder()
.dataFactoryId(testFactory.id())
.keyVaultId(testKeyVault.id())
.build());
var testLinkedServiceAzureBlobStorage = new LinkedServiceAzureBlobStorage("testLinkedServiceAzureBlobStorage", LinkedServiceAzureBlobStorageArgs.builder()
.dataFactoryId(testFactory.id())
.sasUri("https://example.blob.core.windows.net")
.keyVaultSasToken(LinkedServiceAzureBlobStorageKeyVaultSasTokenArgs.builder()
.linkedServiceName(testLinkedServiceKeyVault.name())
.secretName("secret")
.build())
.build());
var testDatafactory_linkedServiceAzureBlobStorageLinkedServiceAzureBlobStorage = new LinkedServiceAzureBlobStorage("testDatafactory/linkedServiceAzureBlobStorageLinkedServiceAzureBlobStorage", LinkedServiceAzureBlobStorageArgs.builder()
.dataFactoryId(testFactory.id())
.serviceEndpoint("https://example.blob.core.windows.net")
.servicePrincipalId("00000000-0000-0000-0000-000000000000")
.tenantId("00000000-0000-0000-0000-000000000000")
.servicePrincipalLinkedKeyVaultKey(LinkedServiceAzureBlobStorageServicePrincipalLinkedKeyVaultKeyArgs.builder()
.linkedServiceName(testLinkedServiceKeyVault.name())
.secretName("secret")
.build())
.build());
}
}

Import

Data Factory Linked Service's can be imported using the resource id, e.g.

$ pulumi import azure:datafactory/linkedServiceAzureBlobStorage:LinkedServiceAzureBlobStorage example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/example/providers/Microsoft.DataFactory/factories/example/linkedservices/example

Constructors

Link copied to clipboard
fun LinkedServiceAzureBlobStorageArgs(additionalProperties: Output<Map<String, String>>? = null, annotations: Output<List<String>>? = null, connectionString: Output<String>? = null, connectionStringInsecure: Output<String>? = null, dataFactoryId: Output<String>? = null, description: Output<String>? = null, integrationRuntimeName: Output<String>? = null, keyVaultSasToken: Output<LinkedServiceAzureBlobStorageKeyVaultSasTokenArgs>? = null, name: Output<String>? = null, parameters: Output<Map<String, String>>? = null, sasUri: Output<String>? = null, serviceEndpoint: Output<String>? = null, servicePrincipalId: Output<String>? = null, servicePrincipalKey: Output<String>? = null, servicePrincipalLinkedKeyVaultKey: Output<LinkedServiceAzureBlobStorageServicePrincipalLinkedKeyVaultKeyArgs>? = null, storageKind: Output<String>? = null, tenantId: Output<String>? = null, useManagedIdentity: Output<Boolean>? = null)

Functions

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

Properties

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

A map of additional properties to associate with the Data Factory Linked Service. The following supported arguments are specific to Azure Blob Storage Linked Service:

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

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

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

The connection string. Conflicts with connection_string_insecure, sas_uri and service_endpoint.

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

The connection string sent insecurely. Conflicts with connection_string, sas_uri and service_endpoint.

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

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

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

The description for the Data Factory Linked Service.

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

The integration runtime reference to associate with the Data Factory Linked Service.

Link copied to clipboard

A key_vault_sas_token block as defined below. Use this argument to store SAS Token in an existing Key Vault. It needs an existing Key Vault Data Factory Linked Service. A sas_uri is required.

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

Specifies the name of the Data Factory Linked Service. Changing this forces a new resource to be created. Must be unique within a data factory. 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 Linked Service.

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

The SAS URI. Conflicts with connection_string_insecure, connection_string and service_endpoint.

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

The Service Endpoint. Conflicts with connection_string, connection_string_insecure and sas_uri.

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

The service principal id in which to authenticate against the Azure Blob Storage account.

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

The service principal key in which to authenticate against the AAzure Blob Storage account.

Link copied to clipboard

A service_principal_linked_key_vault_key block as defined below. Use this argument to store Service Principal key in an existing Key Vault. It needs an existing Key Vault Data Factory Linked Service.

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

Specify the kind of the storage account. Allowed values are Storage, StorageV2, BlobStorage and BlockBlobStorage.

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

The tenant id or name in which to authenticate against the Azure Blob Storage account.

Link copied to clipboard
val useManagedIdentity: Output<Boolean>? = null

Whether to use the Data Factory's managed identity to authenticate against the Azure Blob Storage account. Incompatible with service_principal_id and service_principal_key.