summaryrefslogtreecommitdiff
path: root/service/OneService.cpp
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2018-04-25 06:41:44 -0700
committerAdam Ierymenko <adam.ierymenko@gmail.com>2018-04-25 06:41:44 -0700
commit05bfafbce8b00d9a99e6bf858f5c3d1645442952 (patch)
treee91f72b8af8208ec24c3c1acc0ea9875d6d2e994 /service/OneService.cpp
parent9da79671976411072bbfd18ec1bb92507a0e63e2 (diff)
parentd32a26f780ce7222aa89af64abecf7044ce62327 (diff)
downloadinfinitytier-05bfafbce8b00d9a99e6bf858f5c3d1645442952.tar.gz
infinitytier-05bfafbce8b00d9a99e6bf858f5c3d1645442952.zip
Merge branch 'master' into edge
Diffstat (limited to 'service/OneService.cpp')
-rw-r--r--service/OneService.cpp21
1 files changed, 20 insertions, 1 deletions
diff --git a/service/OneService.cpp b/service/OneService.cpp
index 4b0306a1..e7229717 100644
--- a/service/OneService.cpp
+++ b/service/OneService.cpp
@@ -126,6 +126,10 @@ namespace ZeroTier { typedef WindowsEthernetTap EthernetTap; }
#include "../osdep/BSDEthernetTap.hpp"
namespace ZeroTier { typedef BSDEthernetTap EthernetTap; }
#endif // __FreeBSD__
+#ifdef __NetBSD__
+#include "../osdep/NetBSDEthernetTap.hpp"
+namespace ZeroTier { typedef NetBSDEthernetTap EthernetTap; }
+#endif // __NetBSD__
#ifdef __OpenBSD__
#include "../osdep/BSDEthernetTap.hpp"
namespace ZeroTier { typedef BSDEthernetTap EthernetTap; }
@@ -2671,7 +2675,22 @@ public:
return false;
}
}
-
+ {
+ // Check global blacklists
+ const std::vector<InetAddress> *gbl = (const std::vector<InetAddress> *)0;
+ if (ifaddr.ss_family == AF_INET) {
+ gbl = &_globalV4Blacklist;
+ } else if (ifaddr.ss_family == AF_INET6) {
+ gbl = &_globalV6Blacklist;
+ }
+ if (gbl) {
+ Mutex::Lock _l(_localConfig_m);
+ for(std::vector<InetAddress>::const_iterator a(gbl->begin());a!=gbl->end();++a) {
+ if (a->containsAddress(ifaddr))
+ return false;
+ }
+ }
+ }
{
Mutex::Lock _l(_nets_m);
for(std::map<uint64_t,NetworkState>::const_iterator n(_nets.begin());n!=_nets.end();++n) {