From 0f1707de678a23b8600510be366289071203fc6e Mon Sep 17 00:00:00 2001 From: Pieter Wuille Date: Mon, 14 May 2012 17:15:58 +0200 Subject: [PATCH 1/3] -onlynet instead of -blocknet --- src/init.cpp | 16 +++++++++++----- src/net.cpp | 11 +++++++++-- src/net.h | 1 + 3 files changed, 21 insertions(+), 7 deletions(-) diff --git a/src/init.cpp b/src/init.cpp index 0d3679657b..f1599ed3a5 100644 --- a/src/init.cpp +++ b/src/init.cpp @@ -204,7 +204,7 @@ std::string HelpMessage() " -connect= " + _("Connect only to the specified node") + "\n" + " -seednode= " + _("Connect to a node to retrieve peer addresses, and disconnect") + "\n" + " -externalip= " + _("Specify your own public address") + "\n" + - " -blocknet= " + _("Do not connect to addresses in network (IPv4 or IPv6)") + "\n" + + " -onlynet= " + _("Only connect to nodes in network (IPv4 or IPv6)") + "\n" + " -discover " + _("Try to discover public IP address (default: 1)") + "\n" + " -irc " + _("Find peers using internet relay chat (default: 0)") + "\n" + " -listen " + _("Accept connections from outside (default: 1)") + "\n" + @@ -572,12 +572,18 @@ bool AppInit2() SoftSetBoolArg("-discover", false); } - if (mapArgs.count("-blocknet")) { - BOOST_FOREACH(std::string snet, mapMultiArgs["-blocknet"]) { + if (mapArgs.count("-onlynet")) { + std::set nets; + BOOST_FOREACH(std::string snet, mapMultiArgs["-onlynet"]) { enum Network net = ParseNetwork(snet); if (net == NET_UNROUTABLE) - return InitError(strprintf(_("Unknown network specified in -blocknet: '%s'"), snet.c_str())); - SetLimited(net); + return InitError(strprintf(_("Unknown network specified in -onlynet: '%s'"), snet.c_str())); + nets.insert(net); + } + for (int n = 0; n < NET_MAX; n++) { + enum Network net = (enum Network)n; + if (!nets.count(net)) + SetLimited(net); } } diff --git a/src/net.cpp b/src/net.cpp index 88578cdcb3..e48b300953 100644 --- a/src/net.cpp +++ b/src/net.cpp @@ -245,14 +245,21 @@ bool AddLocal(const CNetAddr &addr, int nScore) /** Make a particular network entirely off-limits (no automatic connects to it) */ void SetLimited(enum Network net, bool fLimited) { + if (net == NET_UNROUTABLE) + return; LOCK(cs_mapLocalHost); vfLimited[net] = fLimited; } -bool IsLimited(const CNetAddr& addr) +bool IsLimited(enum Network net) { LOCK(cs_mapLocalHost); - return vfLimited[addr.GetNetwork()]; + return vfLimited[net]; +} + +bool IsLimited(const CNetAddr &addr) +{ + return IsLimited(addr.GetNetwork()); } /** vote for a local address */ diff --git a/src/net.h b/src/net.h index 3755c765d3..cb90ef6e72 100644 --- a/src/net.h +++ b/src/net.h @@ -57,6 +57,7 @@ enum }; void SetLimited(enum Network net, bool fLimited = true); +bool IsLimited(enum Network net); bool IsLimited(const CNetAddr& addr); bool AddLocal(const CService& addr, int nScore = LOCAL_NONE); bool AddLocal(const CNetAddr& addr, int nScore = LOCAL_NONE); From 55bb0cfbb6841372e4969b598f04dfc15a7687c0 Mon Sep 17 00:00:00 2001 From: Pieter Wuille Date: Mon, 14 May 2012 17:40:08 +0200 Subject: [PATCH 2/3] Allow binding to the any address, and report failure --- src/init.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/init.cpp b/src/init.cpp index f1599ed3a5..81a414a71d 100644 --- a/src/init.cpp +++ b/src/init.cpp @@ -611,8 +611,8 @@ bool AppInit2() std::string strError; if (mapArgs.count("-bind")) { BOOST_FOREACH(std::string strBind, mapMultiArgs["-bind"]) { - CService addrBind(strBind, GetListenPort(), false); - if (!addrBind.IsValid()) + CService addrBind; + if (!Lookup(strBind.c_str(), addrBind, GetListenPort(), false)) return InitError(strprintf(_("Cannot resolve -bind address: '%s'"), strBind.c_str())); fBound |= Bind(addrBind); } @@ -625,7 +625,7 @@ bool AppInit2() #endif } if (!fBound) - return false; + return InitError(_("Not listening on any port")); } if (mapArgs.count("-externalip")) From 91dace35a1c7821675c369d60d1e88b2ed638842 Mon Sep 17 00:00:00 2001 From: Pieter Wuille Date: Mon, 14 May 2012 17:40:35 +0200 Subject: [PATCH 3/3] Do not listen on blocked networks --- src/init.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/init.cpp b/src/init.cpp index 81a414a71d..9b12ab0aa4 100644 --- a/src/init.cpp +++ b/src/init.cpp @@ -619,9 +619,11 @@ bool AppInit2() } else { struct in_addr inaddr_any; inaddr_any.s_addr = INADDR_ANY; - fBound |= Bind(CService(inaddr_any, GetListenPort())); + if (!IsLimited(NET_IPV4)) + fBound |= Bind(CService(inaddr_any, GetListenPort())); #ifdef USE_IPV6 - fBound |= Bind(CService(in6addr_any, GetListenPort())); + if (!IsLimited(NET_IPV6)) + fBound |= Bind(CService(in6addr_any, GetListenPort())); #endif } if (!fBound)