From: Remi Gacogne Date: Thu, 6 Oct 2022 08:48:58 +0000 (+0200) Subject: dnsdist: Add proper bound checks for lazy health-check parameters X-Git-Tag: dnsdist-1.8.0-rc1~271^2~10 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=107fc443e59d29abab47080f8b2ac967c97d9605;p=thirdparty%2Fpdns.git dnsdist: Add proper bound checks for lazy health-check parameters --- diff --git a/pdns/dnsdist-lua.cc b/pdns/dnsdist-lua.cc index aa5cf53ff8..873cf704a2 100644 --- a/pdns/dnsdist-lua.cc +++ b/pdns/dnsdist-lua.cc @@ -527,19 +527,27 @@ static void setupLuaConfig(LuaContext& luaCtx, bool client, bool configCheck) } if (vars.count("lazyHealthCheckSampleSize")) { - config.d_lazyHealthChecksSampleSize = std::stoi(boost::get(vars.at("lazyHealthCheckSampleSize"))); + auto value = std::stoi(boost::get(vars.at("lazyHealthCheckSampleSize"))); + checkParameterBound("lazyHealthCheckSampleSize", value); + config.d_lazyHealthChecksSampleSize = value; } if (vars.count("lazyHealthCheckMinSampleCount")) { - config.d_lazyHealthChecksSampleSize = std::stoi(boost::get(vars.at("lazyHealthCheckThreshold"))); + auto value = std::stoi(boost::get(vars.at("lazyHealthCheckMinSampleCount"))); + checkParameterBound("lazyHealthCheckMinSampleCount", value); + config.d_lazyHealthChecksMinSampleCount = value; } if (vars.count("lazyHealthCheckThreshold")) { - config.d_lazyHealthChecksThreshold = std::stoi(boost::get(vars.at("lazyHealthCheckThreshold"))); + auto value = std::stoi(boost::get(vars.at("lazyHealthCheckThreshold"))); + checkParameterBound("lazyHealthCheckThreshold", value, std::numeric_limits::max()); + config.d_lazyHealthChecksThreshold = value; } if (vars.count("lazyHealthCheckFailedInterval")) { - config.d_lazyHealthChecksFailedInterval = std::stoi(boost::get(vars.at("lazyHealthCheckFailedInterval"))); + auto value = std::stoi(boost::get(vars.at("lazyHealthCheckFailedInterval"))); + checkParameterBound("lazyHealthCheckFailedInterval", value); + config.d_lazyHealthChecksFailedInterval = value; } if (vars.count("lazyHealthCheckMode")) {