From 0b54a2c82bd52a5f97bde8a4758e897826937611 Mon Sep 17 00:00:00 2001 From: JuanJakobo Date: Fri, 29 Jul 2022 17:37:03 +0200 Subject: [PATCH] Fix 22 If no connection on login show dialog --- src/handler/eventHandler.cpp | 57 +++++++++++++++++++++--------------- 1 file changed, 33 insertions(+), 24 deletions(-) diff --git a/src/handler/eventHandler.cpp b/src/handler/eventHandler.cpp index 679dc3e..f33d9b8 100644 --- a/src/handler/eventHandler.cpp +++ b/src/handler/eventHandler.cpp @@ -34,41 +34,50 @@ EventHandler::EventHandler() _loginView = nullptr; _webDAVView = nullptr; - std::vector currentWebDAVItems; - string path = NEXTCLOUD_ROOT_PATH + Util::accessConfig(CONFIG_PATH, Action::IReadString,"UUID") + '/'; + _menu = std::unique_ptr(new MainMenu("Nextcloud")); if (iv_access(CONFIG_PATH.c_str(), W_OK) == 0) - currentWebDAVItems = _webDAV.getDataStructure(path); + { + if (iv_access(Util::accessConfig(CONFIG_PATH, Action::IReadString, "storageLocation").c_str(), W_OK) != 0) + iv_mkdir(Util::accessConfig(CONFIG_PATH, Action::IReadString, "storageLocation").c_str(), 0777); + std::vector currentWebDAVItems; + string path = NEXTCLOUD_ROOT_PATH + Util::accessConfig(CONFIG_PATH, Action::IReadString,"UUID") + '/'; - _menu = std::unique_ptr(new MainMenu("Nextcloud")); + currentWebDAVItems = _webDAV.getDataStructure(path); + _menu = std::unique_ptr(new MainMenu("Nextcloud")); - if(currentWebDAVItems.empty()) - currentWebDAVItems = _sqllite.getItemsChildren(path); - else - updateItems(currentWebDAVItems); + if(currentWebDAVItems.empty()) + currentWebDAVItems = _sqllite.getItemsChildren(path); + else + updateItems(currentWebDAVItems); - if(currentWebDAVItems.empty()) - { - int dialogResult = DialogSynchro(ICON_QUESTION, "Action", "Could not login and there is no DB available to restore information. What would you like to do?", "Logout", "Close App", NULL); - switch (dialogResult) + if(currentWebDAVItems.empty()) { - case 1: - { - _webDAV.logout(); - _loginView = std::make_unique(LoginView(_menu->getContentRect())); - } - break; - case 2: - default: - CloseApp(); - break; + int dialogResult = DialogSynchro(ICON_QUESTION, "Action", "Could not login and there is no DB available to restore information. What would you like to do?", "Logout", "Close App", NULL); + switch (dialogResult) + { + case 1: + { + _webDAV.logout(true); + _loginView = std::unique_ptr(new LoginView(_menu->getContentRect())); + } + break; + case 2: + default: + CloseApp(); + break; + } + } + else + { + drawWebDAVItems(currentWebDAVItems); } } else { - drawWebDAVItems(currentWebDAVItems); + _menu = std::unique_ptr(new MainMenu("Nextcloud")); + _loginView = std::unique_ptr(new LoginView(_menu->getContentRect())); } - } int EventHandler::eventDistributor(const int type, const int par1, const int par2)