mirror of
https://github.com/caddyserver/caddy.git
synced 2024-12-23 22:27:38 -05:00
6f78cc49d1
- Using xenolf/lego's likely-temporary acmev2 branch - Cleaned up vendor folder a little bit (probably more to do) - Temporarily set default CA URL to v2 staging endpoint - Refactored user management a bit; updated tests (biggest change is how we get the email address, which now requires being able to make an ACME client with a User with a private key so that we can get the current ToS URL) - Automatic HTTPS now allows specific wildcard pattern hostnames - Commented out (but kept) the TLS-SNI code, as the challenge type may return in the future in a similar form
53 lines
1.4 KiB
Go
53 lines
1.4 KiB
Go
package acme
|
|
|
|
import (
|
|
"bufio"
|
|
"fmt"
|
|
"os"
|
|
)
|
|
|
|
const (
|
|
dnsTemplate = "%s %d IN TXT \"%s\""
|
|
)
|
|
|
|
// DNSProviderManual is an implementation of the ChallengeProvider interface
|
|
type DNSProviderManual struct{}
|
|
|
|
// NewDNSProviderManual returns a DNSProviderManual instance.
|
|
func NewDNSProviderManual() (*DNSProviderManual, error) {
|
|
return &DNSProviderManual{}, nil
|
|
}
|
|
|
|
// Present prints instructions for manually creating the TXT record
|
|
func (*DNSProviderManual) Present(domain, token, keyAuth string) error {
|
|
fqdn, value, ttl := DNS01Record(domain, keyAuth)
|
|
dnsRecord := fmt.Sprintf(dnsTemplate, fqdn, ttl, value)
|
|
|
|
authZone, err := FindZoneByFqdn(fqdn, RecursiveNameservers)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
logf("[INFO] acme: Please create the following TXT record in your %s zone:", authZone)
|
|
logf("[INFO] acme: %s", dnsRecord)
|
|
logf("[INFO] acme: Press 'Enter' when you are done")
|
|
|
|
reader := bufio.NewReader(os.Stdin)
|
|
_, _ = reader.ReadString('\n')
|
|
return nil
|
|
}
|
|
|
|
// CleanUp prints instructions for manually removing the TXT record
|
|
func (*DNSProviderManual) CleanUp(domain, token, keyAuth string) error {
|
|
fqdn, _, ttl := DNS01Record(domain, keyAuth)
|
|
dnsRecord := fmt.Sprintf(dnsTemplate, fqdn, ttl, "...")
|
|
|
|
authZone, err := FindZoneByFqdn(fqdn, RecursiveNameservers)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
logf("[INFO] acme: You can now remove this TXT record from your %s zone:", authZone)
|
|
logf("[INFO] acme: %s", dnsRecord)
|
|
return nil
|
|
}
|