From 10aa825f5eb7bcc1a1b9ca636f7e305bb2ffae08 Mon Sep 17 00:00:00 2001 From: njucz Date: Thu, 15 Jul 2021 18:47:41 -0500 Subject: [PATCH] "azurerm_data_factory" - supports property "managed_virtual_network_enabled" (#12343) fix #10542 --- .../services/datafactory/client/client.go | 29 ++++++---- .../datafactory/data_factory_resource.go | 49 ++++++++++++++++ .../datafactory/data_factory_resource_test.go | 57 +++++++++++++++++++ website/docs/r/data_factory.html.markdown | 2 + 4 files changed, 125 insertions(+), 12 deletions(-) diff --git a/azurerm/internal/services/datafactory/client/client.go b/azurerm/internal/services/datafactory/client/client.go index 2ad8d5e5bc5c..bd9a2f92148f 100644 --- a/azurerm/internal/services/datafactory/client/client.go +++ b/azurerm/internal/services/datafactory/client/client.go @@ -6,12 +6,13 @@ import ( ) type Client struct { - DatasetClient *datafactory.DatasetsClient - FactoriesClient *datafactory.FactoriesClient - IntegrationRuntimesClient *datafactory.IntegrationRuntimesClient - LinkedServiceClient *datafactory.LinkedServicesClient - PipelinesClient *datafactory.PipelinesClient - TriggersClient *datafactory.TriggersClient + DatasetClient *datafactory.DatasetsClient + FactoriesClient *datafactory.FactoriesClient + IntegrationRuntimesClient *datafactory.IntegrationRuntimesClient + LinkedServiceClient *datafactory.LinkedServicesClient + ManagedVirtualNetworksClient *datafactory.ManagedVirtualNetworksClient + PipelinesClient *datafactory.PipelinesClient + TriggersClient *datafactory.TriggersClient } func NewClient(o *common.ClientOptions) *Client { @@ -27,6 +28,9 @@ func NewClient(o *common.ClientOptions) *Client { LinkedServiceClient := datafactory.NewLinkedServicesClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId) o.ConfigureClient(&LinkedServiceClient.Client, o.ResourceManagerAuthorizer) + ManagedVirtualNetworksClient := datafactory.NewManagedVirtualNetworksClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId) + o.ConfigureClient(&ManagedVirtualNetworksClient.Client, o.ResourceManagerAuthorizer) + PipelinesClient := datafactory.NewPipelinesClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId) o.ConfigureClient(&PipelinesClient.Client, o.ResourceManagerAuthorizer) @@ -34,11 +38,12 @@ func NewClient(o *common.ClientOptions) *Client { o.ConfigureClient(&TriggersClient.Client, o.ResourceManagerAuthorizer) return &Client{ - DatasetClient: &DatasetClient, - FactoriesClient: &FactoriesClient, - IntegrationRuntimesClient: &IntegrationRuntimesClient, - LinkedServiceClient: &LinkedServiceClient, - PipelinesClient: &PipelinesClient, - TriggersClient: &TriggersClient, + DatasetClient: &DatasetClient, + FactoriesClient: &FactoriesClient, + IntegrationRuntimesClient: &IntegrationRuntimesClient, + LinkedServiceClient: &LinkedServiceClient, + ManagedVirtualNetworksClient: &ManagedVirtualNetworksClient, + PipelinesClient: &PipelinesClient, + TriggersClient: &TriggersClient, } } diff --git a/azurerm/internal/services/datafactory/data_factory_resource.go b/azurerm/internal/services/datafactory/data_factory_resource.go index dd57d13abdf8..191c5192313c 100644 --- a/azurerm/internal/services/datafactory/data_factory_resource.go +++ b/azurerm/internal/services/datafactory/data_factory_resource.go @@ -1,6 +1,7 @@ package datafactory import ( + "context" "fmt" "time" @@ -207,6 +208,11 @@ func resourceDataFactory() *pluginsdk.Resource { }, }, + "managed_virtual_network_enabled": { + Type: pluginsdk.TypeBool, + Optional: true, + }, + "public_network_enabled": { Type: pluginsdk.TypeBool, Optional: true, @@ -227,6 +233,7 @@ func resourceDataFactory() *pluginsdk.Resource { func resourceDataFactoryCreateUpdate(d *pluginsdk.ResourceData, meta interface{}) error { client := meta.(*clients.Client).DataFactory.FactoriesClient + managedVirtualNetworksClient := meta.(*clients.Client).DataFactory.ManagedVirtualNetworksClient subscriptionId := meta.(*clients.Client).Account.SubscriptionId ctx, cancel := timeouts.ForCreateUpdate(meta.(*clients.Client).StopContext, d) defer cancel() @@ -316,6 +323,24 @@ func resourceDataFactoryCreateUpdate(d *pluginsdk.ResourceData, meta interface{} } } + managedVirtualNetworkEnabled := d.Get("managed_virtual_network_enabled").(bool) + // only pass datafactory.ManagedVirtualNetworkResource{} will cause rest api error + resource := datafactory.ManagedVirtualNetworkResource{ + Properties: &datafactory.ManagedVirtualNetwork{}, + } + if d.IsNewResource() && managedVirtualNetworkEnabled { + if _, err := managedVirtualNetworksClient.CreateOrUpdate(ctx, id.ResourceGroup, id.FactoryName, "default", resource, ""); err != nil { + return fmt.Errorf("creating virtual network for %s: %+v", id, err) + } + } else if !d.IsNewResource() && d.HasChange("managed_virtual_network_enabled") { + if !managedVirtualNetworkEnabled { + return fmt.Errorf("updating %s: once Managed Virtual Network has been Enabled it's not possible to disable it", id) + } + if _, err := managedVirtualNetworksClient.CreateOrUpdate(ctx, id.ResourceGroup, id.FactoryName, "default", resource, ""); err != nil { + return fmt.Errorf("creating virtual network for %s: %+v", id, err) + } + } + d.SetId(id.ID()) return resourceDataFactoryRead(d, meta) @@ -323,6 +348,7 @@ func resourceDataFactoryCreateUpdate(d *pluginsdk.ResourceData, meta interface{} func resourceDataFactoryRead(d *pluginsdk.ResourceData, meta interface{}) error { client := meta.(*clients.Client).DataFactory.FactoriesClient + managedVirtualNetworksClient := meta.(*clients.Client).DataFactory.ManagedVirtualNetworksClient ctx, cancel := timeouts.ForRead(meta.(*clients.Client).StopContext, d) defer cancel() @@ -393,6 +419,16 @@ func resourceDataFactoryRead(d *pluginsdk.ResourceData, meta interface{}) error d.Set("public_network_enabled", resp.PublicNetworkAccess == datafactory.PublicNetworkAccessEnabled) } + managedVirtualNetworkEnabled := false + managedVirtualNetworkName, err := getManagedVirtualNetworkName(ctx, managedVirtualNetworksClient, id.ResourceGroup, id.FactoryName) + if err != nil { + return err + } + if managedVirtualNetworkName != nil { + managedVirtualNetworkEnabled = true + } + d.Set("managed_virtual_network_enabled", managedVirtualNetworkEnabled) + return tags.FlattenAndSet(d, resp.Tags) } @@ -577,3 +613,16 @@ func flattenDataFactoryGlobalParameters(input map[string]*datafactory.GlobalPara } return result } + +// Only one VNet is allowed per factory +func getManagedVirtualNetworkName(ctx context.Context, client *datafactory.ManagedVirtualNetworksClient, resourceGroup, factoryName string) (*string, error) { + resp, err := client.ListByFactory(ctx, resourceGroup, factoryName) + if err != nil { + return nil, err + } + if len(resp.Values()) == 0 { + return nil, nil + } + managedVirtualNetwork := resp.Values()[0] + return managedVirtualNetwork.Name, nil +} diff --git a/azurerm/internal/services/datafactory/data_factory_resource_test.go b/azurerm/internal/services/datafactory/data_factory_resource_test.go index e423be78681e..70f8a649e542 100644 --- a/azurerm/internal/services/datafactory/data_factory_resource_test.go +++ b/azurerm/internal/services/datafactory/data_factory_resource_test.go @@ -238,6 +238,43 @@ func TestAccDataFactory_globalParameterUpdate(t *testing.T) { }) } +func TestAccDataFactory_managedVirtualNetwork(t *testing.T) { + data := acceptance.BuildTestData(t, "azurerm_data_factory", "test") + r := DataFactoryResource{} + + data.ResourceTest(t, r, []acceptance.TestStep{ + { + Config: r.managedVirtualNetwork(data), + Check: acceptance.ComposeTestCheckFunc( + check.That(data.ResourceName).ExistsInAzure(r), + ), + }, + data.ImportStep(), + }) +} + +func TestAccDataFactory_managedVirtualNetworkUpdated(t *testing.T) { + data := acceptance.BuildTestData(t, "azurerm_data_factory", "test") + r := DataFactoryResource{} + + data.ResourceTest(t, r, []acceptance.TestStep{ + { + Config: r.basic(data), + Check: acceptance.ComposeTestCheckFunc( + check.That(data.ResourceName).ExistsInAzure(r), + ), + }, + data.ImportStep(), + { + Config: r.managedVirtualNetwork(data), + Check: acceptance.ComposeTestCheckFunc( + check.That(data.ResourceName).ExistsInAzure(r), + ), + }, + data.ImportStep(), + }) +} + func (t DataFactoryResource) Exists(ctx context.Context, clients *clients.Client, state *pluginsdk.InstanceState) (*bool, error) { id, err := parse.DataFactoryID(state.ID) if err != nil { @@ -602,3 +639,23 @@ resource "azurerm_data_factory" "test" { } `, data.RandomInteger, data.Locations.Primary, data.RandomInteger) } + +func (DataFactoryResource) managedVirtualNetwork(data acceptance.TestData) string { + return fmt.Sprintf(` +provider "azurerm" { + features {} +} + +resource "azurerm_resource_group" "test" { + name = "acctestRG-df-%d" + location = "%s" +} + +resource "azurerm_data_factory" "test" { + name = "acctestDF%d" + location = azurerm_resource_group.test.location + resource_group_name = azurerm_resource_group.test.name + managed_virtual_network_enabled = true +} +`, data.RandomInteger, data.Locations.Primary, data.RandomInteger) +} diff --git a/website/docs/r/data_factory.html.markdown b/website/docs/r/data_factory.html.markdown index 1d76288fa733..8e5450170f43 100644 --- a/website/docs/r/data_factory.html.markdown +++ b/website/docs/r/data_factory.html.markdown @@ -43,6 +43,8 @@ The following arguments are supported: * `vsts_configuration` - (Optional) A `vsts_configuration` block as defined below. +* `managed_virtual_network_enabled` - (Optional) Is Managed Virtual Network enabled? + * `public_network_enabled` - (Optional) Is the Data Factory visible to the public network? Defaults to `true`. * `customer_managed_key_id` - (Optional) Specifies the Azure Key Vault Key ID to be used as the Customer Managed Key (CMK) for double encryption. Required with user assigned identity.