summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhilipp Andreas <github@smurfy.de>2015-01-14 21:52:36 +0100
committerPhilipp Andreas <github@smurfy.de>2015-01-14 21:52:36 +0100
commit0da3325dcab2ebd419d1d0b1a59428f3201a5732 (patch)
tree6f0b994923e1c1f3ce1b3b1c89301e69a7867997
parent857d9547a9fc4a00c6e621fb54720d047ba90864 (diff)
Working appstore
-rw-r--r--app/pebblestoreview.cpp107
-rw-r--r--app/pebblestoreview.h35
-rw-r--r--app/qml/pages/AppStorePage.qml95
-rw-r--r--app/qml/pages/InstallAppDialog.qml4
-rw-r--r--app/qml/pages/ManagerPage.qml4
5 files changed, 225 insertions, 20 deletions
diff --git a/app/pebblestoreview.cpp b/app/pebblestoreview.cpp
index 011d056..0ea5c14 100644
--- a/app/pebblestoreview.cpp
+++ b/app/pebblestoreview.cpp
@@ -1,22 +1,117 @@
#include "pebblestoreview.h"
#include <QUrlQuery>
-#include <QJsonDocument>
-#include <QJsonObject>
+#include <QStandardPaths>
+#include <QDir>
+#include <QFile>
PebbleStoreView::PebbleStoreView()
: QQuickWebView()
{
connect(this, SIGNAL(navigationRequested(QWebNavigationRequest*)), this, SLOT(onNavigationRequested(QWebNavigationRequest*)));
+
+ this->m_networkManager = new QNetworkAccessManager(this);
+ connect(this->m_networkManager, SIGNAL(finished(QNetworkReply*)), this, SLOT(onNetworkReplyFinished(QNetworkReply*)));
+
+ this->m_configUrl = QUrl("https://boot.getpebble.com/api/config/android/v1/3");
+ this->m_downloadInProgress = false;
+ emit downloadInProgressChanged();
+
+ //Fetching urls to use by the store
+ fetchData(this->m_configUrl);
+}
+
+QString PebbleStoreView::accessToken() const
+{
+ return this->m_accessToken;
+}
+
+void PebbleStoreView::setAccessToken(const QString &accessToken)
+{
+ this->m_accessToken = accessToken;
+ emit accessTokenChanged(accessToken);
+}
+
+void PebbleStoreView::logout()
+{
+ setAccessToken("");
+ setUrl(prepareUrl(this->storeConfigObject.value("webviews").toObject().value("authentication").toString()));
+}
+
+bool PebbleStoreView::loggedin()
+{
+ return (!this->m_accessToken.isEmpty());
}
+bool PebbleStoreView::downloadInProgress()
+{
+ return this->m_downloadInProgress;
+}
+
+void PebbleStoreView::gotoWatchFaces()
+{
+ setUrl(prepareUrl(this->storeConfigObject.value("webviews").toObject().value("appstore/watchfaces").toString()));
+}
+
+void PebbleStoreView::gotoWatchApps()
+{
+ setUrl(prepareUrl(this->storeConfigObject.value("webviews").toObject().value("appstore/watchapps").toString()));
+}
+
+void PebbleStoreView::fetchData(QUrl url)
+{
+ QNetworkRequest request;
+ request.setUrl(url);
+ request.setRawHeader("Cache-Control", "no-cache");
+ this->m_networkManager->get(request);
+}
+
+void PebbleStoreView::onNetworkReplyFinished(QNetworkReply* reply)
+{
+ qDebug()<<"Download finished";
+ if (reply->request().url() == this->m_configUrl) {
+ QJsonDocument jsonResponse = QJsonDocument::fromJson(reply->readAll());
+ QJsonObject jsonObject = jsonResponse.object();
+ this->storeConfigObject = jsonObject.value("config").toObject();
+
+ if (this->m_accessToken.isEmpty()) {
+ setUrl(prepareUrl(this->storeConfigObject.value("webviews").toObject().value("authentication").toString()));
+ } else {
+ setUrl(prepareUrl(this->storeConfigObject.value("webviews").toObject().value("onboarding/get_some_apps").toString()));
+ }
+ } else {
+ QDir dataDir(QStandardPaths::writableLocation(QStandardPaths::DataLocation));
+ QFile file(dataDir.absoluteFilePath("apps") + "/" + this->downloadObject.value("uuid").toString() + ".pbw");
+ file.open(QIODevice::WriteOnly);
+ file.write(reply->readAll());
+ file.close();
+
+ qDebug()<<this->downloadObject;
+
+ this->m_downloadInProgress = false;
+ emit downloadInProgressChanged();
+ }
+}
+
+QUrl PebbleStoreView::prepareUrl(QString baseUrl)
+{
+ baseUrl = baseUrl.replace("$$user_id$$", "ZZZ");
+ baseUrl = baseUrl.replace("$$phone_id$$", "XXX");
+ baseUrl = baseUrl.replace("$$pebble_id$$", "YYY");
+ baseUrl = baseUrl.replace("$$access_token$$", this->m_accessToken);
+
+ qDebug()<<baseUrl;
+
+ return QUrl(baseUrl);
+}
void PebbleStoreView::onNavigationRequested(QWebNavigationRequest* request)
{
if (request->url().scheme() == "pebble") {
if (request->url().host() == "login") {
QUrlQuery *accessTokenFragment = new QUrlQuery(request->url().fragment());
- qDebug()<<"login"<<accessTokenFragment->queryItemValue("access_token");
- emit loginSuccess(accessTokenFragment->queryItemValue("access_token"));
+ this->m_accessToken = accessTokenFragment->queryItemValue("access_token");
+ emit accessTokenChanged(accessTokenFragment->queryItemValue("access_token"));
+ setUrl(prepareUrl(this->storeConfigObject.value("webviews").toObject().value("onboarding/get_some_apps").toString()));
}
}
if (request->url().scheme() == "pebble-method-call-js-frame") {
@@ -38,6 +133,10 @@ void PebbleStoreView::onNavigationRequested(QWebNavigationRequest* request)
QJsonObject jsonObject = jsonResponse.object();
QJsonObject data = jsonObject.value("data").toObject();
qDebug()<<"download"<<data.value("title").toString()<<data.value("pbw_file").toString();
+ this->downloadObject = data;;
+ this->m_downloadInProgress = true;
+ emit downloadInProgressChanged();
+ fetchData(QUrl(data.value("pbw_file").toString()));
emit downloadPebbleApp(data.value("title").toString(), data.value("pbw_file").toString());
}
}
diff --git a/app/pebblestoreview.h b/app/pebblestoreview.h
index f0d18f6..a19b43d 100644
--- a/app/pebblestoreview.h
+++ b/app/pebblestoreview.h
@@ -3,21 +3,50 @@
#include <private/qquickwebview_p.h>
#include <private/qwebnavigationrequest_p.h>
-#include <QQuickItem>
+#include <QNetworkReply>
+#include <QNetworkAccessManager>
+#include <QJsonDocument>
+#include <QJsonObject>
class PebbleStoreView : public QQuickWebView
{
Q_OBJECT
public:
PebbleStoreView();
+ Q_PROPERTY(bool loggedin READ loggedin NOTIFY accessTokenChanged)
+ Q_PROPERTY(bool downloadInProgress READ downloadInProgress NOTIFY downloadInProgressChanged)
+ Q_PROPERTY(QString accessToken READ accessToken WRITE setAccessToken NOTIFY accessTokenChanged)
+
+ bool loggedin();
+ bool downloadInProgress();
+ QString accessToken() const;
+ void setAccessToken(const QString &accessToken);
public slots:
+ void gotoWatchFaces();
+ void gotoWatchApps();
+ void logout();
+
+private slots:
void onNavigationRequested(QWebNavigationRequest* request);
+ void onNetworkReplyFinished(QNetworkReply* reply);
signals:
- void loginSuccess(const QString & accessToken);
- void downloadPebbleApp(const QString & title, const QString & downloadUrl);
+ void accessTokenChanged(const QString & accessToken);
+ void downloadPebbleApp(const QString & downloadTitle, const QString & downloadUrl);
+ void downloadInProgressChanged();
void call(const QString &, const QString &);
+
+private:
+ QNetworkAccessManager* m_networkManager;
+ QUrl m_configUrl;
+ QString m_accessToken;
+ QJsonObject downloadObject;
+ QJsonObject storeConfigObject;
+ bool m_downloadInProgress;
+
+ QUrl prepareUrl(QString baseUrl);
+ void fetchData(QUrl url);
};
#endif // PEBBLESTOREVIEW_H
diff --git a/app/qml/pages/AppStorePage.qml b/app/qml/pages/AppStorePage.qml
index 95bb2db..680ac50 100644
--- a/app/qml/pages/AppStorePage.qml
+++ b/app/qml/pages/AppStorePage.qml
@@ -2,23 +2,100 @@ import QtQuick 2.0
import QtQml 2.1
import Sailfish.Silica 1.0
import org.pebbled 0.1
+import org.nemomobile.configuration 1.0
Page {
id: page
- PebbleStoreView {
- id: webview
+ ConfigurationGroup {
+ id: settings
+ path: "/org/pebbled/settings"
+ property string storeAccessToken: ""
+ }
+
+ SilicaFlickable {
+ id: flickable
anchors.fill: parent
- url: "https://auth.getpebble.com/oauth/authorize?client_id=f88739e8e7a696c411236c41afc81cbef16dc54c3ff633d92dd4ceb0e5a25e5f&response_type=token&mid=xxx&pid=xxx&platform=android&mobile=sign_in&redirect_uri=pebble%3A%2F%2Flogin"
+ contentHeight: column.height + webview.height
+
+ PullDownMenu {
+ visible: webview.loggedin;
- onLoginSuccess: {
- console.log("ON Login " + accessToken);
- webview.url = "https://apps-prod.getpebble.com/en_US/?access_token=" + accessToken + "#/watchfaces"
+ MenuItem {
+ text: qsTr("Logout")
+ onClicked: {
+ webview.logout();
+ }
+ }
}
- onDownloadPebbleApp: {
- console.log("ON DOWNLOAD " + title);
- console.log(downloadUrl);
+ Column {
+ id: column
+ width: page.width
+ spacing: Theme.paddingLarge
+
+ PageHeader {
+ title: qsTr("Pebble Appstore")
+ }
+
+ Row {
+ anchors.horizontalCenter: parent.horizontalCenter
+ visible: webview.loggedin;
+ Button {
+ text: qsTr("WatchApps")
+ onClicked: {
+ webview.gotoWatchApps();
+ }
+ }
+ Button {
+ text: qsTr("WatchFaces")
+ onClicked: {
+ webview.gotoWatchFaces();
+ }
+ }
+ }
+
+ Column {
+ id: download
+ visible: webview.downloadInProgress
+ width: parent.width
+
+ Label {
+ anchors.horizontalCenter: parent.horizontalCenter
+ id: downloadLabel
+ text: qsTr("Downloading...")
+ }
+
+ BusyIndicator {
+ anchors.horizontalCenter: parent.horizontalCenter
+ running: true
+ size: BusyIndicatorSize.Large
+ }
+ }
+ }
+
+ PebbleStoreView {
+ id: webview
+ visible: !webview.downloadInProgress
+ width: page.width
+ height: page.height - column.height
+
+ anchors {
+ top: column.bottom
+ }
+
+ accessToken: settings.storeAccessToken
+
+ onAccessTokenChanged: {
+ settings.storeAccessToken = accessToken;
+ }
+
+ onDownloadPebbleApp: {
+ downloadLabel.text = qsTr("Downloading %1...").arg(downloadTitle)
+ }
}
}
+
+
}
+
diff --git a/app/qml/pages/InstallAppDialog.qml b/app/qml/pages/InstallAppDialog.qml
index ecc3d78..4661cf0 100644
--- a/app/qml/pages/InstallAppDialog.qml
+++ b/app/qml/pages/InstallAppDialog.qml
@@ -84,6 +84,10 @@ Dialog {
}
}
+ MenuItem {
+ text: qsTr("Pebble Appstore")
+ onClicked: pageStack.push(Qt.resolvedUrl("AppStorePage.qml"))
+ }
}
currentIndex: -1
diff --git a/app/qml/pages/ManagerPage.qml b/app/qml/pages/ManagerPage.qml
index c0dd411..814c9d8 100644
--- a/app/qml/pages/ManagerPage.qml
+++ b/app/qml/pages/ManagerPage.qml
@@ -65,10 +65,6 @@ Page {
text: qsTr("About")
onClicked: pageStack.push(Qt.resolvedUrl("AboutPage.qml"))
}
- MenuItem {
- text: qsTr("Pebble Appstore")
- onClicked: pageStack.push(Qt.resolvedUrl("AppStorePage.qml"))
- }
}
Column {