mirror of
https://github.com/zerotier/ZeroTierOne.git
synced 2025-01-04 20:24:10 +00:00
Fix a bug that could cause duplicate IP address assignment on networks if many new members join the controller at once.
This commit is contained in:
parent
5e6a4e5f5e
commit
7ea7e1898a
@ -664,6 +664,7 @@ unsigned int EmbeddedNetworkController::handleControlPlaneHttpPOST(
|
|||||||
|
|
||||||
// Member is being de-authorized, so spray Revocation objects to all online members
|
// Member is being de-authorized, so spray Revocation objects to all online members
|
||||||
if (!newAuth) {
|
if (!newAuth) {
|
||||||
|
_clearNetworkMemberInfoCache(nwid);
|
||||||
Revocation rev(_node->prng(),nwid,0,now,ZT_REVOCATION_FLAG_FAST_PROPAGATE,Address(address),Revocation::CREDENTIAL_TYPE_COM);
|
Revocation rev(_node->prng(),nwid,0,now,ZT_REVOCATION_FLAG_FAST_PROPAGATE,Address(address),Revocation::CREDENTIAL_TYPE_COM);
|
||||||
rev.sign(_signingId);
|
rev.sign(_signingId);
|
||||||
Mutex::Lock _l(_lastRequestTime_m);
|
Mutex::Lock _l(_lastRequestTime_m);
|
||||||
@ -1662,6 +1663,7 @@ void EmbeddedNetworkController::_request(
|
|||||||
if (nc.staticIpCount < ZT_MAX_ZT_ASSIGNED_ADDRESSES)
|
if (nc.staticIpCount < ZT_MAX_ZT_ASSIGNED_ADDRESSES)
|
||||||
nc.staticIps[nc.staticIpCount++] = ip6;
|
nc.staticIps[nc.staticIpCount++] = ip6;
|
||||||
haveManagedIpv6AutoAssignment = true;
|
haveManagedIpv6AutoAssignment = true;
|
||||||
|
_clearNetworkMemberInfoCache(nwid); // clear cache to prevent IP assignment duplication on many rapid assigns
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1717,6 +1719,7 @@ void EmbeddedNetworkController::_request(
|
|||||||
v4ip->sin_addr.s_addr = Utils::hton(ip);
|
v4ip->sin_addr.s_addr = Utils::hton(ip);
|
||||||
}
|
}
|
||||||
haveManagedIpv4AutoAssignment = true;
|
haveManagedIpv4AutoAssignment = true;
|
||||||
|
_clearNetworkMemberInfoCache(nwid); // clear cache to prevent IP assignment duplication on many rapid assigns
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -121,7 +121,6 @@ private:
|
|||||||
Mutex _threads_m;
|
Mutex _threads_m;
|
||||||
|
|
||||||
// Gathers a bunch of statistics about members of a network, IP assignments, etc. that we need in various places
|
// Gathers a bunch of statistics about members of a network, IP assignments, etc. that we need in various places
|
||||||
// This does lock _networkMemberCache_m
|
|
||||||
struct _NetworkMemberInfo
|
struct _NetworkMemberInfo
|
||||||
{
|
{
|
||||||
_NetworkMemberInfo() : authorizedMemberCount(0),activeMemberCount(0),totalMemberCount(0),mostRecentDeauthTime(0) {}
|
_NetworkMemberInfo() : authorizedMemberCount(0),activeMemberCount(0),totalMemberCount(0),mostRecentDeauthTime(0) {}
|
||||||
@ -136,6 +135,11 @@ private:
|
|||||||
std::map<uint64_t,_NetworkMemberInfo> _nmiCache;
|
std::map<uint64_t,_NetworkMemberInfo> _nmiCache;
|
||||||
Mutex _nmiCache_m;
|
Mutex _nmiCache_m;
|
||||||
void _getNetworkMemberInfo(uint64_t now,uint64_t nwid,_NetworkMemberInfo &nmi);
|
void _getNetworkMemberInfo(uint64_t now,uint64_t nwid,_NetworkMemberInfo &nmi);
|
||||||
|
inline void _clearNetworkMemberInfoCache(const uint64_t nwid)
|
||||||
|
{
|
||||||
|
Mutex::Lock _l(_nmiCache_m);
|
||||||
|
_nmiCache.erase(nwid);
|
||||||
|
}
|
||||||
|
|
||||||
void _pushMemberUpdate(uint64_t now,uint64_t nwid,const nlohmann::json &member);
|
void _pushMemberUpdate(uint64_t now,uint64_t nwid,const nlohmann::json &member);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user