diff options
| author | Adam Ierymenko <adam.ierymenko@gmail.com> | 2015-07-23 10:10:17 -0700 |
|---|---|---|
| committer | Adam Ierymenko <adam.ierymenko@gmail.com> | 2015-07-23 10:10:17 -0700 |
| commit | b3516c599bb0beb4b4827f28da472972344379c6 (patch) | |
| tree | 91e31229b46539947fd078366e118c4fc27b8c57 /controller/SqliteNetworkController.cpp | |
| parent | 3ba54c7e3559359abd8d4734aa969829309a9dab (diff) | |
| download | infinitytier-b3516c599bb0beb4b4827f28da472972344379c6.tar.gz infinitytier-b3516c599bb0beb4b4827f28da472972344379c6.zip | |
Add a rate limiting circuit breaker to the network controller to prevent flooding attacks and race conditions.
Diffstat (limited to 'controller/SqliteNetworkController.cpp')
| -rw-r--r-- | controller/SqliteNetworkController.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/controller/SqliteNetworkController.cpp b/controller/SqliteNetworkController.cpp index f6489640..bdf337ec 100644 --- a/controller/SqliteNetworkController.cpp +++ b/controller/SqliteNetworkController.cpp @@ -64,6 +64,10 @@ // API version reported via JSON control plane #define ZT_NETCONF_CONTROLLER_API_VERSION 1 +// Drop requests for a given peer and network ID that occur more frequently +// than this (ms). +#define ZT_NETCONF_MIN_REQUEST_PERIOD 5000 + namespace ZeroTier { namespace { @@ -316,6 +320,15 @@ NetworkController::ResultCode SqliteNetworkController::doNetworkConfigRequest(co return NetworkController::NETCONF_QUERY_INTERNAL_SERVER_ERROR; } + // Check rate limit + + { + uint64_t &lrt = _lastRequestTime[std::pair<Address,uint64_t>(identity.address(),nwid)]; + uint64_t lrt2 = lrt; + if (((lrt = OSUtils::now()) - lrt2) <= ZT_NETCONF_MIN_REQUEST_PERIOD) + return NetworkController::NETCONF_QUERY_IGNORE; + } + NetworkRecord network; memset(&network,0,sizeof(network)); Utils::snprintf(network.id,sizeof(network.id),"%.16llx",(unsigned long long)nwid); |
