diff options
author | Maran <maran.hidskes@gmail.com> | 2014-05-12 21:08:21 +0800 |
---|---|---|
committer | Maran <maran.hidskes@gmail.com> | 2014-05-12 21:08:21 +0800 |
commit | 7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb (patch) | |
tree | 32a18effae95d49b5df64b8ffe4ed2e806949c67 | |
parent | 8b4ed8c505111cb570c7c694675b833ebf0bba21 (diff) | |
download | go-tangerine-7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb.tar go-tangerine-7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb.tar.gz go-tangerine-7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb.tar.bz2 go-tangerine-7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb.tar.lz go-tangerine-7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb.tar.xz go-tangerine-7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb.tar.zst go-tangerine-7f9fd0879207b7aba6c8e27d3e0b4672cba98bfb.zip |
Implemented proper peer checking when adding new peers
We now resolve a hostname to IP before we try to compare it to the existing peer pool
-rw-r--r-- | ethereum.go | 43 |
1 files changed, 41 insertions, 2 deletions
diff --git a/ethereum.go b/ethereum.go index 97ea35d45..0f5bd11a2 100644 --- a/ethereum.go +++ b/ethereum.go @@ -2,6 +2,7 @@ package eth import ( "container/list" + "fmt" "github.com/ethereum/eth-go/ethchain" "github.com/ethereum/eth-go/ethdb" "github.com/ethereum/eth-go/ethrpc" @@ -9,9 +10,11 @@ import ( "github.com/ethereum/eth-go/ethwire" "io/ioutil" "log" + "math/rand" "net" "net/http" "strconv" + "strings" "sync" "sync/atomic" "time" @@ -146,15 +149,51 @@ func (s *Ethereum) ConnectToPeer(addr string) error { if s.peers.Len() < s.MaxPeers { var alreadyConnected bool + ahost, _, _ := net.SplitHostPort(addr) + var chost string + + ips, err := net.LookupIP(ahost) + + if err != nil { + return err + } else { + // If more then one ip is available try stripping away the ipv6 ones + if len(ips) > 1 { + var ipsv4 []net.IP + // For now remove the ipv6 addresses + for _, ip := range ips { + if strings.Contains(ip.String(), "::") { + continue + } else { + ipsv4 = append(ipsv4, ip) + } + } + if len(ipsv4) == 0 { + return fmt.Errorf("[SERV] No IPV4 addresses available for hostname") + } + + // Pick a random ipv4 address, simulating round-robin DNS. + rand.Seed(time.Now().UTC().UnixNano()) + i := rand.Intn(len(ipsv4)) + chost = ipsv4[i].String() + } else { + if len(ips) == 0 { + return fmt.Errorf("[SERV] No IPs resolved for the given hostname") + return nil + } + chost = ips[0].String() + } + } + eachPeer(s.peers, func(p *Peer, v *list.Element) { if p.conn == nil { return } phost, _, _ := net.SplitHostPort(p.conn.RemoteAddr().String()) - ahost, _, _ := net.SplitHostPort(addr) - if phost == ahost { + if phost == chost { alreadyConnected = true + ethutil.Config.Log.Debugf("[SERV] Peer %s already added.\n", chost) return } }) |