2024-09-09 11:21:03 +00:00
|
|
|
// Package ip provides IP address related functions
|
|
|
|
package ip
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net"
|
2024-09-11 18:13:30 +00:00
|
|
|
"strings"
|
2024-09-09 11:21:03 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// IsIPv6Only returns true if all given IPs are IPv6
|
|
|
|
func IsIPv6Only(ips []net.IP) bool {
|
|
|
|
for _, ip := range ips {
|
|
|
|
if ip.To4() != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
2024-09-11 18:13:30 +00:00
|
|
|
|
|
|
|
// SliceToString converts []net.IP to a string separated by comma.
|
|
|
|
// If the separator is empty, it defaults to ",".
|
|
|
|
func SliceToString(ips []net.IP) string {
|
|
|
|
r := make([]string, len(ips))
|
|
|
|
for i, j := range ips {
|
|
|
|
r[i] = j.String()
|
|
|
|
}
|
|
|
|
|
|
|
|
return strings.Join(r, ",")
|
|
|
|
}
|
2024-10-31 21:13:52 +00:00
|
|
|
|
|
|
|
// Add brackets based on whether the given string is IPv6 or not.
|
|
|
|
// If the input is an IPv6 address, wraps it in square brackets `[ ]`.
|
|
|
|
// Otherwise, it returns the input string as-is (for domain names or IPv4
|
|
|
|
// addresses).
|
|
|
|
func FormatHostname(hostname string) string {
|
|
|
|
ip := net.ParseIP(hostname)
|
|
|
|
if ip != nil && ip.To4() == nil {
|
|
|
|
return "[" + hostname + "]"
|
|
|
|
}
|
|
|
|
|
|
|
|
return hostname
|
|
|
|
}
|