subsurface/core/uploadDiveShare.cpp
jan Iversen fc740f6369 core: change uploadFinish() to include html
diveshareexport wants to show the HTML received
in a positive response, so signal cannot be
compatible with diveLogsDE

Signed-off-by: Jan Iversen <jan@casacondor.com>
2019-12-11 11:08:51 -05:00

112 lines
2.7 KiB
C++

// SPDX-License-Identifier: GPL-2.0
#include "uploadDiveShare.h"
#include <QDebug>
#include "core/membuffer.h"
#include "core/settings/qPrefCloudStorage.h"
#include "core/qthelper.h"
#include "core/cloudstorage.h"
#include "core/save-html.h"
#include "core/errorhelper.h"
uploadDiveShare *uploadDiveShare::instance()
{
static uploadDiveShare *self = new uploadDiveShare;
return self;
}
uploadDiveShare::uploadDiveShare():
reply(NULL)
{
timeout.setSingleShot(true);
}
void uploadDiveShare::doUpload(bool selected, const QString &uid, bool noPublic)
{
//generate json
struct membuffer buf = {};
export_list(&buf, NULL, selected, false);
QByteArray json_data(buf.buffer, buf.len);
free_buffer(&buf);
//Request to server
QNetworkRequest request;
if (noPublic)
request.setUrl(QUrl("http://dive-share.appspot.com/upload?private=true"));
else
request.setUrl(QUrl("http://dive-share.appspot.com/upload"));
request.setRawHeader("User-Agent", getUserAgent().toUtf8());
if (uid.length() != 0)
request.setRawHeader("X-UID", uid.toUtf8());
// Execute async.
reply = manager()->put(request, json_data);
// connect signals from upload process
connect(reply, SIGNAL(finished()), this, SLOT(slot_uploadFinished()));
connect(reply, SIGNAL(error(QNetworkReply::NetworkError)), this,
SLOT(slot_uploadError(QNetworkReply::NetworkError)));
connect(reply, SIGNAL(uploadProgress(qint64, qint64)), this,
SLOT(slot_updateProgress(qint64, qint64)));
connect(&timeout, SIGNAL(timeout()), this, SLOT(slot_uploadTimeout()));
timeout.start(30000); // 30s
}
void uploadDiveShare::slot_updateProgress(qint64 current, qint64 total)
{
if (!reply)
return;
if (total <= 0 || current <= 0)
return;
// Calculate percentage
// And signal whoever wants to know
qreal percentage = (float)current / (float)total;
emit uploadProgress(percentage, 1.0);
// reset the timer: 30 seconds after we last got any data
timeout.start();
}
void uploadDiveShare::slot_uploadFinished()
{
reply->deleteLater();
timeout.stop();
if (reply->error() != 0) {
emit uploadFinish(false, reply->errorString(), reply->readAll());
} else {
emit uploadFinish(true, tr("Upload successful"), reply->readAll());
}
}
void uploadDiveShare::slot_uploadTimeout()
{
timeout.stop();
if (reply) {
reply->deleteLater();
reply = NULL;
}
QString err(tr("dive-share.com not responding"));
report_error(err.toUtf8());
emit uploadFinish(false, err, QByteArray());
}
void uploadDiveShare::slot_uploadError(QNetworkReply::NetworkError error)
{
timeout.stop();
if (reply) {
reply->deleteLater();
reply = NULL;
}
QString err(tr("network error %1").arg(error));
report_error(err.toUtf8());
emit uploadFinish(false, err, QByteArray());
}