summaryrefslogtreecommitdiffstats
path: root/fbreader/src/networkActions/AuthenticationDialogManager.cpp
diff options
context:
space:
mode:
authorMichele Calgaro <michele.calgaro@yahoo.it>2024-06-07 23:30:05 +0900
committerMichele Calgaro <michele.calgaro@yahoo.it>2024-06-07 23:30:05 +0900
commit17b259df9cb6b28779d4881b2b6c805ee2e48eea (patch)
tree5ed61937459cb7081089111b0242c01ec178f1f3 /fbreader/src/networkActions/AuthenticationDialogManager.cpp
parent1cba8bce178eb2d6719c6f7f21e2c9352c5513a6 (diff)
downloadtde-ebook-reader-17b259df9cb6b28779d4881b2b6c805ee2e48eea.tar.gz
tde-ebook-reader-17b259df9cb6b28779d4881b2b6c805ee2e48eea.zip
Rename to tde-ebook-reader
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
Diffstat (limited to 'fbreader/src/networkActions/AuthenticationDialogManager.cpp')
-rw-r--r--fbreader/src/networkActions/AuthenticationDialogManager.cpp192
1 files changed, 0 insertions, 192 deletions
diff --git a/fbreader/src/networkActions/AuthenticationDialogManager.cpp b/fbreader/src/networkActions/AuthenticationDialogManager.cpp
deleted file mode 100644
index 165ab01..0000000
--- a/fbreader/src/networkActions/AuthenticationDialogManager.cpp
+++ /dev/null
@@ -1,192 +0,0 @@
-/*
- * Copyright (C) 2004-2012 Geometer Plus <contact@geometerplus.com>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
- * 02110-1301, USA.
- */
-
-#include <ZLExecutionUtil.h>
-#include <ZLResource.h>
-#include <ZLTimeManager.h>
-
-#include "../network/NetworkErrors.h"
-#include "../network/NetworkLink.h"
-#include "AuthenticationDialog.h"
-#include "NetworkOperationRunnable.h"
-
-#include "AuthenticationDialogManager.h"
-
-class AuthenticationDialogListener : public ZLNetworkRequest::Listener {
-public:
- AuthenticationDialogListener(NetworkAuthenticationManager &mgr, shared_ptr<ZLNetworkRequest::Listener> listener);
-
- void returnAnswer(bool result);
- virtual void finished(const std::string &error = std::string());
-
-private:
- void restart(const std::string &error);
-
- enum State { LogOut, Authorisation, Initialization };
-
- shared_ptr<ZLNetworkRequest::Listener> myHolder;
-
- NetworkAuthenticationManager &myManager;
- shared_ptr<ZLNetworkRequest::Listener> myListener;
- std::string myPassword;
- UserList myUserList;
- std::string myError;
- State myState;
-};
-
-AuthenticationDialogListener::AuthenticationDialogListener(NetworkAuthenticationManager &mgr, shared_ptr<ZLNetworkRequest::Listener> listener)
- : myHolder(this), myManager(mgr), myListener(listener), myUserList(mgr.Link.getSiteName()), myState(LogOut) {
- finished(std::string()); //start state machine from LogOut state
-}
-
-void AuthenticationDialogListener::returnAnswer(bool result) {
- if (result) {
- myUserList.saveUser(myManager.currentUserName());
- }
- // TODO: Return notable error
- myListener->setUIStatus(false);
- myListener->finished(result ? std::string() : "Some error");
- ZLTimeManager::deleteLater(myHolder);
- myHolder.reset();
-}
-
-
-
-void AuthenticationDialogListener::finished(const std::string &error) {
- myError = error;
- myListener->setUIStatus(false);
- switch (myState) {
- case LogOut:
- if (!AuthenticationDialog::run(myManager.UserNameOption, myUserList, myError, myPassword)) {
- myManager.logOut();
- returnAnswer(false);
- return;
- }
- if (myManager.UserNameOption.value().empty()) {
- const ZLResource &resource = ZLResource::resource("dialog")["AuthenticationDialog"];
- restart(resource["loginIsEmpty"].value());
- } else {
- myState = Authorisation;
- myListener->setUIStatus(true);
- myManager.authorise(myPassword, myHolder);
- return;
- }
- break;
- case Authorisation:
- if (!myError.empty()) {
- restart(myError);
- return;
- }
- if (myManager.needsInitialization()) {
- myState = Initialization;
- myListener->setUIStatus(true);
- myManager.initialize(myHolder);
- } else {
- returnAnswer(true);
- }
- break;
- case Initialization:
- if (!myError.empty()) {
- restart(myError);
- return;
- }
- returnAnswer(true);
- break;
- }
-}
-
-void AuthenticationDialogListener::restart(const std::string &error) {
- myPassword.clear();
- myState = LogOut;
- finished(error);
- //TODO it was autoremovable task here
-}
-
-
-class AuthoriseIfCanListener : public ZLNetworkRequest::Listener {
-public:
- AuthoriseIfCanListener(NetworkAuthenticationManager &mgr, shared_ptr<ZLNetworkRequest::Listener> listener);
-
- void returnAnswer(std::string answer = std::string());
- virtual void finished(const std::string &error = std::string());
-
-private:
- enum State { Init, AuthorisationCheck, Initialization};
-
- shared_ptr<ZLNetworkRequest::Listener> myHolder;
-
- NetworkAuthenticationManager &myManager;
- shared_ptr<ZLNetworkRequest::Listener> myListener;
- State myState;
-};
-
-AuthoriseIfCanListener::AuthoriseIfCanListener(NetworkAuthenticationManager &mgr, shared_ptr<ZLNetworkRequest::Listener> listener)
- : myHolder(this), myManager(mgr), myListener(listener), myState(Init) {
- finished(std::string()); //start state machine from Init state
-}
-
-void AuthoriseIfCanListener::returnAnswer(std::string answer) {
- myListener->setUIStatus(false);
- myListener->finished(answer);
- ZLTimeManager::deleteLater(myHolder);
- myHolder.reset();
-}
-
-void AuthoriseIfCanListener::finished(const std::string &error) {
- myListener->setUIStatus(false);
- switch (myState) {
- case Init:
- myListener->setUIStatus(true);
- myState = AuthorisationCheck;
- myManager.isAuthorised(myHolder);
- break;
- case AuthorisationCheck:
- if (!error.empty()) {
- NetworkErrors::showErrorMessage(error);
- returnAnswer(error);
- return;
- }
- if (myManager.needsInitialization()) {
- myState = Initialization;
- myListener->setUIStatus(true);
- myManager.initialize(myHolder);
- } else {
- returnAnswer();
- }
- break;
- case Initialization:
- if (!error.empty()) {
- NetworkErrors::showErrorMessage(error);
- returnAnswer(error);
- return;
- }
- returnAnswer();
- break;
- }
-}
-
-std::string AuthenticationDialogManager::authAndInitAsync(NetworkAuthenticationManager &manager, shared_ptr<ZLNetworkRequest::Listener> listener) {
- new AuthenticationDialogListener(manager, listener);
- return std::string();
-}
-
-std::string AuthenticationDialogManager::athoriseIfCan(NetworkAuthenticationManager &manager, shared_ptr<ZLNetworkRequest::Listener> listener) {
- new AuthoriseIfCanListener(manager, listener);
- return std::string();
-}