From a372619fee2b24fcacffffcb280203127e4b481c Mon Sep 17 00:00:00 2001 From: Travis LaDuke Date: Fri, 10 Mar 2023 07:57:54 -0800 Subject: [PATCH] Fix addIp being called with applied ips (#1897) This was getting called outside of the check for existing ips Because of the added ifdef and a brace getting moved to the wrong place. ``` if (! n.tap()->addIp(*ip)) { fprintf(stderr, "ERROR: unable to add ip address %s" ZT_EOL_S, ip->toString(ipbuf)); } WinFWHelper::newICMPRule(*ip, n.config().nwid); ``` --- service/OneService.cpp | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/service/OneService.cpp b/service/OneService.cpp index d01ae7d95..5864f2075 100644 --- a/service/OneService.cpp +++ b/service/OneService.cpp @@ -2307,8 +2307,10 @@ class OneServiceImpl : public OneService auto same_subnet = [ip](InetAddress i){ return ip->network() == i.network(); }; +#endif if (std::find(n.managedIps().begin(),n.managedIps().end(),*ip) == n.managedIps().end()) { +#ifdef __APPLE__ // if same subnet as a previously added address if ( std::find_if(n.managedIps().begin(),n.managedIps().end(), same_subnet) != n.managedIps().end() || @@ -2322,15 +2324,17 @@ class OneServiceImpl : public OneService } else { newManagedIps2.push_back(*ip); } - } #endif - if (!n.tap()->addIp(*ip)) - fprintf(stderr,"ERROR: unable to add ip address %s" ZT_EOL_S, ip->toString(ipbuf)); - - #ifdef __WINDOWS__ - WinFWHelper::newICMPRule(*ip, n.config().nwid); - #endif + if (! n.tap()->addIp(*ip)) { + fprintf(stderr, "ERROR: unable to add ip address %s" ZT_EOL_S, ip->toString(ipbuf)); + } + else { +#ifdef __WINDOWS__ + WinFWHelper::newICMPRule(*ip, n.config().nwid); +#endif + } + } } #ifdef __APPLE__