1
0
Fork 0
mirror of https://github.com/mjl-/mox.git synced 2025-01-15 18:06:27 +03:00
mox/dns/ipdomain.go
Mechiel Lukkien 5742ed1537
when logging email addresses with IDNA domain and/or special characters or utf8 in localpart, log both native utf8 form and form with escape localpart and ascii-only domain
the idea is to make it clear from the logging if non-ascii characters are used.

this is implemented by making mlog recognize if a field value that will be
logged has a LogString method. if so, that value is logged. dns.Domain,
smtp.Address, smtp.Localpart, smtp.Path now have a LogString method.

some explicit calls to String have been replaced to LogString, and some %q
formatting have been replaced with %s, because the escaped localpart would
already have double quotes, and double doublequotes aren't easy to read.
2023-03-09 20:18:34 +01:00

51 lines
1.1 KiB
Go

package dns
import (
"net"
)
// IPDomain is an ip address, a domain, or empty.
type IPDomain struct {
IP net.IP
Domain Domain
}
// IsZero returns if both IP and Domain are zero.
func (d IPDomain) IsZero() bool {
return d.IP == nil && d.Domain == Domain{}
}
// String returns a string representation of either the IP or domain (with
// UTF-8).
func (d IPDomain) String() string {
if len(d.IP) > 0 {
return d.IP.String()
}
return d.Domain.Name()
}
// LogString returns a string with both ASCII-only and optional UTF-8
// representation.
func (d IPDomain) LogString() string {
if len(d.IP) > 0 {
return d.IP.String()
}
return d.Domain.LogString()
}
// XString is like String, but only returns UTF-8 domains if utf8 is true.
func (d IPDomain) XString(utf8 bool) string {
if d.IsIP() {
// todo: check callers if this is valid syntax for them. should we add [] for ipv6? perhaps also ipv4? probably depends on context. in smtp, the syntax is [<ipv4>] and [IPv6:<ipv6>].
return d.IP.String()
}
return d.Domain.XName(utf8)
}
func (d IPDomain) IsIP() bool {
return len(d.IP) > 0
}
func (d IPDomain) IsDomain() bool {
return !d.Domain.IsZero()
}