From 2a9fd57926cb2bcaffec8baddbd6d7ec7c4f7826 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=87a=C4=9Fatay=20G=C3=BCrt=C3=BCrk?= Date: Sun, 30 Aug 2020 19:12:49 +0200 Subject: [PATCH] Use cloud.json to find out cloud-netblocks Fixes #6996 --- .../data_source_google_netblock_ip_ranges.go | 82 +------------------ 1 file changed, 4 insertions(+), 78 deletions(-) diff --git a/google/data_source_google_netblock_ip_ranges.go b/google/data_source_google_netblock_ip_ranges.go index 21f5bde46b7..b1e824ee87d 100644 --- a/google/data_source_google_netblock_ip_ranges.go +++ b/google/data_source_google_netblock_ip_ranges.go @@ -3,11 +3,9 @@ package google import ( "encoding/json" "fmt" + "github.com/hashicorp/terraform-plugin-sdk/helper/schema" "io/ioutil" "net/http" - "strings" - - "github.com/hashicorp/terraform-plugin-sdk/helper/schema" ) type googRanges struct { @@ -58,9 +56,9 @@ func dataSourceGoogleNetblockIpRangesRead(d *schema.ResourceData, meta interface switch rt { // Dynamic ranges case "cloud-netblocks": - // https://cloud.google.com/compute/docs/faq#where_can_i_find_product_name_short_ip_ranges - const CLOUD_NETBLOCK_DNS = "_cloud-netblocks.googleusercontent.com" - CidrBlocks, err := getCidrBlocksFromDns(CLOUD_NETBLOCK_DNS) + // https://cloud.google.com/compute/docs/faq#find_ip_range + const CLOUD_NETBLOCK_URL = "https://www.gstatic.com/ipranges/cloud.json" + CidrBlocks, err := getCidrBlocksFromUrl(CLOUD_NETBLOCK_URL) if err != nil { return err @@ -128,78 +126,6 @@ func dataSourceGoogleNetblockIpRangesRead(d *schema.ResourceData, meta interface return nil } -func netblock_request(name string) (string, error) { - response, err := http.Get(fmt.Sprintf("https://dns.google.com/resolve?name=%s&type=TXT", name)) - - if err != nil { - return "", fmt.Errorf("Error from _cloud-netblocks: %s", err) - } - - defer response.Body.Close() - body, err := ioutil.ReadAll(response.Body) - - if err != nil { - return "", fmt.Errorf("Error to retrieve the domains list: %s", err) - } - - return string(body), nil -} - -func getCidrBlocksFromDns(netblock string) (map[string][]string, error) { - var dnsNetblockList []string - cidrBlocks := make(map[string][]string) - - response, err := netblock_request(netblock) - - if err != nil { - return nil, err - } - - splitedResponse := strings.Split(response, " ") - - for _, sp := range splitedResponse { - if strings.HasPrefix(sp, "include:") { - dnsNetblock := strings.Replace(sp, "include:", "", 1) - dnsNetblockList = append(dnsNetblockList, dnsNetblock) - } - } - - for len(dnsNetblockList) > 0 { - - dnsNetblock := dnsNetblockList[0] - - dnsNetblockList[0] = "" - dnsNetblockList = dnsNetblockList[1:] - - response, err = netblock_request(dnsNetblock) - - if err != nil { - return nil, err - } - - splitedResponse = strings.Split(response, " ") - - for _, sp := range splitedResponse { - if strings.HasPrefix(sp, "ip4") { - cdrBlock := strings.Replace(sp, "ip4:", "", 1) - cidrBlocks["cidr_blocks_ipv4"] = append(cidrBlocks["cidr_blocks_ipv4"], cdrBlock) - cidrBlocks["cidr_blocks"] = append(cidrBlocks["cidr_blocks"], cdrBlock) - - } else if strings.HasPrefix(sp, "ip6") { - cdrBlock := strings.Replace(sp, "ip6:", "", 1) - cidrBlocks["cidr_blocks_ipv6"] = append(cidrBlocks["cidr_blocks_ipv6"], cdrBlock) - cidrBlocks["cidr_blocks"] = append(cidrBlocks["cidr_blocks"], cdrBlock) - - } else if strings.HasPrefix(sp, "include:") { - cidr_block := strings.Replace(sp, "include:", "", 1) - dnsNetblockList = append(dnsNetblockList, cidr_block) - } - } - } - - return cidrBlocks, nil -} - func getCidrBlocksFromUrl(url string) (map[string][]string, error) { cidrBlocks := make(map[string][]string)