#include "common.h"
#include "contactmanager.h"
#include "../error.h"
-#include "ui/facebookloginbrowser.h"
#include "facebookservice/facebookauthentication.h"
#include "gps/gpsposition.h"
#include "map/mapengine.h"
qDebug() << __PRETTY_FUNCTION__;
m_ui = new MainWindow;
- m_ui->updateItemVisibility();
+ m_ui->updateItemVisibility(false);
Application *application = static_cast<Application *>(qApp);
application->registerWindow(m_ui->winId());
m_situareService = new SituareService(this);
// build FacebookAuthenticator
- m_facebookAuthenticator = new FacebookAuthentication(this);
+ m_facebookAuthenticator = new FacebookAuthentication(m_ui, this);
// build routing service
m_routingService = new RoutingService(this); // create this when needed, not in constructor!
m_mapEngine->init();
m_ui->show();
-// m_facebookAuthenticator->start();
-
m_gps->setMode(GPSPosition::Default);
initializeGpsAndAutocentering();
m_contactManager = new ContactManager(this);
m_contactManager->requestContactGuids();
- ///< @todo just for testing the login browser
- login();
+ m_facebookAuthenticator->login();
}
SituareEngine::~SituareEngine()
delete m_ui;
- QSettings settings(DIRECTORY_NAME, FILE_NAME);
+ QSettings settings(SETTINGS_ORGANIZATION_NAME, SETTINGS_APPLICATION_NAME);
settings.setValue(SETTINGS_GPS_ENABLED, m_gps->isRunning());
settings.setValue(SETTINGS_AUTO_CENTERING_ENABLED, m_autoCenteringEnabled);
}
break;
case SituareError::SESSION_EXPIRED:
m_ui->buildInformationBox(tr("Session expired. Please login again"), true);
- m_facebookAuthenticator->clearAccountInformation(true); // keep username = true
- m_situareService->clearUserData();
- m_ui->loggedIn(false);
- m_ui->loginFailed();
- break;
- case SituareError::LOGIN_FAILED:
- m_ui->toggleProgressIndicator(false);
- m_ui->buildInformationBox(tr("Invalid E-mail address or password"), true);
- m_ui->loginFailed();
+ m_facebookAuthenticator->logOut();
+ m_facebookAuthenticator->login();
break;
case SituareError::UPDATE_FAILED:
m_ui->toggleProgressIndicator(false);
{
qDebug() << __PRETTY_FUNCTION__;
- QSettings settings(DIRECTORY_NAME, FILE_NAME);
+ QSettings settings(SETTINGS_ORGANIZATION_NAME, SETTINGS_APPLICATION_NAME);
QVariant gpsEnabled = settings.value(SETTINGS_GPS_ENABLED);
QVariant autoCenteringEnabled = settings.value(SETTINGS_AUTO_CENTERING_ENABLED);
m_geocodingService->requestLocation(location);
}
-void SituareEngine::login()
-{
- qWarning() << __PRETTY_FUNCTION__;
-
- FacebookLoginBrowser *browser = m_ui->buildFacebookLoginBrowser();
-
- connect(browser, SIGNAL(loadFinished(bool)),
- m_facebookAuthenticator, SLOT(loadFinished(bool)));
-
- connect(browser, SIGNAL(urlChanged(QUrl)),
- m_facebookAuthenticator, SLOT(urlChanged(QUrl)));
-
-// browser->load(QUrl("https://graph.facebook.com/oauth/authorize?client_id=4197c64da2fb6b927236feaea32d7d81&redirect_uri=http://www.facebook.com/connect/login_success.html&display=touch&type=user_agent"));
-
- QString url = "https://www.facebook.com/login.php?";
- url.append("api_key=cf77865a5070f2c2ba3b52cbf3371579&"); ///< @todo hard coded test server api key
- url.append("cancel_url=http://www.facebook.com/connect/login_failure.html&");
- url.append("display=touch&");
- url.append("fbconnect=1&");
- url.append("next=http://www.facebook.com/connect/login_success.html&");
- url.append("return_session=1&");
- url.append("session_version=3&");
- url.append("v=1.0&");
- url.append("req_perms=publish_stream");
-
- browser->load(QUrl(url));
-}
-
-void SituareEngine::loggedIn()
-{
- qWarning() << __PRETTY_FUNCTION__;
-
- m_ui->destroyFacebookLoginBrowser();
-
- loginOk();
-}
-
void SituareEngine::loginActionPressed()
{
qDebug() << __PRETTY_FUNCTION__;
- if (m_networkAccessManager->isConnected()) {
- if(m_ui->loginState()) {
- logout();
- m_situareService->clearUserData();
- } else {
- login();
- }
- }
- else {
+ if (m_facebookAuthenticator->isLoggedIn())
+ m_facebookAuthenticator->logOut(true);
+ else if (m_networkAccessManager->isConnected())
+ m_facebookAuthenticator->login();
+ else
error(ErrorContext::NETWORK, QNetworkReply::UnknownNetworkError);
- }
}
-void SituareEngine::loginOk()
+void SituareEngine::onLogin()
{
qDebug() << __PRETTY_FUNCTION__;
m_ui->loggedIn(true);
- m_ui->show();
- m_situareService->fetchLocations(); // request user locations
+ m_situareService->fetchLocations();
if (m_gps->isRunning())
m_ui->readAutomaticLocationUpdateSettings();
}
-void SituareEngine::loginProcessCancelled()
-{
- qDebug() << __PRETTY_FUNCTION__;
-
- m_ui->toggleProgressIndicator(false);
- m_ui->updateItemVisibility();
-}
-
-void SituareEngine::logout()
+void SituareEngine::onLogout()
{
qDebug() << __PRETTY_FUNCTION__;
m_ui, SIGNAL(clearUpdateLocationDialogData()));
emit clearUpdateLocationDialogData();
- m_facebookAuthenticator->clearAccountInformation(); // clear all
+ m_situareService->updateSession(""); // empty session string means logged out
+
m_automaticUpdateFirstStart = true;
}
m_gps->start();
m_gps->requestLastPosition();
- if(m_ui->loginState())
+ if(m_facebookAuthenticator->isLoggedIn())
m_ui->readAutomaticLocationUpdateSettings();
}
else if (!enabled && m_gps->isRunning()) {
connect(m_facebookAuthenticator, SIGNAL(error(int, int)),
this, SLOT(error(int, int)));
- connect(m_facebookAuthenticator, SIGNAL(credentialsReady(FacebookCredentials)),
- m_situareService, SLOT(credentialsReady(FacebookCredentials)));
-
- connect(m_facebookAuthenticator, SIGNAL(credentialsReady(FacebookCredentials)),
- this, SLOT(loginOk()));
-
- connect(m_facebookAuthenticator, SIGNAL(newLoginRequest()),
- m_ui, SLOT(startLoginProcess()));
-
- connect(m_facebookAuthenticator, SIGNAL(saveCookiesRequest()),
- m_ui, SLOT(saveCookies()));
+ connect(m_facebookAuthenticator, SIGNAL(loggedIn(QString, bool)),
+ m_situareService, SLOT(updateSession(QString)));
- connect(m_facebookAuthenticator, SIGNAL(loginUsingCookies()),
- m_ui, SLOT(loginUsingCookies()));
+ connect(m_facebookAuthenticator, SIGNAL(loggedIn(QString, bool)),
+ this, SLOT(onLogin()));
- connect(m_facebookAuthenticator, SIGNAL(loggedIn(QString)),
- m_situareService, SLOT(updateAccessToken(QString)));
-
- connect(m_facebookAuthenticator, SIGNAL(loggedIn(QString)),
- this, SLOT(loggedIn()));
+ connect(m_facebookAuthenticator, SIGNAL(loggedOut()), this, SLOT(onLogout()));
}
void SituareEngine::signalsFromGeocodingService()
connect(m_ui, SIGNAL(error(int, int)),
this, SLOT(error(int, int)));
- connect(m_ui, SIGNAL(fetchUsernameFromSettings()),
- this, SLOT(fetchUsernameFromSettings()));
-
connect(m_ui, SIGNAL(loginActionPressed()),
this, SLOT(loginActionPressed()));
- connect(m_ui, SIGNAL(saveUsername(QString)),
- m_facebookAuthenticator, SLOT(saveUsername(QString)));
-
- connect(m_ui, SIGNAL(updateCredentials(QUrl)),
- m_facebookAuthenticator, SLOT(updateCredentials(QUrl)));
-
// signals from map view
connect(m_ui, SIGNAL(mapViewScrolled(SceneCoordinate)),
m_mapEngine, SLOT(setCenterPosition(SceneCoordinate)));
connect(m_ui, SIGNAL(gpsTriggered(bool)),
this, SLOT(setGPS(bool)));
- //signals from dialogs
- connect(m_ui, SIGNAL(cancelLoginProcess()),
- this, SLOT(loginProcessCancelled()));
-
connect(m_ui, SIGNAL(requestReverseGeo()),
this, SLOT(requestAddress()));