diff options
-rw-r--r-- | qt-ui/preferences.cpp | 20 | ||||
-rw-r--r-- | qt-ui/preferences.h | 2 |
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(); |