From 41ae53e60d1302ffe5d059a64ee3fdf87d95691a Mon Sep 17 00:00:00 2001 From: Loyalsoldier <10487845+Loyalsoldier@users.noreply.github.com> Date: Sat, 11 Sep 2021 10:07:54 +0800 Subject: [PATCH] Fix: IP length not deterministic (#1267) The length of IPv4 address in Go standard library could be 16 if it is in IPv6-mapped-IPv4 format. (cherry picked from commit c58a372d93e22f990161da5612a9207dfe0218b2) --- app/router/condition_geoip.go | 20 +++++++------------- 1 file changed, 7 insertions(+), 13 deletions(-) diff --git a/app/router/condition_geoip.go b/app/router/condition_geoip.go index 43feaca51..536dbf2e5 100644 --- a/app/router/condition_geoip.go +++ b/app/router/condition_geoip.go @@ -1,12 +1,7 @@ -//go:build !confonly -// +build !confonly - package router import ( "github.com/v2fly/v2ray-core/v4/app/router/routercommon" - "strconv" - "inet.af/netaddr" "github.com/v2fly/v2ray-core/v4/common/net" @@ -22,16 +17,15 @@ type GeoIPMatcher struct { func (m *GeoIPMatcher) Init(cidrs []*routercommon.CIDR) error { var builder4, builder6 netaddr.IPSetBuilder for _, cidr := range cidrs { - ip := net.IP(cidr.GetIp()) - ipStr := ip.String() + "/" + strconv.Itoa(int(cidr.GetPrefix())) - ipPrefix, err := netaddr.ParseIPPrefix(ipStr) - if err != nil { - return err + netaddrIP, ok := netaddr.FromStdIP(net.IP(cidr.GetIp())) + if !ok { + return newError("invalid IP address ", cidr) } - switch len(ip) { - case net.IPv4len: + ipPrefix := netaddr.IPPrefixFrom(netaddrIP, uint8(cidr.GetPrefix())) + switch { + case netaddrIP.Is4(): builder4.AddPrefix(ipPrefix) - case net.IPv6len: + case netaddrIP.Is6(): builder6.AddPrefix(ipPrefix) } }