From 8f1acaf02603c6e9788da2613c29c9409e8a597c Mon Sep 17 00:00:00 2001 From: Luke Amdor Date: Tue, 14 Apr 2015 14:17:01 -0500 Subject: [PATCH 1/6] expose Route53 zone name servers --- builtin/providers/aws/resource_aws_route53_zone.go | 10 +++++++++- .../providers/aws/resource_aws_route53_zone_test.go | 9 +++++++++ 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/builtin/providers/aws/resource_aws_route53_zone.go b/builtin/providers/aws/resource_aws_route53_zone.go index a16a711b72c6..7dc6329a84d6 100644 --- a/builtin/providers/aws/resource_aws_route53_zone.go +++ b/builtin/providers/aws/resource_aws_route53_zone.go @@ -31,6 +31,12 @@ func resourceAwsRoute53Zone() *schema.Resource { Computed: true, }, + "delegation_set_name_servers": &schema.Schema{ + Type: schema.TypeList, + Elem: &schema.Schema{Type: schema.TypeString}, + Computed: true, + }, + "tags": tagsSchema(), }, } @@ -80,7 +86,7 @@ func resourceAwsRoute53ZoneCreate(d *schema.ResourceData, meta interface{}) erro func resourceAwsRoute53ZoneRead(d *schema.ResourceData, meta interface{}) error { r53 := meta.(*AWSClient).r53conn - _, err := r53.GetHostedZone(&route53.GetHostedZoneRequest{ID: aws.String(d.Id())}) + zone, err := r53.GetHostedZone(&route53.GetHostedZoneRequest{ID: aws.String(d.Id())}) if err != nil { // Handle a deleted zone if r53err, ok := err.(aws.APIError); ok && r53err.Code == "NoSuchHostedZone" { @@ -90,6 +96,8 @@ func resourceAwsRoute53ZoneRead(d *schema.ResourceData, meta interface{}) error return err } + d.Set("delegation_set_name_servers", zone.DelegationSet.NameServers) + // get tags req := &route53.ListTagsForResourceRequest{ ResourceID: aws.String(d.Id()), diff --git a/builtin/providers/aws/resource_aws_route53_zone_test.go b/builtin/providers/aws/resource_aws_route53_zone_test.go index 0669f88b1cde..a9b0225c78ce 100644 --- a/builtin/providers/aws/resource_aws_route53_zone_test.go +++ b/builtin/providers/aws/resource_aws_route53_zone_test.go @@ -114,6 +114,15 @@ func testAccCheckRoute53ZoneExists(n string, zone *route53.HostedZone) resource. if err != nil { return fmt.Errorf("Hosted zone err: %v", err) } + + for i, ns := range resp.DelegationSet.NameServers { + attribute := fmt.Sprintf("delegation_set_name_servers.%d", i) + dsns := rs.Primary.Attributes[attribute] + if dsns != ns { + return fmt.Errorf("Got: %v for %v, Expected: %v", dsns, attribute, ns) + } + } + *zone = *resp.HostedZone return nil } From a4e4ffb87f8df63591499c771aae55af03f54129 Mon Sep 17 00:00:00 2001 From: Luke Amdor Date: Tue, 14 Apr 2015 14:18:38 -0500 Subject: [PATCH 2/6] updating Route53 docs for parent nameserver change --- .../docs/providers/aws/r/route53_zone.html.markdown | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/website/source/docs/providers/aws/r/route53_zone.html.markdown b/website/source/docs/providers/aws/r/route53_zone.html.markdown index 7b0cf9388019..67a5f79f14b4 100644 --- a/website/source/docs/providers/aws/r/route53_zone.html.markdown +++ b/website/source/docs/providers/aws/r/route53_zone.html.markdown @@ -29,7 +29,6 @@ resource "aws_route53_zone" "main" { resource "aws_route53_zone" "dev" { name = "dev.example.com" - parent_route53_zone = "${aws_route53_zone.main.zone_id}" } resource "aws_route53_record" "dev-ns" { @@ -37,7 +36,12 @@ resource "aws_route53_record" "dev-ns" { name = "dev.example.com" type = "NS" ttl = "30" - records = ["127.0.0.1", "127.0.0.27"] + records = [ + "${aws_route53_zone.dev.delegation_set_name_servers.0}", + "${aws_route53_zone.dev.delegation_set_name_servers.1}", + "${aws_route53_zone.dev.delegation_set_name_servers.2}", + "${aws_route53_zone.dev.delegation_set_name_servers.3}" + ] } ``` From eb43822f68e00e84f78da09c7090243d6611c335 Mon Sep 17 00:00:00 2001 From: Luke Amdor Date: Tue, 14 Apr 2015 14:54:38 -0500 Subject: [PATCH 3/6] err-check the resource set --- builtin/providers/aws/resource_aws_route53_zone.go | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/builtin/providers/aws/resource_aws_route53_zone.go b/builtin/providers/aws/resource_aws_route53_zone.go index 7dc6329a84d6..4c0dcc6de149 100644 --- a/builtin/providers/aws/resource_aws_route53_zone.go +++ b/builtin/providers/aws/resource_aws_route53_zone.go @@ -1,6 +1,7 @@ package aws import ( + "fmt" "log" "strings" "time" @@ -96,7 +97,10 @@ func resourceAwsRoute53ZoneRead(d *schema.ResourceData, meta interface{}) error return err } - d.Set("delegation_set_name_servers", zone.DelegationSet.NameServers) + ns := zone.DelegationSet.NameServers + if err := d.Set("delegation_set_name_servers", ns); err != nil { + return fmt.Errorf("[DEBUG] Error setting name servers for: %s, error: %#v", zone, err) + } // get tags req := &route53.ListTagsForResourceRequest{ From b763294926594f54e9ab718f6ef5e175f863ec30 Mon Sep 17 00:00:00 2001 From: Luke Amdor Date: Tue, 14 Apr 2015 16:51:58 -0500 Subject: [PATCH 4/6] fixing string format --- builtin/providers/aws/resource_aws_route53_zone.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/builtin/providers/aws/resource_aws_route53_zone.go b/builtin/providers/aws/resource_aws_route53_zone.go index 4c0dcc6de149..f27617e9e73f 100644 --- a/builtin/providers/aws/resource_aws_route53_zone.go +++ b/builtin/providers/aws/resource_aws_route53_zone.go @@ -99,7 +99,7 @@ func resourceAwsRoute53ZoneRead(d *schema.ResourceData, meta interface{}) error ns := zone.DelegationSet.NameServers if err := d.Set("delegation_set_name_servers", ns); err != nil { - return fmt.Errorf("[DEBUG] Error setting name servers for: %s, error: %#v", zone, err) + return fmt.Errorf("[DEBUG] Error setting name servers for: %s, error: %#v", d.Id(), err) } // get tags From 46d3ab5ccd253fc65c2adcf888e44f67f3c76ffc Mon Sep 17 00:00:00 2001 From: Luke Amdor Date: Wed, 15 Apr 2015 16:07:50 -0500 Subject: [PATCH 5/6] rename delegation_set_name_servers to name_servers --- builtin/providers/aws/resource_aws_route53_zone.go | 4 ++-- builtin/providers/aws/resource_aws_route53_zone_test.go | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/builtin/providers/aws/resource_aws_route53_zone.go b/builtin/providers/aws/resource_aws_route53_zone.go index f27617e9e73f..eabec81e8be7 100644 --- a/builtin/providers/aws/resource_aws_route53_zone.go +++ b/builtin/providers/aws/resource_aws_route53_zone.go @@ -32,7 +32,7 @@ func resourceAwsRoute53Zone() *schema.Resource { Computed: true, }, - "delegation_set_name_servers": &schema.Schema{ + "name_servers": &schema.Schema{ Type: schema.TypeList, Elem: &schema.Schema{Type: schema.TypeString}, Computed: true, @@ -98,7 +98,7 @@ func resourceAwsRoute53ZoneRead(d *schema.ResourceData, meta interface{}) error } ns := zone.DelegationSet.NameServers - if err := d.Set("delegation_set_name_servers", ns); err != nil { + if err := d.Set("name_servers", ns); err != nil { return fmt.Errorf("[DEBUG] Error setting name servers for: %s, error: %#v", d.Id(), err) } diff --git a/builtin/providers/aws/resource_aws_route53_zone_test.go b/builtin/providers/aws/resource_aws_route53_zone_test.go index a9b0225c78ce..dcadf575c5d5 100644 --- a/builtin/providers/aws/resource_aws_route53_zone_test.go +++ b/builtin/providers/aws/resource_aws_route53_zone_test.go @@ -116,7 +116,7 @@ func testAccCheckRoute53ZoneExists(n string, zone *route53.HostedZone) resource. } for i, ns := range resp.DelegationSet.NameServers { - attribute := fmt.Sprintf("delegation_set_name_servers.%d", i) + attribute := fmt.Sprintf("name_servers.%d", i) dsns := rs.Primary.Attributes[attribute] if dsns != ns { return fmt.Errorf("Got: %v for %v, Expected: %v", dsns, attribute, ns) From f8b05fa05e78b29c913fd205d17e43215caf7f0d Mon Sep 17 00:00:00 2001 From: Luke Amdor Date: Wed, 15 Apr 2015 16:10:02 -0500 Subject: [PATCH 6/6] using a set for route53 name_servers --- builtin/providers/aws/resource_aws_route53_zone.go | 6 +++++- builtin/providers/aws/resource_aws_route53_zone_test.go | 5 +++-- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/builtin/providers/aws/resource_aws_route53_zone.go b/builtin/providers/aws/resource_aws_route53_zone.go index eabec81e8be7..c85577073e62 100644 --- a/builtin/providers/aws/resource_aws_route53_zone.go +++ b/builtin/providers/aws/resource_aws_route53_zone.go @@ -6,6 +6,7 @@ import ( "strings" "time" + "github.com/hashicorp/terraform/helper/hashcode" "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/helper/schema" @@ -33,9 +34,12 @@ func resourceAwsRoute53Zone() *schema.Resource { }, "name_servers": &schema.Schema{ - Type: schema.TypeList, + Type: schema.TypeSet, Elem: &schema.Schema{Type: schema.TypeString}, Computed: true, + Set: func(v interface{}) int { + return hashcode.String(v.(string)) + }, }, "tags": tagsSchema(), diff --git a/builtin/providers/aws/resource_aws_route53_zone_test.go b/builtin/providers/aws/resource_aws_route53_zone_test.go index dcadf575c5d5..e00b50ee6a13 100644 --- a/builtin/providers/aws/resource_aws_route53_zone_test.go +++ b/builtin/providers/aws/resource_aws_route53_zone_test.go @@ -4,6 +4,7 @@ import ( "fmt" "testing" + "github.com/hashicorp/terraform/helper/hashcode" "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/terraform" @@ -115,8 +116,8 @@ func testAccCheckRoute53ZoneExists(n string, zone *route53.HostedZone) resource. return fmt.Errorf("Hosted zone err: %v", err) } - for i, ns := range resp.DelegationSet.NameServers { - attribute := fmt.Sprintf("name_servers.%d", i) + for _, ns := range resp.DelegationSet.NameServers { + attribute := fmt.Sprintf("name_servers.%d", hashcode.String(ns)) dsns := rs.Primary.Attributes[attribute] if dsns != ns { return fmt.Errorf("Got: %v for %v, Expected: %v", dsns, attribute, ns)