Add check for database files when selecting a key file

Reject own database file as the key file. Prompt for other kdbx files as key files.

Also add a static warning message to the key file selection dialog
This commit is contained in:
Tobias Beeh 2019-10-16 15:11:47 +02:00 committed by Jonathan White
parent 99a2d66086
commit a1e12c1b30
5 changed files with 52 additions and 3 deletions

View File

@ -43,3 +43,9 @@ void DatabaseSettingsWidget::load(QSharedPointer<Database> db)
m_db = std::move(db); m_db = std::move(db);
initialize(); initialize();
} }
const QSharedPointer<Database> DatabaseSettingsWidget::getDatabase() const
{
return m_db;
}

View File

@ -38,6 +38,8 @@ public:
virtual void load(QSharedPointer<Database> db); virtual void load(QSharedPointer<Database> db);
const QSharedPointer<Database> getDatabase() const;
signals: signals:
/** /**
* Can be emitted to indicate size changes and allow parents widgets to adjust properly. * Can be emitted to indicate size changes and allow parents widgets to adjust properly.

View File

@ -17,6 +17,7 @@
#include "KeyFileEditWidget.h" #include "KeyFileEditWidget.h"
#include "ui_KeyFileEditWidget.h" #include "ui_KeyFileEditWidget.h"
#include <gui/dbsettings/DatabaseSettingsWidget.h>
#include "gui/FileDialog.h" #include "gui/FileDialog.h"
#include "gui/MainWindow.h" #include "gui/MainWindow.h"
@ -24,9 +25,10 @@
#include "keys/CompositeKey.h" #include "keys/CompositeKey.h"
#include "keys/FileKey.h" #include "keys/FileKey.h"
KeyFileEditWidget::KeyFileEditWidget(QWidget* parent) KeyFileEditWidget::KeyFileEditWidget(DatabaseSettingsWidget* parent)
: KeyComponentWidget(parent) : KeyComponentWidget(parent)
, m_compUi(new Ui::KeyFileEditWidget()) , m_compUi(new Ui::KeyFileEditWidget())
, m_parent(parent)
{ {
setComponentName(tr("Key File")); setComponentName(tr("Key File"));
setComponentDescription(tr("<p>You can add a key file containing random bytes for additional security.</p>" setComponentDescription(tr("<p>You can add a key file containing random bytes for additional security.</p>"
@ -120,6 +122,26 @@ void KeyFileEditWidget::browseKeyFile()
QString filters = QString("%1 (*.key);;%2 (*)").arg(tr("Key files"), tr("All files")); QString filters = QString("%1 (*.key);;%2 (*)").arg(tr("Key files"), tr("All files"));
QString fileName = fileDialog()->getOpenFileName(this, tr("Select a key file"), QString(), filters); QString fileName = fileDialog()->getOpenFileName(this, tr("Select a key file"), QString(), filters);
if (QFileInfo(fileName).canonicalFilePath() == m_parent->getDatabase()->canonicalFilePath()) {
MessageBox::critical(getMainWindow(),
tr("Invalid Key File"),
tr("You cannot use the current database as its own keyfile. Please choose a different "
"file or generate a new key file."));
return;
} else if (fileName.endsWith(".kdbx", Qt::CaseInsensitive)) {
auto response =
MessageBox::warning(getMainWindow(),
tr("Suspicious Key File"),
tr("The chosen key file looks like a password database file. A key file must be a "
"static file that never changes or you will lose access to your database "
"forever.\nAre you sure you want to continue with this file?"),
MessageBox::Continue | MessageBox::Cancel,
MessageBox::Cancel);
if (response != MessageBox::Continue) {
return;
}
}
if (!fileName.isEmpty()) { if (!fileName.isEmpty()) {
m_compUi->keyFileCombo->setEditText(fileName); m_compUi->keyFileCombo->setEditText(fileName);
} }

View File

@ -26,12 +26,15 @@ namespace Ui
class KeyFileEditWidget; class KeyFileEditWidget;
} }
class DatabaseSettingsWidget;
class KeyFileEditWidget : public KeyComponentWidget class KeyFileEditWidget : public KeyComponentWidget
{ {
Q_OBJECT Q_OBJECT
public: public:
explicit KeyFileEditWidget(QWidget* parent = nullptr); explicit KeyFileEditWidget(DatabaseSettingsWidget* parent);
Q_DISABLE_COPY(KeyFileEditWidget); Q_DISABLE_COPY(KeyFileEditWidget);
~KeyFileEditWidget() override; ~KeyFileEditWidget() override;
@ -49,6 +52,7 @@ private slots:
private: private:
const QScopedPointer<Ui::KeyFileEditWidget> m_compUi; const QScopedPointer<Ui::KeyFileEditWidget> m_compUi;
QPointer<QWidget> m_compEditWidget; QPointer<QWidget> m_compEditWidget;
const QPointer<DatabaseSettingsWidget> m_parent;
}; };
#endif // KEEPASSXC_KEYFILEEDITWIDGET_H #endif // KEEPASSXC_KEYFILEEDITWIDGET_H

View File

@ -6,7 +6,7 @@
<rect> <rect>
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>364</width> <width>370</width>
<height>76</height> <height>76</height>
</rect> </rect>
</property> </property>
@ -72,6 +72,21 @@
</property> </property>
</spacer> </spacer>
</item> </item>
<item row="1" column="0">
<widget class="QLabel" name="label">
<property name="font">
<font>
<italic>true</italic>
</font>
</property>
<property name="text">
<string>Note: Do not use a file that may change as that will prevent you from unlocking your database!</string>
</property>
<property name="wordWrap">
<bool>true</bool>
</property>
</widget>
</item>
</layout> </layout>
</widget> </widget>
<resources/> <resources/>