mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-05 18:44:58 +03:00
6fde3632ef
The vendor/ folder was created with the help of @FiloSottile's gvt and vendorcheck. Any dependencies of Caddy plugins outside this repo are not vendored. We do not remove any unused, vendored packages because vendorcheck -u only checks using the current build configuration; i.e. packages that may be imported by files toggled by build tags of other systems. CI tests have been updated to ignore the vendor/ folder. When Go 1.9 is released, a few of the go commands should be revised to again use ./... as it will ignore the vendor folder by default.
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
|
|
}
|