Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SDK12: Migrating Networking over to the new SDK #738

Merged
merged 5 commits into from
Jan 23, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
211 changes: 81 additions & 130 deletions azurerm/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ import (
"github.com/Azure/azure-sdk-for-go/arm/cosmos-db"
"github.com/Azure/azure-sdk-for-go/arm/disk"
"github.com/Azure/azure-sdk-for-go/arm/keyvault"
"github.com/Azure/azure-sdk-for-go/arm/network"
keyVault "github.com/Azure/azure-sdk-for-go/dataplane/keyvault"
appinsights "github.com/Azure/azure-sdk-for-go/services/appinsights/mgmt/2015-05-01/insights"
"github.com/Azure/azure-sdk-for-go/services/authorization/mgmt/2015-07-01/authorization"
Expand All @@ -28,6 +27,7 @@ import (
"github.com/Azure/azure-sdk-for-go/services/eventhub/mgmt/2017-04-01/eventhub"
"github.com/Azure/azure-sdk-for-go/services/graphrbac/1.6/graphrbac"
"github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-04-30-preview/mysql"
"github.com/Azure/azure-sdk-for-go/services/network/mgmt/2017-09-01/network"
"github.com/Azure/azure-sdk-for-go/services/operationalinsights/mgmt/2015-11-01-preview/operationalinsights"
"github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-04-30-preview/postgresql"
"github.com/Azure/azure-sdk-for-go/services/redis/mgmt/2016-04-01/redis"
Expand Down Expand Up @@ -78,24 +78,8 @@ type ArmClient struct {
automationCredentialClient automation.CredentialClient
automationScheduleClient automation.ScheduleClient

applicationGatewayClient network.ApplicationGatewaysClient
ifaceClient network.InterfacesClient
expressRouteCircuitClient network.ExpressRouteCircuitsClient
loadBalancerClient network.LoadBalancersClient
localNetConnClient network.LocalNetworkGatewaysClient
publicIPClient network.PublicIPAddressesClient
secGroupClient network.SecurityGroupsClient
secRuleClient network.SecurityRulesClient
subnetClient network.SubnetsClient
netUsageClient network.UsagesClient
vnetGatewayConnectionsClient network.VirtualNetworkGatewayConnectionsClient
vnetGatewayClient network.VirtualNetworkGatewaysClient
vnetClient network.VirtualNetworksClient
vnetPeeringsClient network.VirtualNetworkPeeringsClient
routeTablesClient network.RouteTablesClient
routesClient network.RoutesClient
dnsClient dns.RecordSetsClient
zonesClient dns.ZonesClient
dnsClient dns.RecordSetsClient
zonesClient dns.ZonesClient

containerRegistryClient containerregistry.RegistriesClient
containerServicesClient containerservice.ContainerServicesClient
Expand Down Expand Up @@ -142,7 +126,23 @@ type ArmClient struct {
sqlServersClient sql.ServersClient

// Networking
watcherClient network.WatchersClient
applicationGatewayClient network.ApplicationGatewaysClient
expressRouteCircuitClient network.ExpressRouteCircuitsClient
ifaceClient network.InterfacesClient
loadBalancerClient network.LoadBalancersClient
localNetConnClient network.LocalNetworkGatewaysClient
publicIPClient network.PublicIPAddressesClient
routesClient network.RoutesClient
routeTablesClient network.RouteTablesClient
secGroupClient network.SecurityGroupsClient
secRuleClient network.SecurityRulesClient
subnetClient network.SubnetsClient
netUsageClient network.UsagesClient
vnetGatewayConnectionsClient network.VirtualNetworkGatewayConnectionsClient
vnetGatewayClient network.VirtualNetworkGatewaysClient
vnetClient network.VirtualNetworksClient
vnetPeeringsClient network.VirtualNetworkPeeringsClient
watcherClient network.WatchersClient

// Resources
managementLocksClient locks.ManagementLocksClient
Expand Down Expand Up @@ -367,13 +367,6 @@ func getArmClient(c *authentication.Config) (*ArmClient, error) {
vmc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.vmClient = vmc

agc := network.NewApplicationGatewaysClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&agc.Client)
agc.Authorizer = auth
agc.Sender = sender
agc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.applicationGatewayClient = agc

csc := containerservice.NewContainerServicesClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&csc.Client)
csc.Authorizer = auth
Expand All @@ -395,104 +388,6 @@ func getArmClient(c *authentication.Config) (*ArmClient, error) {
img.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.imageClient = img

ifc := network.NewInterfacesClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&ifc.Client)
ifc.Authorizer = auth
ifc.Sender = sender
ifc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.ifaceClient = ifc

erc := network.NewExpressRouteCircuitsClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&erc.Client)
erc.Authorizer = auth
erc.Sender = sender
erc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.expressRouteCircuitClient = erc

lbc := network.NewLoadBalancersClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&lbc.Client)
lbc.Authorizer = auth
lbc.Sender = sender
lbc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.loadBalancerClient = lbc

lgc := network.NewLocalNetworkGatewaysClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&lgc.Client)
lgc.Authorizer = auth
lgc.Sender = sender
lgc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.localNetConnClient = lgc

