diff --git a/init.cpp b/init.cpp index ac2721db6..3afc8eedc 100644 --- a/init.cpp +++ b/init.cpp @@ -429,6 +429,9 @@ bool AppInit2(int argc, char* argv[]) } } + if (mapArgs.count("-dnsseed")) + DNSAddressSeed(); + if (mapArgs.count("-paytxfee")) { if (!ParseMoney(mapArgs["-paytxfee"], nTransactionFee)) diff --git a/net.cpp b/net.cpp index d18b63eb5..372402f51 100644 --- a/net.cpp +++ b/net.cpp @@ -857,7 +857,34 @@ void ThreadSocketHandler2(void* parg) +static const char *strDNSSeed[] = { + "bitseed.xf2.org", +}; +void DNSAddressSeed() +{ + int found = 0; + + printf("Loading addresses from DNS seeds (could take a while)\n"); + + for (int seed_idx = 0; seed_idx < ARRAYLEN(strDNSSeed); seed_idx++) { + struct hostent* phostent = gethostbyname(strDNSSeed[seed_idx]); + if (!phostent) + continue; + + for (int host = 0; phostent->h_addr_list[host] != NULL; host++) { + CAddress addr(*(unsigned int*)phostent->h_addr_list[host], + GetDefaultPort(), NODE_NETWORK); + addr.nTime = 0; + if (addr.IsValid() && addr.GetByte(3) != 127) { + AddAddress(addr); + found++; + } + } + } + + printf("%d addresses found from DNS seeds\n", found); +} diff --git a/net.h b/net.h index f07081619..05ef5e064 100644 --- a/net.h +++ b/net.h @@ -30,6 +30,7 @@ CNode* FindNode(unsigned int ip); CNode* ConnectNode(CAddress addrConnect, int64 nTimeout=0); void AbandonRequests(void (*fn)(void*, CDataStream&), void* param1); bool AnySubscribed(unsigned int nChannel); +void DNSAddressSeed(); bool BindListenPort(string& strError=REF(string())); void StartNode(void* parg); bool StopNode();