From 38b9d1780f8f02053d20ac0e95e91f6b08ee3d9a Mon Sep 17 00:00:00 2001
From: Lioncash <mathew1800@gmail.com>
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 05082a309..e7c61f8af 100644
--- a/src/web_service/verify_login.cpp
+++ b/src/web_service/verify_login.cpp
@@ -12,15 +12,19 @@ std::future<bool> VerifyLogin(std::string& username, std::string& token,
                               const std::string& endpoint_url, std::function<void()> 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<bool>(get_func, endpoint_url, false, username, token);
 }