mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-08 05:58:25 -05:00
Merge branch 'release/2.3.0' into develop
This commit is contained in:
commit
c4b9d54085
@ -197,14 +197,13 @@ if(CMAKE_SYSTEM_NAME STREQUAL "Linux")
|
|||||||
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,-z,relro,-z,now")
|
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,-z,relro,-z,now")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
add_gcc_compiler_cflags("-std=c99")
|
||||||
add_gcc_compiler_cxxflags("-std=c++11")
|
add_gcc_compiler_cxxflags("-std=c++11")
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
add_gcc_compiler_cxxflags("-stdlib=libc++")
|
add_gcc_compiler_cxxflags("-stdlib=libc++")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_gcc_compiler_cflags("-ansi")
|
|
||||||
|
|
||||||
if(WITH_DEV_BUILD)
|
if(WITH_DEV_BUILD)
|
||||||
add_definitions(-DQT_DEPRECATED_WARNINGS -DGCRYPT_NO_DEPRECATED)
|
add_definitions(-DQT_DEPRECATED_WARNINGS -DGCRYPT_NO_DEPRECATED)
|
||||||
endif()
|
endif()
|
||||||
|
@ -17,8 +17,8 @@ find_path(YUBIKEY_CORE_INCLUDE_DIR yubikey.h)
|
|||||||
find_path(YUBIKEY_PERS_INCLUDE_DIR ykcore.h PATH_SUFFIXES ykpers-1)
|
find_path(YUBIKEY_PERS_INCLUDE_DIR ykcore.h PATH_SUFFIXES ykpers-1)
|
||||||
set(YUBIKEY_INCLUDE_DIRS ${YUBIKEY_CORE_INCLUDE_DIR} ${YUBIKEY_PERS_INCLUDE_DIR})
|
set(YUBIKEY_INCLUDE_DIRS ${YUBIKEY_CORE_INCLUDE_DIR} ${YUBIKEY_PERS_INCLUDE_DIR})
|
||||||
|
|
||||||
find_library(YUBIKEY_CORE_LIBRARY yubikey)
|
find_library(YUBIKEY_CORE_LIBRARY NAMES yubikey.dll libyubikey.so yubikey)
|
||||||
find_library(YUBIKEY_PERS_LIBRARY ykpers-1)
|
find_library(YUBIKEY_PERS_LIBRARY NAMES ykpers-1.dll libykpers-1.so ykpers-1)
|
||||||
set(YUBIKEY_LIBRARIES ${YUBIKEY_CORE_LIBRARY} ${YUBIKEY_PERS_LIBRARY})
|
set(YUBIKEY_LIBRARIES ${YUBIKEY_CORE_LIBRARY} ${YUBIKEY_PERS_LIBRARY})
|
||||||
|
|
||||||
include(FindPackageHandleStandardArgs)
|
include(FindPackageHandleStandardArgs)
|
||||||
|
@ -19,10 +19,6 @@
|
|||||||
<source>KeePassXC is distributed under the terms of the GNU General Public License (GPL) version 2 or (at your option) version 3.</source>
|
<source>KeePassXC is distributed under the terms of the GNU General Public License (GPL) version 2 or (at your option) version 3.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<source>Project Maintainers:</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<source>Contributors</source>
|
<source>Contributors</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
@ -70,6 +66,11 @@ Kernel: %3 %4</source>
|
|||||||
<source>Enabled extensions:</source>
|
<source>Enabled extensions:</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Build Type: Snapshot
|
||||||
|
</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>AccessControlDialog</name>
|
<name>AccessControlDialog</name>
|
||||||
@ -819,6 +820,22 @@ If you keep this number, your database may be too easy to crack!</source>
|
|||||||
<source>Failed to transform key with new KDF parameters; KDF unchanged.</source>
|
<source>Failed to transform key with new KDF parameters; KDF unchanged.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message numerus="yes">
|
||||||
|
<source> MiB</source>
|
||||||
|
<comment>Abbreviation for Mebibytes (KDF settings)</comment>
|
||||||
|
<translation type="unfinished">
|
||||||
|
<numerusform></numerusform>
|
||||||
|
<numerusform></numerusform>
|
||||||
|
</translation>
|
||||||
|
</message>
|
||||||
|
<message numerus="yes">
|
||||||
|
<source> thread(s)</source>
|
||||||
|
<comment>Threads for parallel execution (KDF settings)</comment>
|
||||||
|
<translation type="unfinished">
|
||||||
|
<numerusform></numerusform>
|
||||||
|
<numerusform></numerusform>
|
||||||
|
</translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>DatabaseSettingsWidgetEncryption</name>
|
<name>DatabaseSettingsWidgetEncryption</name>
|
||||||
@ -850,18 +867,10 @@ If you keep this number, your database may be too easy to crack!</source>
|
|||||||
<source>Memory Usage:</source>
|
<source>Memory Usage:</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<source> MB</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<source>Parallelism:</source>
|
<source>Parallelism:</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<source> thread</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>DatabaseSettingsWidgetGeneral</name>
|
<name>DatabaseSettingsWidgetGeneral</name>
|
||||||
@ -901,6 +910,14 @@ If you keep this number, your database may be too easy to crack!</source>
|
|||||||
<source>Use recycle bin</source>
|
<source>Use recycle bin</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Additional Database Settings</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Enable &compression (recommended)</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>DatabaseTabWidget</name>
|
<name>DatabaseTabWidget</name>
|
||||||
@ -1018,6 +1035,15 @@ Do you want to save the database before locking it?
|
|||||||
Otherwise your changes are lost.</source>
|
Otherwise your changes are lost.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Disable safe saves?</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>KeePassXC has failed to save the database multiple times. This is likely caused by file sync services holding a lock on the save file.
|
||||||
|
Disable safe saves and try again?</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>DatabaseWidget</name>
|
<name>DatabaseWidget</name>
|
||||||
@ -1817,6 +1843,65 @@ Do you want to merge your changes?</source>
|
|||||||
<source>URL</source>
|
<source>URL</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Never</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Password</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Notes</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Expires</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Created</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Modified</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Accessed</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Attachments</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>EntryView</name>
|
||||||
|
<message>
|
||||||
|
<source>Customize View</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Hide Usernames</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Hide Passwords</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Fit to window</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Fit to contents</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Reset to defaults</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>Group</name>
|
<name>Group</name>
|
||||||
@ -2694,6 +2779,12 @@ This is a one-way migration. You won't be able to open the imported databas
|
|||||||
<source>Please touch the button on your YubiKey!</source>
|
<source>Please touch the button on your YubiKey!</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>WARNING: You are using an unstable build of KeePassXC!
|
||||||
|
There is a high risk of corruption, maintain a backup of your databases.
|
||||||
|
This version is not meant for production use.</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>OpenSSHKey</name>
|
<name>OpenSSHKey</name>
|
||||||
@ -3650,6 +3741,30 @@ Please unlock the selected database or choose another one which is unlocked.</so
|
|||||||
<comment>Milliseconds</comment>
|
<comment>Milliseconds</comment>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Startup</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>File Management</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Safely save database files (may be incompatible with Dropbox, etc)</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Backup database file before saving</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Entry Management</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>General</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>SettingsWidgetSecurity</name>
|
<name>SettingsWidgetSecurity</name>
|
||||||
@ -3787,10 +3902,6 @@ Please unlock the selected database or choose another one which is unlocked.</so
|
|||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>WelcomeWidget</name>
|
<name>WelcomeWidget</name>
|
||||||
<message>
|
|
||||||
<source>Welcome to KeePassXC</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<source>Start storing your passwords securely in a KeePassXC database</source>
|
<source>Start storing your passwords securely in a KeePassXC database</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
@ -3815,6 +3926,10 @@ Please unlock the selected database or choose another one which is unlocked.</so
|
|||||||
<source>Recent databases</source>
|
<source>Recent databases</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Welcome to KeePassXC %1</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>main</name>
|
<name>main</name>
|
||||||
|
@ -21,7 +21,6 @@
|
|||||||
#include <QCoreApplication>
|
#include <QCoreApplication>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
#include <QStandardPaths>
|
|
||||||
#include <QTemporaryFile>
|
#include <QTemporaryFile>
|
||||||
|
|
||||||
Config* Config::m_instance(nullptr);
|
Config* Config::m_instance(nullptr);
|
||||||
@ -51,6 +50,18 @@ void Config::set(const QString& key, const QVariant& value)
|
|||||||
m_settings->setValue(key, value);
|
m_settings->setValue(key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sync configuration with persistent storage.
|
||||||
|
*
|
||||||
|
* Usually, you don't need to call this method manually, but if you are writing
|
||||||
|
* configurations after an emitted \link QCoreApplication::aboutToQuit() signal,
|
||||||
|
* use it to guarantee your config values are persisted.
|
||||||
|
*/
|
||||||
|
void Config::sync()
|
||||||
|
{
|
||||||
|
m_settings->sync();
|
||||||
|
}
|
||||||
|
|
||||||
Config::Config(const QString& fileName, QObject* parent)
|
Config::Config(const QString& fileName, QObject* parent)
|
||||||
: QObject(parent)
|
: QObject(parent)
|
||||||
{
|
{
|
||||||
@ -106,6 +117,7 @@ Config::~Config()
|
|||||||
void Config::init(const QString& fileName)
|
void Config::init(const QString& fileName)
|
||||||
{
|
{
|
||||||
m_settings.reset(new QSettings(fileName, QSettings::IniFormat));
|
m_settings.reset(new QSettings(fileName, QSettings::IniFormat));
|
||||||
|
connect(qApp, &QCoreApplication::aboutToQuit, this, &Config::sync);
|
||||||
|
|
||||||
m_defaults.insert("SingleInstance", true);
|
m_defaults.insert("SingleInstance", true);
|
||||||
m_defaults.insert("RememberLastDatabases", true);
|
m_defaults.insert("RememberLastDatabases", true);
|
||||||
@ -162,7 +174,7 @@ void Config::createConfigFromFile(const QString& file)
|
|||||||
void Config::createTempFileInstance()
|
void Config::createTempFileInstance()
|
||||||
{
|
{
|
||||||
Q_ASSERT(!m_instance);
|
Q_ASSERT(!m_instance);
|
||||||
QTemporaryFile* tmpFile = new QTemporaryFile();
|
auto* tmpFile = new QTemporaryFile();
|
||||||
bool openResult = tmpFile->open();
|
bool openResult = tmpFile->open();
|
||||||
Q_ASSERT(openResult);
|
Q_ASSERT(openResult);
|
||||||
Q_UNUSED(openResult);
|
Q_UNUSED(openResult);
|
||||||
|
@ -26,15 +26,18 @@ class QSettings;
|
|||||||
|
|
||||||
class Config : public QObject
|
class Config : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
~Config();
|
Q_DISABLE_COPY(Config)
|
||||||
|
|
||||||
|
~Config() override;
|
||||||
QVariant get(const QString& key);
|
QVariant get(const QString& key);
|
||||||
QVariant get(const QString& key, const QVariant& defaultValue);
|
QVariant get(const QString& key, const QVariant& defaultValue);
|
||||||
QString getFileName();
|
QString getFileName();
|
||||||
void set(const QString& key, const QVariant& value);
|
void set(const QString& key, const QVariant& value);
|
||||||
bool hasAccessError();
|
bool hasAccessError();
|
||||||
|
void sync();
|
||||||
|
|
||||||
static Config* instance();
|
static Config* instance();
|
||||||
static void createConfigFromFile(const QString& file);
|
static void createConfigFromFile(const QString& file);
|
||||||
@ -49,8 +52,6 @@ private:
|
|||||||
|
|
||||||
QScopedPointer<QSettings> m_settings;
|
QScopedPointer<QSettings> m_settings;
|
||||||
QHash<QString, QVariant> m_defaults;
|
QHash<QString, QVariant> m_defaults;
|
||||||
|
|
||||||
Q_DISABLE_COPY(Config)
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline Config* config() {
|
inline Config* config() {
|
||||||
|
@ -57,6 +57,9 @@ DatabaseSettingsWidget::DatabaseSettingsWidget(QWidget* parent)
|
|||||||
connect(m_uiEncryption->transformBenchmarkButton, SIGNAL(clicked()), SLOT(transformRoundsBenchmark()));
|
connect(m_uiEncryption->transformBenchmarkButton, SIGNAL(clicked()), SLOT(transformRoundsBenchmark()));
|
||||||
connect(m_uiEncryption->kdfComboBox, SIGNAL(currentIndexChanged(int)), SLOT(kdfChanged(int)));
|
connect(m_uiEncryption->kdfComboBox, SIGNAL(currentIndexChanged(int)), SLOT(kdfChanged(int)));
|
||||||
|
|
||||||
|
connect(m_uiEncryption->memorySpinBox, SIGNAL(valueChanged(int)), this, SLOT(memoryChanged(int)));
|
||||||
|
connect(m_uiEncryption->parallelismSpinBox, SIGNAL(valueChanged(int)), this, SLOT(parallelismChanged(int)));
|
||||||
|
|
||||||
m_ui->categoryList->addCategory(tr("General"), FilePath::instance()->icon("categories", "preferences-other"));
|
m_ui->categoryList->addCategory(tr("General"), FilePath::instance()->icon("categories", "preferences-other"));
|
||||||
m_ui->categoryList->addCategory(tr("Encryption"), FilePath::instance()->icon("actions", "document-encrypt"));
|
m_ui->categoryList->addCategory(tr("Encryption"), FilePath::instance()->icon("actions", "document-encrypt"));
|
||||||
m_ui->stackedWidget->addWidget(m_uiGeneralPage);
|
m_ui->stackedWidget->addWidget(m_uiGeneralPage);
|
||||||
@ -121,7 +124,7 @@ void DatabaseSettingsWidget::load(Database* db)
|
|||||||
kdfChanged(kdfIndex);
|
kdfChanged(kdfIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
// properly initialize parallelism spin box (may be overwritten by actual KDF values)
|
m_uiEncryption->memorySpinBox->setValue(64);
|
||||||
m_uiEncryption->parallelismSpinBox->setValue(QThread::idealThreadCount());
|
m_uiEncryption->parallelismSpinBox->setValue(QThread::idealThreadCount());
|
||||||
|
|
||||||
// Setup kdf parameters
|
// Setup kdf parameters
|
||||||
@ -289,3 +292,21 @@ void DatabaseSettingsWidget::kdfChanged(int index)
|
|||||||
|
|
||||||
transformRoundsBenchmark();
|
transformRoundsBenchmark();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update memory spin box suffix on value change.
|
||||||
|
*/
|
||||||
|
void DatabaseSettingsWidget::memoryChanged(int value)
|
||||||
|
{
|
||||||
|
m_uiEncryption->memorySpinBox->setSuffix(
|
||||||
|
tr(" MiB", "Abbreviation for Mebibytes (KDF settings)", value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update parallelism spin box suffix on value change.
|
||||||
|
*/
|
||||||
|
void DatabaseSettingsWidget::parallelismChanged(int value)
|
||||||
|
{
|
||||||
|
m_uiEncryption->parallelismSpinBox->setSuffix(
|
||||||
|
tr(" thread(s)", "Threads for parallel execution (KDF settings)", value));
|
||||||
|
}
|
||||||
|
@ -54,6 +54,8 @@ private slots:
|
|||||||
void reject();
|
void reject();
|
||||||
void transformRoundsBenchmark();
|
void transformRoundsBenchmark();
|
||||||
void kdfChanged(int index);
|
void kdfChanged(int index);
|
||||||
|
void memoryChanged(int value);
|
||||||
|
void parallelismChanged(int value);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void truncateHistories();
|
void truncateHistories();
|
||||||
|
@ -139,18 +139,12 @@
|
|||||||
<height>16777215</height>
|
<height>16777215</height>
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="suffix">
|
|
||||||
<string> MB</string>
|
|
||||||
</property>
|
|
||||||
<property name="minimum">
|
<property name="minimum">
|
||||||
<number>1</number>
|
<number>1</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="maximum">
|
<property name="maximum">
|
||||||
<number>1048576</number>
|
<number>1048576</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="value">
|
|
||||||
<number>64</number>
|
|
||||||
</property>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="4" column="0">
|
<item row="4" column="0">
|
||||||
@ -174,9 +168,6 @@
|
|||||||
<height>16777215</height>
|
<height>16777215</height>
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="suffix">
|
|
||||||
<string> thread</string>
|
|
||||||
</property>
|
|
||||||
<property name="minimum">
|
<property name="minimum">
|
||||||
<number>1</number>
|
<number>1</number>
|
||||||
</property>
|
</property>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2011 Felix Geyer <debfx@fobos.de>
|
|
||||||
* Copyright (C) 2017 KeePassXC Team <team@keepassxc.org>
|
* Copyright (C) 2017 KeePassXC Team <team@keepassxc.org>
|
||||||
|
* Copyright (C) 2011 Felix Geyer <debfx@fobos.de>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -51,7 +51,7 @@ class DatabaseTabWidget : public QTabWidget
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
explicit DatabaseTabWidget(QWidget* parent = nullptr);
|
explicit DatabaseTabWidget(QWidget* parent = nullptr);
|
||||||
~DatabaseTabWidget();
|
~DatabaseTabWidget() override;
|
||||||
void openDatabase(const QString& fileName, const QString& pw = QString(),
|
void openDatabase(const QString& fileName, const QString& pw = QString(),
|
||||||
const QString& keyFile = QString());
|
const QString& keyFile = QString());
|
||||||
void mergeDatabase(const QString& fileName);
|
void mergeDatabase(const QString& fileName);
|
||||||
@ -116,7 +116,7 @@ private:
|
|||||||
void connectDatabase(Database* newDb, Database* oldDb = nullptr);
|
void connectDatabase(Database* newDb, Database* oldDb = nullptr);
|
||||||
|
|
||||||
QHash<Database*, DatabaseManagerStruct> m_dbList;
|
QHash<Database*, DatabaseManagerStruct> m_dbList;
|
||||||
DatabaseWidgetStateSync* m_dbWidgetStateSync;
|
QPointer<DatabaseWidgetStateSync> m_dbWidgetStateSync;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // KEEPASSX_DATABASETABWIDGET_H
|
#endif // KEEPASSX_DATABASETABWIDGET_H
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
|
||||||
* Copyright (C) 2017 KeePassXC Team <team@keepassxc.org>
|
* Copyright (C) 2017 KeePassXC Team <team@keepassxc.org>
|
||||||
|
* Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
|
* Copyright (C) 2018 KeePassXC Team <team@keepassxc.org>
|
||||||
* Copyright (C) 2014 Felix Geyer <debfx@fobos.de>
|
* Copyright (C) 2014 Felix Geyer <debfx@fobos.de>
|
||||||
* Copyright (C) 2014 Florian Geyer <blueice@fobos.de>
|
* Copyright (C) 2014 Florian Geyer <blueice@fobos.de>
|
||||||
*
|
*
|
||||||
@ -19,6 +20,7 @@
|
|||||||
#include "DatabaseWidgetStateSync.h"
|
#include "DatabaseWidgetStateSync.h"
|
||||||
|
|
||||||
#include "core/Config.h"
|
#include "core/Config.h"
|
||||||
|
#include <QCoreApplication>
|
||||||
|
|
||||||
DatabaseWidgetStateSync::DatabaseWidgetStateSync(QObject* parent)
|
DatabaseWidgetStateSync::DatabaseWidgetStateSync(QObject* parent)
|
||||||
: QObject(parent)
|
: QObject(parent)
|
||||||
@ -31,9 +33,18 @@ DatabaseWidgetStateSync::DatabaseWidgetStateSync(QObject* parent)
|
|||||||
m_hidePasswords = config()->get("GUI/HidePasswords").toBool();
|
m_hidePasswords = config()->get("GUI/HidePasswords").toBool();
|
||||||
m_listViewState = config()->get("GUI/ListViewState").toByteArray();
|
m_listViewState = config()->get("GUI/ListViewState").toByteArray();
|
||||||
m_searchViewState = config()->get("GUI/SearchViewState").toByteArray();
|
m_searchViewState = config()->get("GUI/SearchViewState").toByteArray();
|
||||||
|
|
||||||
|
connect(qApp, &QCoreApplication::aboutToQuit, this, &DatabaseWidgetStateSync::sync);
|
||||||
}
|
}
|
||||||
|
|
||||||
DatabaseWidgetStateSync::~DatabaseWidgetStateSync()
|
DatabaseWidgetStateSync::~DatabaseWidgetStateSync()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sync state with persistent storage.
|
||||||
|
*/
|
||||||
|
void DatabaseWidgetStateSync::sync()
|
||||||
{
|
{
|
||||||
config()->set("GUI/SplitterState", intListToVariant(m_mainSplitterSizes));
|
config()->set("GUI/SplitterState", intListToVariant(m_mainSplitterSizes));
|
||||||
config()->set("GUI/DetailSplitterState", intListToVariant(m_detailSplitterSizes));
|
config()->set("GUI/DetailSplitterState", intListToVariant(m_detailSplitterSizes));
|
||||||
@ -41,12 +52,13 @@ DatabaseWidgetStateSync::~DatabaseWidgetStateSync()
|
|||||||
config()->set("GUI/HidePasswords", m_hidePasswords);
|
config()->set("GUI/HidePasswords", m_hidePasswords);
|
||||||
config()->set("GUI/ListViewState", m_listViewState);
|
config()->set("GUI/ListViewState", m_listViewState);
|
||||||
config()->set("GUI/SearchViewState", m_searchViewState);
|
config()->set("GUI/SearchViewState", m_searchViewState);
|
||||||
|
config()->sync();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatabaseWidgetStateSync::setActive(DatabaseWidget* dbWidget)
|
void DatabaseWidgetStateSync::setActive(DatabaseWidget* dbWidget)
|
||||||
{
|
{
|
||||||
if (m_activeDbWidget) {
|
if (m_activeDbWidget) {
|
||||||
disconnect(m_activeDbWidget, 0, this, 0);
|
disconnect(m_activeDbWidget, nullptr, this, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_activeDbWidget = dbWidget;
|
m_activeDbWidget = dbWidget;
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
|
* Copyright (C) 2018 KeePassXC Team <team@keepassxc.org>
|
||||||
* Copyright (C) 2014 Felix Geyer <debfx@fobos.de>
|
* Copyright (C) 2014 Felix Geyer <debfx@fobos.de>
|
||||||
* Copyright (C) 2014 Florian Geyer <blueice@fobos.de>
|
* Copyright (C) 2014 Florian Geyer <blueice@fobos.de>
|
||||||
*
|
*
|
||||||
@ -27,7 +28,7 @@ class DatabaseWidgetStateSync : public QObject
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
explicit DatabaseWidgetStateSync(QObject* parent = nullptr);
|
explicit DatabaseWidgetStateSync(QObject* parent = nullptr);
|
||||||
~DatabaseWidgetStateSync();
|
~DatabaseWidgetStateSync() override;
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void setActive(DatabaseWidget* dbWidget);
|
void setActive(DatabaseWidget* dbWidget);
|
||||||
@ -38,12 +39,13 @@ private slots:
|
|||||||
void blockUpdates();
|
void blockUpdates();
|
||||||
void updateSplitterSizes();
|
void updateSplitterSizes();
|
||||||
void updateViewState();
|
void updateViewState();
|
||||||
|
void sync();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static QList<int> variantToIntList(const QVariant& variant);
|
static QList<int> variantToIntList(const QVariant& variant);
|
||||||
static QVariant intListToVariant(const QList<int>& list);
|
static QVariant intListToVariant(const QList<int>& list);
|
||||||
|
|
||||||
DatabaseWidget* m_activeDbWidget;
|
QPointer<DatabaseWidget> m_activeDbWidget;
|
||||||
|
|
||||||
bool m_blockUpdates;
|
bool m_blockUpdates;
|
||||||
QList<int> m_mainSplitterSizes;
|
QList<int> m_mainSplitterSizes;
|
||||||
|
@ -271,7 +271,7 @@ void EditEntryWidget::setupSSHAgent()
|
|||||||
m_sshAgentUi->publicKeyEdit->setFont(fixedFont);
|
m_sshAgentUi->publicKeyEdit->setFont(fixedFont);
|
||||||
|
|
||||||
connect(m_sshAgentUi->attachmentRadioButton, SIGNAL(clicked(bool)), SLOT(updateSSHAgentKeyInfo()));
|
connect(m_sshAgentUi->attachmentRadioButton, SIGNAL(clicked(bool)), SLOT(updateSSHAgentKeyInfo()));
|
||||||
connect(m_sshAgentUi->attachmentComboBox, SIGNAL(currentIndexChanged(int)), SLOT(updateSSHAgentKeyInfo()));
|
connect(m_sshAgentUi->attachmentComboBox, SIGNAL(currentIndexChanged(int)), SLOT(updateSSHAgentAttachment()));
|
||||||
connect(m_sshAgentUi->externalFileRadioButton, SIGNAL(clicked(bool)), SLOT(updateSSHAgentKeyInfo()));
|
connect(m_sshAgentUi->externalFileRadioButton, SIGNAL(clicked(bool)), SLOT(updateSSHAgentKeyInfo()));
|
||||||
connect(m_sshAgentUi->externalFileEdit, SIGNAL(textChanged(QString)), SLOT(updateSSHAgentKeyInfo()));
|
connect(m_sshAgentUi->externalFileEdit, SIGNAL(textChanged(QString)), SLOT(updateSSHAgentKeyInfo()));
|
||||||
connect(m_sshAgentUi->browseButton, SIGNAL(clicked()), SLOT(browsePrivateKey()));
|
connect(m_sshAgentUi->browseButton, SIGNAL(clicked()), SLOT(browsePrivateKey()));
|
||||||
@ -323,6 +323,12 @@ void EditEntryWidget::updateSSHAgent()
|
|||||||
updateSSHAgentKeyInfo();
|
updateSSHAgentKeyInfo();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EditEntryWidget::updateSSHAgentAttachment()
|
||||||
|
{
|
||||||
|
m_sshAgentUi->attachmentRadioButton->setChecked(true);
|
||||||
|
updateSSHAgentKeyInfo();
|
||||||
|
}
|
||||||
|
|
||||||
void EditEntryWidget::updateSSHAgentKeyInfo()
|
void EditEntryWidget::updateSSHAgentKeyInfo()
|
||||||
{
|
{
|
||||||
m_sshAgentUi->addToAgentButton->setEnabled(false);
|
m_sshAgentUi->addToAgentButton->setEnabled(false);
|
||||||
@ -398,6 +404,8 @@ void EditEntryWidget::browsePrivateKey()
|
|||||||
QString fileName = QFileDialog::getOpenFileName(this, tr("Select private key"), "");
|
QString fileName = QFileDialog::getOpenFileName(this, tr("Select private key"), "");
|
||||||
if (!fileName.isEmpty()) {
|
if (!fileName.isEmpty()) {
|
||||||
m_sshAgentUi->externalFileEdit->setText(fileName);
|
m_sshAgentUi->externalFileEdit->setText(fileName);
|
||||||
|
m_sshAgentUi->externalFileRadioButton->setChecked(true);
|
||||||
|
updateSSHAgentKeyInfo();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,6 +101,7 @@ private slots:
|
|||||||
void toggleHideNotes(bool visible);
|
void toggleHideNotes(bool visible);
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef WITH_XC_SSHAGENT
|
||||||
void updateSSHAgent();
|
void updateSSHAgent();
|
||||||
|
void updateSSHAgentAttachment();
|
||||||
void updateSSHAgentKeyInfo();
|
void updateSSHAgentKeyInfo();
|
||||||
void browsePrivateKey();
|
void browsePrivateKey();
|
||||||
void addKeyToAgent();
|
void addKeyToAgent();
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
|
* Copyright (C) 2018 KeePassXC Team <team@keepassxc.org>
|
||||||
* Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
* Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
@ -88,11 +89,11 @@ EntryView::EntryView(QWidget* parent)
|
|||||||
// Stretching of last section interferes with fitting columns to window
|
// Stretching of last section interferes with fitting columns to window
|
||||||
header()->setStretchLastSection(false);
|
header()->setStretchLastSection(false);
|
||||||
header()->setContextMenuPolicy(Qt::CustomContextMenu);
|
header()->setContextMenuPolicy(Qt::CustomContextMenu);
|
||||||
connect(header(), SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(showHeaderMenu(QPoint)));
|
connect(header(), SIGNAL(customContextMenuRequested(QPoint)), SLOT(showHeaderMenu(QPoint)));
|
||||||
connect(header(), SIGNAL(sectionCountChanged(int, int)), this, SIGNAL(viewStateChanged()));
|
connect(header(), SIGNAL(sectionCountChanged(int, int)), SIGNAL(viewStateChanged()));
|
||||||
connect(header(), SIGNAL(sectionMoved(int, int, int)), this, SIGNAL(viewStateChanged()));
|
connect(header(), SIGNAL(sectionMoved(int, int, int)), SIGNAL(viewStateChanged()));
|
||||||
connect(header(), SIGNAL(sectionResized(int, int, int)), this, SIGNAL(viewStateChanged()));
|
connect(header(), SIGNAL(sectionResized(int, int, int)), SIGNAL(viewStateChanged()));
|
||||||
connect(header(), SIGNAL(sortIndicatorChanged(int, Qt::SortOrder)), this, SIGNAL(viewStateChanged()));
|
connect(header(), SIGNAL(sortIndicatorChanged(int, Qt::SortOrder)), SIGNAL(viewStateChanged()));
|
||||||
|
|
||||||
// TODO: not working as expected, columns will end up being very small,
|
// TODO: not working as expected, columns will end up being very small,
|
||||||
// most likely due to the widget not being sized properly at this time
|
// most likely due to the widget not being sized properly at this time
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
|
* Copyright (C) 2018 KeePassXC Team <team@keepassxc.org>
|
||||||
* Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
* Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
Loading…
Reference in New Issue
Block a user