pipc := network.NewPublicIPAddressesClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&pipc.Client)
pipc.Authorizer = auth
pipc.Sender = sender
pipc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.publicIPClient = pipc

sgc := network.NewSecurityGroupsClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&sgc.Client)
sgc.Authorizer = auth
sgc.Sender = sender
sgc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.secGroupClient = sgc

src := network.NewSecurityRulesClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&src.Client)
src.Authorizer = auth
src.Sender = sender
src.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.secRuleClient = src

snc := network.NewSubnetsClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&snc.Client)
snc.Authorizer = auth
snc.Sender = sender
snc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.subnetClient = snc

vgcc := network.NewVirtualNetworkGatewayConnectionsClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&vgcc.Client)
vgcc.Authorizer = auth
vgcc.Sender = sender
vgcc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.vnetGatewayConnectionsClient = vgcc

vgc := network.NewVirtualNetworkGatewaysClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&vgc.Client)
vgc.Authorizer = auth
vgc.Sender = sender
vgc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.vnetGatewayClient = vgc

vnc := network.NewVirtualNetworksClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&vnc.Client)
vnc.Authorizer = auth
vnc.Sender = sender
vnc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.vnetClient = vnc

vnpc := network.NewVirtualNetworkPeeringsClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&vnpc.Client)
vnpc.Authorizer = auth
vnpc.Sender = sender
vnpc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.vnetPeeringsClient = vnpc

rtc := network.NewRouteTablesClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&rtc.Client)
rtc.Authorizer = auth
rtc.Sender = sender
rtc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.routeTablesClient = rtc

rc := network.NewRoutesClientWithBaseURI(endpoint, c.SubscriptionID)
setUserAgent(&rc.Client)
rc.Authorizer = auth
rc.Sender = sender
rc.SkipResourceProviderRegistration = c.SkipProviderRegistration
client.routesClient = rc

client.registerAppInsightsClient(endpoint, c.SubscriptionID, auth, sender)
client.registerAutomationClients(endpoint, c.SubscriptionID, auth, sender)
client.registerAuthentication(endpoint, graphEndpoint, c.SubscriptionID, c.TenantID, auth, graphAuth, sender)
Expand Down Expand Up @@ -760,12 +655,68 @@ func (c *ArmClient) registerKeyVaultClients(endpoint, subscriptionId string, aut
}

func (c *ArmClient) registerNetworkingClients(endpoint, subscriptionId string, auth autorest.Authorizer, sender autorest.Sender) {
// TODO: move the other networking stuff in here, gradually
applicationGatewaysClient := network.NewApplicationGatewaysClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&applicationGatewaysClient.Client, auth)
c.applicationGatewayClient = applicationGatewaysClient

expressRouteCircuitsClient := network.NewExpressRouteCircuitsClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&expressRouteCircuitsClient.Client, auth)
c.expressRouteCircuitClient = expressRouteCircuitsClient

interfacesClient := network.NewInterfacesClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&interfacesClient.Client, auth)
c.ifaceClient = interfacesClient

loadBalancersClient := network.NewLoadBalancersClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&loadBalancersClient.Client, auth)
c.loadBalancerClient = loadBalancersClient

localNetworkGatewaysClient := network.NewLocalNetworkGatewaysClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&localNetworkGatewaysClient.Client, auth)
c.localNetConnClient = localNetworkGatewaysClient

gatewaysClient := network.NewVirtualNetworkGatewaysClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&gatewaysClient.Client, auth)
c.vnetGatewayClient = gatewaysClient

gatewayConnectionsClient := network.NewVirtualNetworkGatewayConnectionsClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&gatewayConnectionsClient.Client, auth)
c.vnetGatewayConnectionsClient = gatewayConnectionsClient

networksClient := network.NewVirtualNetworksClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&networksClient.Client, auth)
c.vnetClient = networksClient

peeringsClient := network.NewVirtualNetworkPeeringsClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&peeringsClient.Client, auth)
c.vnetPeeringsClient = peeringsClient

publicIPAddressesClient := network.NewPublicIPAddressesClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&publicIPAddressesClient.Client, auth)
c.publicIPClient = publicIPAddressesClient

routesClient := network.NewRoutesClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&routesClient.Client, auth)
c.routesClient = routesClient

routeTablesClient := network.NewRouteTablesClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&routeTablesClient.Client, auth)
c.routeTablesClient = routeTablesClient

securityGroupsClient := network.NewSecurityGroupsClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&securityGroupsClient.Client, auth)
c.secGroupClient = securityGroupsClient

securityRulesClient := network.NewSecurityRulesClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&securityRulesClient.Client, auth)
c.secRuleClient = securityRulesClient

