mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-05 21:47:38 +03:00
Merge 85ed0e0f70
into af2479da8d
This commit is contained in:
commit
8659b1169f
3 changed files with 28 additions and 6 deletions
|
@ -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'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>
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue