mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-21 20:21:10 -05:00
596d2cf425
Replaces all string configuration options with enum types that can be checked by the compiler. This prevents spelling errors, in-place configuration definitions, and inconsistent default values. The default value config getter signature was removed in favour of consistently and centrally default-initialised configuration values. Individual default values were adjusted for better security, such as the default password length, which was increased from 16 characters to 32. The already existing config option deprecation map was extended by a general migration procedure using configuration versioning. Settings were split into Roaming and Local settings, which go to their respective AppData locations on Windows. Fixes #2574 Fixes #2193
99 lines
2.9 KiB
C++
99 lines
2.9 KiB
C++
/*
|
|
* Copyright (C) 2018 Aetf <aetf@unlimitedcodeworks.xyz>
|
|
*
|
|
* 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
|
|
* the Free Software Foundation, either version 2 or (at your option)
|
|
* version 3 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "FdoSecretsSettings.h"
|
|
|
|
#include "core/Config.h"
|
|
#include "core/CustomData.h"
|
|
#include "core/Database.h"
|
|
#include "core/Metadata.h"
|
|
|
|
namespace Keys
|
|
{
|
|
namespace Db
|
|
{
|
|
constexpr auto FdoSecretsExposedGroup = "FDO_SECRETS_EXPOSED_GROUP";
|
|
} // namespace Db
|
|
|
|
} // namespace Keys
|
|
|
|
namespace FdoSecrets
|
|
{
|
|
|
|
FdoSecretsSettings* FdoSecretsSettings::m_instance = nullptr;
|
|
|
|
FdoSecretsSettings* FdoSecretsSettings::instance()
|
|
{
|
|
if (!m_instance) {
|
|
m_instance = new FdoSecretsSettings;
|
|
}
|
|
return m_instance;
|
|
}
|
|
|
|
bool FdoSecretsSettings::isEnabled() const
|
|
{
|
|
return config()->get(Config::FdoSecrets_Enabled).toBool();
|
|
}
|
|
|
|
void FdoSecretsSettings::setEnabled(bool enabled)
|
|
{
|
|
config()->set(Config::FdoSecrets_Enabled, enabled);
|
|
}
|
|
|
|
bool FdoSecretsSettings::showNotification() const
|
|
{
|
|
return config()->get(Config::FdoSecrets_ShowNotification).toBool();
|
|
}
|
|
|
|
void FdoSecretsSettings::setShowNotification(bool show)
|
|
{
|
|
config()->set(Config::FdoSecrets_ShowNotification, show);
|
|
}
|
|
|
|
bool FdoSecretsSettings::noConfirmDeleteItem() const
|
|
{
|
|
return config()->get(Config::FdoSecrets_NoConfirmDeleteItem).toBool();
|
|
}
|
|
|
|
void FdoSecretsSettings::setNoConfirmDeleteItem(bool noConfirm)
|
|
{
|
|
config()->set(Config::FdoSecrets_NoConfirmDeleteItem, noConfirm);
|
|
}
|
|
|
|
QUuid FdoSecretsSettings::exposedGroup(const QSharedPointer<Database>& db) const
|
|
{
|
|
return exposedGroup(db.data());
|
|
}
|
|
|
|
void FdoSecretsSettings::setExposedGroup(const QSharedPointer<Database>& db,
|
|
const QUuid& group) // clazy:exclude=function-args-by-value
|
|
{
|
|
setExposedGroup(db.data(), group);
|
|
}
|
|
|
|
QUuid FdoSecretsSettings::exposedGroup(Database* db) const
|
|
{
|
|
return {db->metadata()->customData()->value(Keys::Db::FdoSecretsExposedGroup)};
|
|
}
|
|
|
|
void FdoSecretsSettings::setExposedGroup(Database* db, const QUuid& group) // clazy:exclude=function-args-by-value
|
|
{
|
|
db->metadata()->customData()->set(Keys::Db::FdoSecretsExposedGroup, group.toString());
|
|
}
|
|
|
|
} // namespace FdoSecrets
|