summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/preferences.cpp20
-rw-r--r--qt-ui/preferences.h2
2 files changed, 21 insertions, 1 deletions
diff --git a/qt-ui/preferences.cpp b/qt-ui/preferences.cpp
index 11264b2b4..76b35c1e7 100644
--- a/qt-ui/preferences.cpp
+++ b/qt-ui/preferences.cpp
@@ -8,7 +8,10 @@
#include <QShortcut>
#include <QNetworkProxy>
#include <QNetworkCookieJar>
+#include <QNetworkReply>
#include <QWebView>
+#include <QJsonDocument>
+
static QString facebookConnectUrl =
"https://www.facebook.com/dialog/oauth?"
@@ -76,11 +79,28 @@ void PreferencesDialog::facebookLoginResponse(const QUrl &url)
settings.beginGroup("WebApps");
settings.beginGroup("Facebook");
settings.setValue("ConnectToken", securityToken);
+
+ QNetworkAccessManager *getUserID = new QNetworkAccessManager();
+ connect(getUserID, &QNetworkAccessManager::finished, this, &PreferencesDialog::facebookGetUserId);
+ getUserID->get(QNetworkRequest(QUrl("https://graph.facebook.com/me?fields=id&access_token=" + securityToken)));
+
ui.facebookWebView->setHtml("We need a better 'you re connected' page. but, YEY. ");
ui.btnDisconnectFacebook->show();
}
}
+void PreferencesDialog::facebookGetUserId(QNetworkReply *reply)
+{
+ QJsonDocument jsonDoc = QJsonDocument::fromJson(reply->readAll());
+ QJsonObject obj = jsonDoc.object();
+ if (obj.keys().contains("id")){
+ QSettings s;
+ s.beginGroup("WebApps");
+ s.beginGroup("Facebook");
+ s.setValue("UserId", obj.value("id").toVariant());
+ }
+}
+
void PreferencesDialog::facebookDisconnect()
{
QSettings settings;
diff --git a/qt-ui/preferences.h b/qt-ui/preferences.h
index 1db95a91e..d455f536c 100644
--- a/qt-ui/preferences.h
+++ b/qt-ui/preferences.h
@@ -32,7 +32,7 @@ slots:
void on_btnUseDefaultFile_toggled(bool toggle);
void facebookLoginResponse(const QUrl& url);
void facebookDisconnect();
-
+ void facebookGetUserId(QNetworkReply *reply);
private:
explicit PreferencesDialog(QWidget *parent = 0, Qt::WindowFlags f = 0);
void setUiFromPrefs();