From fd1eef7d81659fbfe0a5a51ee1c90d1840da65c3 Mon Sep 17 00:00:00 2001 From: Andrea Marchesini Date: Tue, 3 May 2022 18:33:04 +0200 Subject: [PATCH] Check the model initialization before going to StateMain (#3427) --- src/mozillavpn.cpp | 33 ++++++++++++--------------------- 1 file changed, 12 insertions(+), 21 deletions(-) diff --git a/src/mozillavpn.cpp b/src/mozillavpn.cpp index ffe3585d86d..e4d877d4184 100644 --- a/src/mozillavpn.cpp +++ b/src/mozillavpn.cpp @@ -349,6 +349,17 @@ void MozillaVPN::setState(State state) { void MozillaVPN::maybeStateMain() { logger.debug() << "Maybe state main"; + if (!modelsInitialized()) { + logger.warning() << "Models not initialized yet"; + SettingsHolder::instance()->clear(); + errorHandle(ErrorHandler::RemoteServiceError); + setUserState(UserNotAuthenticated); + setState(StateInitialize); + return; + } + + Q_ASSERT(m_private->m_serverData.initialized()); + if (FeatureInAppPurchase::instance()->isSupported()) { if (m_state != StateSubscriptionBlocked && m_private->m_user.subscriptionNeeded()) { @@ -645,18 +656,7 @@ void MozillaVPN::completeActivation() { TaskScheduler::scheduleTask(new TaskSurveyData()); // Finally we are able to activate the client. - TaskScheduler::scheduleTask(new TaskFunction([this]() { - if (!modelsInitialized()) { - logger.error() << "Failed to complete the authentication"; - errorHandle(ErrorHandler::RemoteServiceError); - setUserState(UserNotAuthenticated); - return; - } - - Q_ASSERT(m_private->m_serverData.initialized()); - - maybeStateMain(); - })); + TaskScheduler::scheduleTask(new TaskFunction([this]() { maybeStateMain(); })); } void MozillaVPN::deviceAdded(const QString& deviceName, @@ -746,15 +746,6 @@ void MozillaVPN::removeDeviceFromPublicKey(const QString& publicKey) { return; } - if (!modelsInitialized()) { - logger.warning() << "Models not initialized yet"; - errorHandle(ErrorHandler::RemoteServiceError); - SettingsHolder::instance()->clear(); - setUserState(UserNotAuthenticated); - setState(StateInitialize); - return; - } - maybeStateMain(); })); }