handler: fix valid for taking ms

This commit is contained in:
Vaxry
2025-05-10 21:21:55 +01:00
parent 5afa967338
commit 5022e37917
3 changed files with 5 additions and 5 deletions

View File

@@ -83,6 +83,6 @@
"traffic_log_file": "./traffic.csv"
},
// how long the token (solved challenge) should be valid for before showing a new challenge, in minutes
"token_valid_for": 60 // 1 hour
// how long the token (solved challenge) should be valid for before showing a new challenge, in seconds
"token_valid_for": 3600 // 1 hour
}

View File

@@ -35,7 +35,7 @@ class CConfig {
bool trace_logging = false;
std::vector<SConfigRule> rules = {};
int default_challenge_difficulty = 4;
int token_valid_for = 60;
int token_valid_for = 3600;
bool async_proxy = true;
std::vector<SProxyRule> proxy_rules;

View File

@@ -215,13 +215,13 @@ void CServerHandler::onRequest(const Pistache::Http::Request& req, Pistache::Htt
if (TOKEN.valid()) {
const auto AGE = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count() -
std::chrono::duration_cast<std::chrono::milliseconds>(TOKEN.issued().time_since_epoch()).count();
if (AGE <= g_pConfig->m_config.token_valid_for && TOKEN.fingerprint() == NRequestUtils::fingerprintForRequest(req)) {
if (AGE <= g_pConfig->m_config.token_valid_for * 1000 && TOKEN.fingerprint() == NRequestUtils::fingerprintForRequest(req)) {
Debug::log(LOG, " | Action: PASS (token)");
g_pTrafficLogger->logTraffic(req, "PASS (token)");
proxyPass(req, response);
return;
} else { // token has been used from a different IP or is expired. Nuke it.
if (AGE > g_pConfig->m_config.token_valid_for)
if (AGE > g_pConfig->m_config.token_valid_for * 1000)
Debug::log(LOG, " | Action: CHALLENGE (token expired)");
else
Debug::log(LOG, " | Action: CHALLENGE (token fingerprint mismatch)");