Improve messages and fix issue in ShareObserver

Fixed smaller issue with error check before the actual write.
Extended the error messages in ShareObserver to differentiate between
the error cases.
This commit is contained in:
Christian Kieschnick 2019-02-25 17:10:43 +01:00 committed by Jonathan White
parent 9d44a756bb
commit c369130338

View File

@ -659,8 +659,10 @@ ShareObserver::Result ShareObserver::exportIntoReferenceSignedContainer(const Ke
QuaZipFile file(&zip); QuaZipFile file(&zip);
const auto signatureOpened = file.open(QIODevice::WriteOnly, QuaZipNewInfo(KeeShare_Signature)); const auto signatureOpened = file.open(QIODevice::WriteOnly, QuaZipNewInfo(KeeShare_Signature));
if (!signatureOpened) { if (!signatureOpened) {
::qWarning("Embedding signature failed: %d", zip.getZipError()); ::qWarning("Embedding signature failed: Could not open file to write (%d)", zip.getZipError());
return {reference.path, Result::Error, tr("Could not embed signature (%1)").arg(file.getZipError())}; return {reference.path,
Result::Error,
tr("Could not embed signature: Could not open file to write (%1)").arg(file.getZipError())};
} }
QTextStream stream(&file); QTextStream stream(&file);
KeeShareSettings::Sign sign; KeeShareSettings::Sign sign;
@ -672,8 +674,10 @@ ShareObserver::Result ShareObserver::exportIntoReferenceSignedContainer(const Ke
stream << KeeShareSettings::Sign::serialize(sign); stream << KeeShareSettings::Sign::serialize(sign);
stream.flush(); stream.flush();
if (file.getZipError() != ZIP_OK) { if (file.getZipError() != ZIP_OK) {
::qWarning("Embedding signature failed: %d", zip.getZipError()); ::qWarning("Embedding signature failed: Could not write file (%d)", zip.getZipError());
return {reference.path, Result::Error, tr("Could not embed signature (%1)").arg(file.getZipError())}; return {reference.path,
Result::Error,
tr("Could not embed signature: Could not write file (%1)").arg(file.getZipError())};
} }
file.close(); file.close();
} }
@ -681,14 +685,18 @@ ShareObserver::Result ShareObserver::exportIntoReferenceSignedContainer(const Ke
QuaZipFile file(&zip); QuaZipFile file(&zip);
const auto dbOpened = file.open(QIODevice::WriteOnly, QuaZipNewInfo(KeeShare_Container)); const auto dbOpened = file.open(QIODevice::WriteOnly, QuaZipNewInfo(KeeShare_Container));
if (!dbOpened) { if (!dbOpened) {
::qWarning("Embedding database failed: %d", zip.getZipError()); ::qWarning("Embedding database failed: Could not open file to write (%d)", zip.getZipError());
return {reference.path, Result::Error, tr("Could not embed database (%1)").arg(file.getZipError())}; return {reference.path,
} Result::Error,
if (file.getZipError() != ZIP_OK) { tr("Could not embed database: Could not open file to write (%1)").arg(file.getZipError())};
::qWarning("Embedding database failed: %d", zip.getZipError());
return {reference.path, Result::Error, tr("Could not embed database (%1)").arg(file.getZipError())};
} }
file.write(bytes); file.write(bytes);
if (file.getZipError() != ZIP_OK) {
::qWarning("Embedding database failed: Could not write file (%d)", zip.getZipError());
return {reference.path,
Result::Error,
tr("Could not embed database: Could not write file (%1)").arg(file.getZipError())};
}
file.close(); file.close();
} }
zip.close(); zip.close();