Add discovery support for SMTP with implicit TLS
This commit is contained in:
parent
75122a175a
commit
bfb2d8a4de
1 changed files with 15 additions and 5 deletions
20
discover.go
20
discover.go
|
@ -53,14 +53,24 @@ func discoverIMAP(domain string) (*url.URL, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// discoverSMTP performs a DNS-based SMTP submission service discovery, as
|
// discoverSMTP performs a DNS-based SMTP submission service discovery, as
|
||||||
// defined in RFC 6186 section 3.1.
|
// defined in RFC 6186 section 3.1. RFC 8314 section 5.1 adds a new service for
|
||||||
|
// SMTP submission with implicit TLS.
|
||||||
func discoverSMTP(domain string) (*url.URL, error) {
|
func discoverSMTP(domain string) (*url.URL, error) {
|
||||||
host, err := discoverTCP("submission", domain)
|
smtpsHost, err := discoverTCP("submissions", domain)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if host == "" {
|
if smtpsHost != "" {
|
||||||
|
return &url.URL{Scheme: "smtps", Host: smtpsHost}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
smtpHost, err := discoverTCP("submission", domain)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if smtpHost != "" {
|
||||||
|
return &url.URL{Scheme: "smtp", Host: smtpHost}, nil
|
||||||
|
}
|
||||||
|
|
||||||
return nil, fmt.Errorf("SMTP service discovery not configured for domain %q", domain)
|
return nil, fmt.Errorf("SMTP service discovery not configured for domain %q", domain)
|
||||||
}
|
}
|
||||||
return &url.URL{Scheme: "smtp", Host: host}, nil
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue