2017-04-27 18:24:53 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2015-06-16 13:08:31 +00:00
|
|
|
#include <QObject>
|
|
|
|
#include <QTimer>
|
|
|
|
#include <QNetworkAccessManager>
|
|
|
|
#include <QNetworkReply>
|
|
|
|
#include <QEventLoop>
|
|
|
|
|
|
|
|
#include "pref.h"
|
2018-06-03 20:15:19 +00:00
|
|
|
#include "qthelper.h"
|
2016-04-04 00:26:05 +00:00
|
|
|
#include "git-access.h"
|
2019-08-05 17:41:15 +00:00
|
|
|
#include "errorhelper.h"
|
2015-06-16 13:08:31 +00:00
|
|
|
|
|
|
|
#include "checkcloudconnection.h"
|
|
|
|
|
2015-10-02 19:25:03 +00:00
|
|
|
CheckCloudConnection::CheckCloudConnection(QObject *parent) :
|
|
|
|
QObject(parent),
|
|
|
|
reply(0)
|
2015-06-16 13:08:31 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#define TEAPOT "/make-latte?number-of-shots=3"
|
|
|
|
#define HTTP_I_AM_A_TEAPOT 418
|
|
|
|
#define MILK "Linus does not like non-fat milk"
|
|
|
|
bool CheckCloudConnection::checkServer()
|
|
|
|
{
|
2016-04-04 00:26:05 +00:00
|
|
|
if (verbose)
|
|
|
|
fprintf(stderr, "Checking cloud connection...\n");
|
|
|
|
|
2015-06-16 13:08:31 +00:00
|
|
|
QTimer timer;
|
|
|
|
timer.setSingleShot(true);
|
|
|
|
QEventLoop loop;
|
|
|
|
QNetworkRequest request;
|
|
|
|
request.setRawHeader("Accept", "text/plain");
|
|
|
|
request.setRawHeader("User-Agent", getUserAgent().toUtf8());
|
2015-11-19 01:57:13 +00:00
|
|
|
request.setRawHeader("Client-Id", getUUID().toUtf8());
|
2015-06-16 13:08:31 +00:00
|
|
|
request.setUrl(QString(prefs.cloud_base_url) + TEAPOT);
|
|
|
|
QNetworkAccessManager *mgr = new QNetworkAccessManager();
|
2015-09-23 16:55:11 +00:00
|
|
|
reply = mgr->get(request);
|
2015-12-01 23:34:00 +00:00
|
|
|
connect(&timer, &QTimer::timeout, &loop, &QEventLoop::quit);
|
|
|
|
connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
|
|
|
|
connect(reply, &QNetworkReply::sslErrors, this, &CheckCloudConnection::sslErrors);
|
2016-07-23 03:54:30 +00:00
|
|
|
for (int seconds = 1; seconds <= prefs.cloud_timeout; seconds++) {
|
|
|
|
timer.start(1000); // wait the given number of seconds (default 5)
|
2016-04-04 00:26:05 +00:00
|
|
|
loop.exec();
|
|
|
|
if (timer.isActive()) {
|
|
|
|
// didn't time out, did we get the right response?
|
|
|
|
timer.stop();
|
|
|
|
if (reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt() == HTTP_I_AM_A_TEAPOT &&
|
|
|
|
reply->readAll() == QByteArray(MILK)) {
|
|
|
|
reply->deleteLater();
|
|
|
|
mgr->deleteLater();
|
|
|
|
if (verbose > 1)
|
|
|
|
qWarning() << "Cloud storage: successfully checked connection to cloud server";
|
|
|
|
return true;
|
|
|
|
}
|
2016-07-23 03:54:30 +00:00
|
|
|
} else if (seconds < prefs.cloud_timeout) {
|
2017-06-22 12:27:52 +00:00
|
|
|
QString text = tr("Waiting for cloud connection (%n second(s) passed)", "", seconds);
|
2017-06-18 06:22:37 +00:00
|
|
|
git_storage_update_progress(qPrintable(text));
|
2016-04-04 00:26:05 +00:00
|
|
|
} else {
|
|
|
|
disconnect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
|
|
|
|
reply->abort();
|
2015-06-16 13:08:31 +00:00
|
|
|
}
|
|
|
|
}
|
2017-06-18 06:50:22 +00:00
|
|
|
git_storage_update_progress(qPrintable(tr("Cloud connection failed")));
|
2018-09-10 13:30:01 +00:00
|
|
|
git_local_only = true;
|
2015-09-23 16:55:11 +00:00
|
|
|
if (verbose)
|
|
|
|
qDebug() << "connection test to cloud server failed" <<
|
|
|
|
reply->error() << reply->errorString() <<
|
|
|
|
reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt() <<
|
|
|
|
reply->readAll();
|
2015-06-16 13:08:31 +00:00
|
|
|
reply->deleteLater();
|
|
|
|
mgr->deleteLater();
|
2015-09-20 17:11:09 +00:00
|
|
|
if (verbose)
|
|
|
|
qWarning() << "Cloud storage: unable to connect to cloud server";
|
2015-06-16 13:08:31 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2019-04-01 20:15:19 +00:00
|
|
|
void CheckCloudConnection::sslErrors(const QList<QSslError> &errorList)
|
2015-09-23 16:55:11 +00:00
|
|
|
{
|
2019-10-09 15:49:40 +00:00
|
|
|
qDebug() << "Received error response trying to set up https connection with cloud storage backend:";
|
|
|
|
for (QSslError err: errorList)
|
|
|
|
qDebug() << err.errorString();
|
2015-09-23 16:55:11 +00:00
|
|
|
}
|
|
|
|
|
2015-06-16 13:08:31 +00:00
|
|
|
// helper to be used from C code
|
|
|
|
extern "C" bool canReachCloudServer()
|
|
|
|
{
|
2015-09-20 17:11:09 +00:00
|
|
|
if (verbose)
|
|
|
|
qWarning() << "Cloud storage: checking connection to cloud server";
|
2017-12-05 22:22:47 +00:00
|
|
|
return CheckCloudConnection().checkServer();
|
2015-06-16 13:08:31 +00:00
|
|
|
}
|