Remove existing records in gcloud (#308)

When record already exists in gcloud we can't add a new record without removing the other one first. This is a simple fix that doesn't attempt to create multiple entries for the record but just removes the previous data.

fixes #218
This commit is contained in:
Matthew Buckett 2016-11-02 14:47:17 +00:00 committed by xenolf
parent 85200a157c
commit 501b7b6e0f
2 changed files with 24 additions and 0 deletions

View file

@ -68,6 +68,16 @@ func (c *DNSProvider) Present(domain, token, keyAuth string) error {
Additions: []*dns.ResourceRecordSet{rec}, Additions: []*dns.ResourceRecordSet{rec},
} }
// Look for existing records.
list, err := c.client.ResourceRecordSets.List(c.project, zone).Name(fqdn).Type("TXT").Do()
if err != nil {
return err
}
if len(list.Rrsets) > 0 {
// Attempt to delete the existing records when adding our new one.
change.Deletions = list.Rrsets
}
chg, err := c.client.Changes.Create(c.project, zone, change).Do() chg, err := c.client.Changes.Create(c.project, zone, change).Do()
if err != nil { if err != nil {
return err return err

View file

@ -70,6 +70,20 @@ func TestLiveGoogleCloudPresent(t *testing.T) {
assert.NoError(t, err) assert.NoError(t, err)
} }
func TestLiveGoogleCloudPresentMultiple(t *testing.T) {
if !gcloudLiveTest {
t.Skip("skipping live test")
}
provider, err := NewDNSProviderCredentials(gcloudProject)
assert.NoError(t, err)
// Check that we're able to create multiple entries
err = provider.Present(gcloudDomain, "1", "123d==")
err = provider.Present(gcloudDomain, "2", "123d==")
assert.NoError(t, err)
}
func TestLiveGoogleCloudCleanUp(t *testing.T) { func TestLiveGoogleCloudCleanUp(t *testing.T) {
if !gcloudLiveTest { if !gcloudLiveTest {
t.Skip("skipping live test") t.Skip("skipping live test")