This commit is contained in:
sforst 2025-03-31 23:04:44 -04:00 committed by GitHub
commit 8659b1169f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 28 additions and 6 deletions

View file

@ -2453,10 +2453,6 @@ removed from the database.</source>
<source>Download failed with error: %1</source> <source>Download failed with error: %1</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Download finished, but file %1 could not be found.</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Download successful.</source> <source>Download successful.</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
@ -2489,6 +2485,14 @@ The command has to exit. In case of `sftp` as last command `exit` has to be sent
</source> </source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Command finished, but downloaded file does not exist.</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Downloaded file is not a KeePass file or it&apos;s an unsupported version: %1</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Timeout:</source> <source>Timeout:</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>

View file

@ -18,6 +18,7 @@
#include "DatabaseSettingsWidgetRemote.h" #include "DatabaseSettingsWidgetRemote.h"
#include "ui_DatabaseSettingsWidgetRemote.h" #include "ui_DatabaseSettingsWidgetRemote.h"
#include "core/Database.h"
#include "core/Global.h" #include "core/Global.h"
#include "core/Metadata.h" #include "core/Metadata.h"
@ -186,12 +187,12 @@ void DatabaseSettingsWidgetRemote::testDownload()
params->downloadInput = m_ui->inputForDownload->toPlainText(); params->downloadInput = m_ui->inputForDownload->toPlainText();
params->downloadTimeoutMsec = m_ui->downloadTimeoutSec->value() * 1000; params->downloadTimeoutMsec = m_ui->downloadTimeoutSec->value() * 1000;
QScopedPointer<RemoteHandler> remoteHandler(new RemoteHandler(this));
if (params->downloadCommand.isEmpty()) { if (params->downloadCommand.isEmpty()) {
m_ui->messageWidget->showMessage(tr("Download command cannot be empty."), MessageWidget::Warning); m_ui->messageWidget->showMessage(tr("Download command cannot be empty."), MessageWidget::Warning);
return; return;
} }
QScopedPointer<RemoteHandler> remoteHandler(new RemoteHandler(this));
RemoteHandler::RemoteResult result = remoteHandler->download(params); RemoteHandler::RemoteResult result = remoteHandler->download(params);
if (!result.success) { if (!result.success) {
m_ui->messageWidget->showMessage(tr("Download failed with error: %1").arg(result.errorMessage), m_ui->messageWidget->showMessage(tr("Download failed with error: %1").arg(result.errorMessage),
@ -200,10 +201,25 @@ void DatabaseSettingsWidgetRemote::testDownload()
} }
if (!QFile::exists(result.filePath)) { if (!QFile::exists(result.filePath)) {
m_ui->messageWidget->showMessage(tr("Download finished, but file %1 could not be found.").arg(result.filePath), m_ui->messageWidget->showMessage(tr("Command finished, but downloaded file does not exist."),
MessageWidget::Error); MessageWidget::Error);
return; return;
} }
QString error;
if (!hasValidPublicHeader(result.filePath, &error)) {
m_ui->messageWidget->showMessage(
tr("Downloaded file is not a KeePass file or it's an unsupported version: %1").arg(error),
MessageWidget::Error);
return;
}
m_ui->messageWidget->showMessage(tr("Download successful."), MessageWidget::Positive); m_ui->messageWidget->showMessage(tr("Download successful."), MessageWidget::Positive);
} }
bool DatabaseSettingsWidgetRemote::hasValidPublicHeader(QString& filePath, QString* error)
{
// Read public headers
QScopedPointer<Database> db(new Database());
return db->open(filePath, nullptr, error);
}

View file

@ -56,6 +56,8 @@ private:
QListWidgetItem* findItemByName(const QString& name); QListWidgetItem* findItemByName(const QString& name);
void clearFields(); void clearFields();
bool hasValidPublicHeader(QString& filePath, QString* error);
QScopedPointer<RemoteSettings> m_remoteSettings; QScopedPointer<RemoteSettings> m_remoteSettings;
const QScopedPointer<Ui::DatabaseSettingsWidgetRemote> m_ui; const QScopedPointer<Ui::DatabaseSettingsWidgetRemote> m_ui;
bool m_modified = false; bool m_modified = false;