subnetsClient := network.NewSubnetsClientWithBaseURI(endpoint, subscriptionId)
c.configureClient(&subnetsClient.Client, auth)
c.subnetClient = subnetsClient

watchersClient := network.NewWatchersClientWithBaseURI(endpoint, subscriptionId)
setUserAgent(&watchersClient.Client)
watchersClient.Authorizer = auth
watchersClient.Sender = sender
watchersClient.SkipResourceProviderRegistration = c.skipProviderRegistration
c.configureClient(&watchersClient.Client, auth)
c.watcherClient = watchersClient
}

Expand Down
3 changes: 2 additions & 1 deletion azurerm/data_source_network_security_group.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,11 +85,12 @@ func dataSourceArmNetworkSecurityGroup() *schema.Resource {

func dataSourceArmNetworkSecurityGroupRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*ArmClient).secGroupClient
ctx := meta.(*ArmClient).StopContext

resourceGroup := d.Get("resource_group_name").(string)
name := d.Get("name").(string)

resp, err := client.Get(resourceGroup, name, "")
resp, err := client.Get(ctx, resourceGroup, name, "")
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
d.SetId("")
Expand Down
9 changes: 5 additions & 4 deletions azurerm/data_source_public_ip.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@ package azurerm

import (
"fmt"
"net/http"

"github.com/hashicorp/terraform/helper/schema"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/utils"
)

func dataSourceArmPublicIP() *schema.Resource {
Expand Down Expand Up @@ -44,14 +44,15 @@ func dataSourceArmPublicIP() *schema.Resource {
}

func dataSourceArmPublicIPRead(d *schema.ResourceData, meta interface{}) error {
publicIPClient := meta.(*ArmClient).publicIPClient
client := meta.(*ArmClient).publicIPClient
ctx := meta.(*ArmClient).StopContext

resGroup := d.Get("resource_group_name").(string)
name := d.Get("name").(string)

resp, err := publicIPClient.Get(resGroup, name, "")
resp, err := client.Get(ctx, resGroup, name, "")
if err != nil {
if resp.StatusCode == http.StatusNotFound {
if utils.ResponseWasNotFound(resp.Response) {
d.SetId("")
}
return fmt.Errorf("Error making Read request on Azure public ip %s: %s", name, err)
Expand Down
3 changes: 2 additions & 1 deletion azurerm/data_source_subnet.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,12 +53,13 @@ func dataSourceArmSubnet() *schema.Resource {

func dataSourceArmSubnetRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*ArmClient).subnetClient
ctx := meta.(*ArmClient).StopContext

name := d.Get("name").(string)
virtualNetworkName := d.Get("virtual_network_name").(string)
resourceGroupName := d.Get("resource_group_name").(string)

resp, err := client.Get(resourceGroupName, virtualNetworkName, name, "")
resp, err := client.Get(ctx, resourceGroupName, virtualNetworkName, name, "")
if err != nil {
return fmt.Errorf("Error reading Subnet: %+v", err)
}
Expand Down
5 changes: 3 additions & 2 deletions azurerm/data_source_virtual_network.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ package azurerm
import (
"fmt"

"github.com/Azure/azure-sdk-for-go/arm/network"
"github.com/Azure/azure-sdk-for-go/services/network/mgmt/2017-09-01/network"
"github.com/hashicorp/terraform/helper/schema"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/utils"
)
Expand Down Expand Up @@ -56,11 +56,12 @@ func dataSourceArmVirtualNetwork() *schema.Resource {

func dataSourceArmVnetRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*ArmClient).vnetClient
ctx := meta.(*ArmClient).StopContext

resGroup := d.Get("resource_group_name").(string)
name := d.Get("name").(string)

resp, err := client.Get(resGroup, name, "")
resp, err := client.Get(ctx, resGroup, name, "")
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
return fmt.Errorf("Error making Read request on Azure virtual network %q (resource group %q): %+v", name, resGroup, err)
Expand Down
5 changes: 3 additions & 2 deletions azurerm/express_route_circuit.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ package azurerm
import (
"fmt"

"github.com/Azure/azure-sdk-for-go/arm/network"
"github.com/Azure/azure-sdk-for-go/services/network/mgmt/2017-09-01/network"
"github.com/hashicorp/errwrap"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/utils"
)
Expand All @@ -22,13 +22,14 @@ func extractResourceGroupAndErcName(resourceId string) (resourceGroup string, na

func retrieveErcByResourceId(resourceId string, meta interface{}) (erc *network.ExpressRouteCircuit, resourceGroup string, e error) {
ercClient := meta.(*ArmClient).expressRouteCircuitClient
ctx := meta.(*ArmClient).StopContext

resGroup, name, err := extractResourceGroupAndErcName(resourceId)
if err != nil {
return nil, "", errwrap.Wrapf("Error Parsing Azure Resource ID - {{err}}", err)
}

resp, err := ercClient.Get(resGroup, name)
resp, err := ercClient.Get(ctx, resGroup, name)
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
return nil, "", nil
Expand Down
Loading