btc-crawl/seed.go

45 lines
933 B
Go
Raw Normal View History

package main
import (
"net"
"sync"
2014-05-19 17:14:24 -05:00
"github.com/btcsuite/btcd/chaincfg"
)
func GetSeedsFromDNS(dnsSeeds []string) []string {
wait := sync.WaitGroup{}
results := make(chan []net.IP)
2014-05-19 17:14:24 -05:00
for _, seed := range dnsSeeds {
wait.Add(1)
2014-04-23 19:20:55 -05:00
go func(address string) {
defer wait.Done()
ips, err := net.LookupIP(address)
if err != nil {
2014-04-24 21:13:33 -05:00
logger.Warningf("Failed to resolve %s: %v", address, err)
return
}
2014-04-24 21:13:33 -05:00
logger.Debugf("Resolved %d seeds from %s.", len(ips), address)
results <- ips
2014-05-19 17:14:24 -05:00
}(seed)
}
go func() {
wait.Wait()
close(results)
}()
seeds := []string{}
for ips := range results {
for _, ip := range ips {
seeds = append(seeds, net.JoinHostPort(ip.String(), chaincfg.MainNetParams.DefaultPort))
}
}
2014-04-24 21:13:33 -05:00
logger.Infof("Resolved %d seed nodes from %d DNS seeds.", len(seeds), len(dnsSeeds))
// Note that this will likely include duplicate seeds. The crawler deduplicates them.
return seeds
}