digitalocean: LEGO_EXPERIMENTAL_CNAME_SUPPORT support (#885)

This commit is contained in:
Zimbo Boyd 2019-05-14 15:20:49 +02:00 committed by Ludovic Fernandez
parent b9bafc582c
commit a0d59b85fe
2 changed files with 10 additions and 5 deletions

View file

@ -57,10 +57,10 @@ func (d *DNSProvider) removeTxtRecord(domain string, recordID int) error {
return nil return nil
} }
func (d *DNSProvider) addTxtRecord(domain, fqdn, value string) (*txtRecordResponse, error) { func (d *DNSProvider) addTxtRecord(fqdn, value string) (*txtRecordResponse, error) {
authZone, err := dns01.FindZoneByFqdn(dns01.ToFqdn(domain)) authZone, err := dns01.FindZoneByFqdn(dns01.ToFqdn(fqdn))
if err != nil { if err != nil {
return nil, fmt.Errorf("could not determine zone for domain: '%s'. %s", domain, err) return nil, fmt.Errorf("could not determine zone for domain: '%s'. %s", fqdn, err)
} }
reqData := record{Type: "TXT", Name: fqdn, Data: value, TTL: d.config.TTL} reqData := record{Type: "TXT", Name: fqdn, Data: value, TTL: d.config.TTL}

View file

@ -88,7 +88,7 @@ func (d *DNSProvider) Timeout() (timeout, interval time.Duration) {
func (d *DNSProvider) Present(domain, token, keyAuth string) error { func (d *DNSProvider) Present(domain, token, keyAuth string) error {
fqdn, value := dns01.GetRecord(domain, keyAuth) fqdn, value := dns01.GetRecord(domain, keyAuth)
respData, err := d.addTxtRecord(domain, fqdn, value) respData, err := d.addTxtRecord(fqdn, value)
if err != nil { if err != nil {
return fmt.Errorf("digitalocean: %v", err) return fmt.Errorf("digitalocean: %v", err)
} }
@ -104,6 +104,11 @@ func (d *DNSProvider) Present(domain, token, keyAuth string) error {
func (d *DNSProvider) CleanUp(domain, token, keyAuth string) error { func (d *DNSProvider) CleanUp(domain, token, keyAuth string) error {
fqdn, _ := dns01.GetRecord(domain, keyAuth) fqdn, _ := dns01.GetRecord(domain, keyAuth)
authZone, err := dns01.FindZoneByFqdn(fqdn)
if err != nil {
return fmt.Errorf("digitalocean: %v", err)
}
// get the record's unique ID from when we created it // get the record's unique ID from when we created it
d.recordIDsMu.Lock() d.recordIDsMu.Lock()
recordID, ok := d.recordIDs[fqdn] recordID, ok := d.recordIDs[fqdn]
@ -112,7 +117,7 @@ func (d *DNSProvider) CleanUp(domain, token, keyAuth string) error {
return fmt.Errorf("digitalocean: unknown record ID for '%s'", fqdn) return fmt.Errorf("digitalocean: unknown record ID for '%s'", fqdn)
} }
err := d.removeTxtRecord(domain, recordID) err = d.removeTxtRecord(authZone, recordID)
if err != nil { if err != nil {
return fmt.Errorf("digitalocean: %v", err) return fmt.Errorf("digitalocean: %v", err)
} }