From 8becc29ca881332b3567ec15a396da9845837318 Mon Sep 17 00:00:00 2001 From: jan Iversen Date: Mon, 9 Dec 2019 12:51:16 +0100 Subject: desktop-widgets: split UI and network in DivelogsDeWebServices (prepare) Clean prepareDivesForUpload() and uploadDives() so that uploadDives() only contain network handling no UI. Signed-off-by: Jan Iversen --- desktop-widgets/subsurfacewebservices.cpp | 57 +++++++++++++++++-------------- 1 file changed, 32 insertions(+), 25 deletions(-) (limited to 'desktop-widgets/subsurfacewebservices.cpp') diff --git a/desktop-widgets/subsurfacewebservices.cpp b/desktop-widgets/subsurfacewebservices.cpp index 9d2d01aca..bca36b5e4 100644 --- a/desktop-widgets/subsurfacewebservices.cpp +++ b/desktop-widgets/subsurfacewebservices.cpp @@ -235,48 +235,52 @@ void DivelogsDeWebServices::downloadDives() } void DivelogsDeWebServices::prepareDivesForUpload(bool selected) +{ + // this is called when the user selects the divelogs.de radiobutton + + // Prepare zip file + if (!uploadDives(selected)) + return; + + // Adjust UI + hideDownload(); + resetState(); + uploadMode = true; + ui.buttonBox->button(QDialogButtonBox::Cancel)->setEnabled(true); + ui.buttonBox->button(QDialogButtonBox::Apply)->setEnabled(false); + ui.buttonBox->button(QDialogButtonBox::Apply)->setText(tr("Done")); + exec(); +} + +bool DivelogsDeWebServices::uploadDives(bool selected) { /* generate a random filename and create/open that file with zip_open */ QString filename = QDir::tempPath() + "/import-" + QString::number(qrand() % 99999999) + ".dld"; if (!amount_selected) { report_error(tr("No dives were selected").toUtf8()); - return; + return false; } - if (uploadDiveLogsDE::instance()->prepareDives(filename, selected)) { - QFile f(filename); - if (f.open(QIODevice::ReadOnly)) { - uploadDives((QIODevice *)&f); - f.close(); - f.remove(); - return; - } else { - report_error("Failed to open upload file %s\n", qPrintable(filename)); - } - } else { + if (!uploadDiveLogsDE::instance()->prepareDives(filename, selected)) { report_error("Failed to create upload file %s\n", qPrintable(filename)); + return false; + } + + QFile f(filename); + if (!f.open(QIODevice::ReadOnly)) { + report_error("Failed to open upload file %s\n", qPrintable(filename)); + return false; } -} -void DivelogsDeWebServices::uploadDives(QIODevice *dldContent) -{ QHttpMultiPart mp(QHttpMultiPart::FormDataType); QHttpPart part; - QFile *f = (QFile *)dldContent; - QFileInfo fi(*f); + QFileInfo fi(f); QString args("form-data; name=\"userfile\"; filename=\"" + fi.absoluteFilePath() + "\""); part.setRawHeader("Content-Disposition", args.toLatin1()); - part.setBodyDevice(dldContent); + part.setBodyDevice((QIODevice *)&f); mp.append(part); multipart = ∓ - hideDownload(); - resetState(); - uploadMode = true; - ui.buttonBox->button(QDialogButtonBox::Cancel)->setEnabled(true); - ui.buttonBox->button(QDialogButtonBox::Apply)->setEnabled(false); - ui.buttonBox->button(QDialogButtonBox::Apply)->setText(tr("Done")); - exec(); multipart = NULL; if (reply != NULL && reply->isOpen()) { @@ -284,6 +288,9 @@ void DivelogsDeWebServices::uploadDives(QIODevice *dldContent) delete reply; reply = NULL; } + f.close(); + f.remove(); + return true; } DivelogsDeWebServices::DivelogsDeWebServices(QWidget *parent, Qt::WindowFlags f) : WebServices(parent, f), -- cgit v1.2.3-70-g09d2