mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Move checking the cloud connection into its own files
This isn't UI related and shouldn't have been in a file full of UI functionality. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
0fa0eb2879
commit
854f55fd89
6 changed files with 78 additions and 58 deletions
|
|
@ -1007,48 +1007,3 @@ void CloudStorageAuthenticate::sslErrors(QList<QSslError> errorList)
|
|||
qDebug() << err.errorString();
|
||||
}
|
||||
}
|
||||
|
||||
CheckCloudConnection::CheckCloudConnection(QObject *parent)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
#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()
|
||||
{
|
||||
QTimer timer;
|
||||
timer.setSingleShot(true);
|
||||
QEventLoop loop;
|
||||
QNetworkRequest request;
|
||||
request.setRawHeader("Accept", "text/plain");
|
||||
request.setRawHeader("User-Agent", getUserAgent().toUtf8());
|
||||
request.setUrl(QString(prefs.cloud_base_url) + TEAPOT);
|
||||
QNetworkAccessManager *mgr = new QNetworkAccessManager();
|
||||
QNetworkReply *reply = mgr->get(request);
|
||||
connect(&timer, SIGNAL(timeout()), &loop, SLOT(quit()));
|
||||
connect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
|
||||
timer.start(2000); // wait two seconds
|
||||
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();
|
||||
return true;
|
||||
}
|
||||
// qDebug() << "did not get expected response - server unreachable" <<
|
||||
// reply->error() << reply->errorString() <<
|
||||
// reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt() <<
|
||||
// reply->readAll();
|
||||
} else {
|
||||
disconnect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
|
||||
reply->abort();
|
||||
}
|
||||
reply->deleteLater();
|
||||
mgr->deleteLater();
|
||||
return false;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue