digitalocean: LEGO_EXPERIMENTAL_CNAME_SUPPORT support (#885)
This commit is contained in:
parent
b9bafc582c
commit
a0d59b85fe
2 changed files with 10 additions and 5 deletions
|
@ -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}
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue