diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2015-11-18 13:14:19 -0800 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-11-18 13:14:19 -0800 |
commit | 74b15922f306872d948e722d6f2a0bb18f978436 (patch) | |
tree | b9a75d611accff8a725b604cb7ea4114fd8ea890 /qt-mobile/gpslocation.cpp | |
parent | 18e52c1da402138a2204419bb008beb7271333bb (diff) | |
download | subsurface-74b15922f306872d948e722d6f2a0bb18f978436.tar.gz |
Location service: retrieve the userid using the cloud storage API
This should actually not be in the mobile section at all. This needs to be
available on the desktop as well.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-mobile/gpslocation.cpp')
-rw-r--r-- | qt-mobile/gpslocation.cpp | 48 |
1 files changed, 47 insertions, 1 deletions
diff --git a/qt-mobile/gpslocation.cpp b/qt-mobile/gpslocation.cpp index 7ce60b4a6..f78a482a0 100644 --- a/qt-mobile/gpslocation.cpp +++ b/qt-mobile/gpslocation.cpp @@ -11,6 +11,9 @@ #include <QApplication> #include <QTimer> +#define GPS_FIX_ADD_URL "http://api.subsurface-divelog.org/api/dive/add/" +#define GET_WEBSERVICE_UID_URL "https://cloud.subsurface-divelog.org/webuserid/" + GpsLocation::GpsLocation(QObject *parent) { // create a QSettings object that's separate from the main application settings @@ -79,6 +82,44 @@ void GpsLocation::status(QString msg) qmlUiShowMessage(qPrintable(msg)); } +QString GpsLocation::getUserid(QString user, QString passwd) +{ + qDebug() << "called getUserid"; + QEventLoop loop; + QTimer timer; + timer.setSingleShot(true); + + QNetworkAccessManager *manager = new QNetworkAccessManager(qApp); + QUrl url(GET_WEBSERVICE_UID_URL); + QString data; + data = user + " " + passwd; + QNetworkRequest request; + request.setUrl(url); + request.setRawHeader("Accept", "text/html"); + request.setRawHeader("Content-type", "application/x-www-form-urlencoded"); + reply = manager->post(request, data.toUtf8()); + connect(&timer, &QTimer::timeout, &loop, &QEventLoop::quit); + connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit); + connect(reply, SIGNAL(error(QNetworkReply::NetworkError)), + this, SLOT(getUseridError(QNetworkReply::NetworkError))); + timer.start(10000); + loop.exec(); + if (timer.isActive()) { + timer.stop(); + if (reply->error() == QNetworkReply::NoError) { + QString result = reply->readAll(); + status(QString("received ") + result); + result.remove("WebserviceID:"); + reply->deleteLater(); + return result; + } + } else { + status("Getting Web service ID timed out"); + } + reply->deleteLater(); + return QString(); +} + int GpsLocation::getGpsNum() const { return geoSettings->value("count", 0).toInt(); @@ -223,6 +264,11 @@ void GpsLocation::postError(QNetworkReply::NetworkError error) status(QString("error when sending a GPS fix: %1").arg(reply->errorString())); } +void GpsLocation::getUseridError(QNetworkReply::NetworkError error) +{ + status(QString("error when retrieving Subsurface webservice user id: %1").arg(reply->errorString())); +} + void GpsLocation::uploadToServer() { // we want to do this one at a time (the server prefers that) @@ -231,7 +277,7 @@ void GpsLocation::uploadToServer() timer.setSingleShot(true); QNetworkAccessManager *manager = new QNetworkAccessManager(qApp); - QUrl url("http://api.subsurface-divelog.org/api/dive/add/"); + QUrl url(GPS_FIX_ADD_URL); int count = geoSettings->value("count", 0).toInt(); for (int i = 0; i < count; i++) { QDateTime dt; |