Browse Source
Update network.go since To16 converts the IP address ip up to a 16-byte representation. If ip is not an IP address (it is the wrong length), To16 returns nil. (#5134 )
revert-5134-patch-1
vivekkoya
1 year ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with
2 additions and
13 deletions
weed/util/network.go
@ -15,18 +15,13 @@ func DetectedHostAddress() string {
return ""
return ""
}
}
if v4Address := selectIpV4 ( netInterfaces , true ) ; v4Address != "" {
if v4Address := selectIpV4 ( netInterfaces ) ; v4Address != "" {
return v4Address
return v4Address
}
}
if v6Address := selectIpV4 ( netInterfaces , false ) ; v6Address != "" {
return v6Address
}
return "localhost"
return "localhost"
}
}
func selectIpV4 ( netInterfaces [ ] net . Interface , isIpV4 bool ) string {
func selectIpV4 ( netInterfaces [ ] net . Interface ) string {
for _ , netInterface := range netInterfaces {
for _ , netInterface := range netInterfaces {
if ( netInterface . Flags & net . FlagUp ) == 0 {
if ( netInterface . Flags & net . FlagUp ) == 0 {
continue
continue
@ -38,18 +33,12 @@ func selectIpV4(netInterfaces []net.Interface, isIpV4 bool) string {
for _ , a := range addrs {
for _ , a := range addrs {
if ipNet , ok := a . ( * net . IPNet ) ; ok && ! ipNet . IP . IsLoopback ( ) {
if ipNet , ok := a . ( * net . IPNet ) ; ok && ! ipNet . IP . IsLoopback ( ) {
if isIpV4 {
if ipNet . IP . To4 ( ) != nil {
return ipNet . IP . String ( )
}
} else {
if ipNet . IP . To16 ( ) != nil {
if ipNet . IP . To16 ( ) != nil {
return ipNet . IP . String ( )
return ipNet . IP . String ( )
}
}
}
}
}
}
}
}
}
return ""
return ""
}
}