mirror of
https://github.com/mjl-/mox.git
synced 2025-01-14 17:36:27 +03:00
smtpserver: in helo/ehlo for submission don't fail on bad domain/ip address
for submission, we don't care about the value. users typically won't be able to easily fix the errors (of their mail client software). so we just ignore the domain/ip address, unless in pedantic mode. this also parses "additional information after literal addresses" more strictly/correctly. for issue #55 by gimpf, thanks for the report!
This commit is contained in:
parent
f4c20673ff
commit
165639cb38
1 changed files with 19 additions and 9 deletions
|
@ -773,15 +773,19 @@ func (c *conn) cmdEhlo(p *parser) {
|
||||||
|
|
||||||
// ../rfc/5321:1783
|
// ../rfc/5321:1783
|
||||||
func (c *conn) cmdHello(p *parser, ehlo bool) {
|
func (c *conn) cmdHello(p *parser, ehlo bool) {
|
||||||
// ../rfc/5321:1827, though a few paragraphs earlier at ../rfc/5321:1802 is a claim
|
|
||||||
// additional data can occur.
|
|
||||||
p.xspace()
|
|
||||||
var remote dns.IPDomain
|
var remote dns.IPDomain
|
||||||
|
if c.submission && !moxvar.Pedantic {
|
||||||
|
// Mail clients regularly put bogus information in the hostname/ip. For submission,
|
||||||
|
// the value is of no use, so there is not much point in annoying the user with
|
||||||
|
// errors they cannot fix themselves. Except when in pedantic mode.
|
||||||
|
remote = dns.IPDomain{IP: c.remoteIP}
|
||||||
|
} else {
|
||||||
|
p.xspace()
|
||||||
if ehlo {
|
if ehlo {
|
||||||
remote = p.xipdomain(true)
|
remote = p.xipdomain(true)
|
||||||
} else {
|
} else {
|
||||||
remote = dns.IPDomain{Domain: p.xdomain()}
|
remote = dns.IPDomain{Domain: p.xdomain()}
|
||||||
if !c.submission {
|
|
||||||
// Verify a remote domain name has an A or AAAA record, CNAME not allowed. ../rfc/5321:722
|
// Verify a remote domain name has an A or AAAA record, CNAME not allowed. ../rfc/5321:722
|
||||||
cidctx := context.WithValue(mox.Context, mlog.CidKey, c.cid)
|
cidctx := context.WithValue(mox.Context, mlog.CidKey, c.cid)
|
||||||
ctx, cancel := context.WithTimeout(cidctx, time.Minute)
|
ctx, cancel := context.WithTimeout(cidctx, time.Minute)
|
||||||
|
@ -792,9 +796,15 @@ func (c *conn) cmdHello(p *parser, ehlo bool) {
|
||||||
}
|
}
|
||||||
// For success or temporary resolve errors, we'll just continue.
|
// For success or temporary resolve errors, we'll just continue.
|
||||||
}
|
}
|
||||||
|
// ../rfc/5321:1827
|
||||||
|
// Though a few paragraphs earlier is a claim additional data can occur for address
|
||||||
|
// literals (IP addresses), although the ABNF in that document does not allow it.
|
||||||
|
// We allow additional text, but only if space-separated.
|
||||||
|
if len(remote.IP) > 0 && p.space() {
|
||||||
|
p.remainder() // ../rfc/5321:1802 ../rfc/2821:1632
|
||||||
}
|
}
|
||||||
p.remainder() // ../rfc/5321:1802
|
|
||||||
p.xend()
|
p.xend()
|
||||||
|
}
|
||||||
|
|
||||||
// Reset state as if RSET command has been issued. ../rfc/5321:2093 ../rfc/5321:2453
|
// Reset state as if RSET command has been issued. ../rfc/5321:2093 ../rfc/5321:2453
|
||||||
c.rset()
|
c.rset()
|
||||||
|
|
Loading…
Reference in a new issue