From 38b9d1780f8f02053d20ac0e95e91f6b08ee3d9a Mon Sep 17 00:00:00 2001 From: Lioncash Date: Wed, 28 Mar 2018 21:29:14 -0400 Subject: [PATCH] verify_login: Make VerifyLogin exceptionless This function can be simplified by attempting to find the username within the JSON object and then only accessing it if it does. There's no need to blindly access the data itself. This also eliminates the need to copy the string to a local as well, since we already have the element itself, we can just compare against it. For the failure case, it's the same if we were checking that the provided username string is empty. --- src/web_service/verify_login.cpp | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/src/web_service/verify_login.cpp b/src/web_service/verify_login.cpp index 05082a3096..e7c61f8af7 100644 --- a/src/web_service/verify_login.cpp +++ b/src/web_service/verify_login.cpp @@ -12,15 +12,19 @@ std::future VerifyLogin(std::string& username, std::string& token, const std::string& endpoint_url, std::function func) { auto get_func = [func, username](const std::string& reply) -> bool { func(); - if (reply.empty()) + + if (reply.empty()) { return false; - nlohmann::json json = nlohmann::json::parse(reply); - std::string result; - try { - result = json["username"]; - } catch (const nlohmann::detail::out_of_range&) { } - return result == username; + + nlohmann::json json = nlohmann::json::parse(reply); + const auto iter = json.find("username"); + + if (iter == json.end()) { + return username.empty(); + } + + return username == *iter; }; return GetJson(get_func, endpoint_url, false, username, token); }