Propagate: On download store checksum header in db #3735

This commit is contained in:
Christian Kamm 2015-10-14 15:29:27 +02:00
parent 60b2312ab6
commit b1387f801b
2 changed files with 11 additions and 4 deletions

View file

@ -351,7 +351,10 @@ void PropagateDownloadFileQNAM::start()
if (_resumeStart == _item->_size) {
qDebug() << "File is already complete, no need to download";
_tmpFile.close();
downloadFinished();
// Unfortunately we lost the checksum header, if any...
QByteArray checksumHeader;
downloadFinished(checksumHeader);
return;
}
}
@ -532,7 +535,7 @@ void PropagateDownloadFileQNAM::slotGetFinished()
// will also emit the validated() signal to continue the flow in slot downloadFinished()
// as this is (still) also correct.
ValidateChecksumHeader *validator = new ValidateChecksumHeader(this);
connect(validator, SIGNAL(validated(QByteArray)), this, SLOT(downloadFinished()));
connect(validator, SIGNAL(validated(QByteArray)), this, SLOT(downloadFinished(QByteArray)));
connect(validator, SIGNAL(validationFailed(QString)), this, SLOT(slotChecksumFail(QString)));
validator->start(_tmpFile.fileName(), job->reply()->rawHeader(checkSumHeaderC));
}
@ -611,8 +614,12 @@ static void handleRecallFile(const QString &fn)
}
} // end namespace
void PropagateDownloadFileQNAM::downloadFinished()
void PropagateDownloadFileQNAM::downloadFinished(const QByteArray& checksumHeader)
{
if (!checksumHeader.isEmpty()) {
_item->_checksumHeader = checksumHeader;
}
QString fn = _propagator->getFilePath(_item->_file);
// In case of file name clash, report an error

View file

@ -117,7 +117,7 @@ public:
private slots:
void slotGetFinished();
void abort() Q_DECL_OVERRIDE;
void downloadFinished();
void downloadFinished(const QByteArray& checksumHeader);
void slotDownloadProgress(qint64,qint64);
void slotChecksumFail( const QString& errMsg );