diff --git a/src/kleo/keygroup.cpp b/src/kleo/keygroup.cpp index 378b7e7d0..02ee4e172 100644 --- a/src/kleo/keygroup.cpp +++ b/src/kleo/keygroup.cpp @@ -1,121 +1,134 @@ /* kleo/keygroup.cpp This file is part of libkleopatra, the KDE keymanagement library SPDX-FileCopyrightText: 2021 g10 Code GmbH SPDX-FileContributor: Ingo Klöcker SPDX-License-Identifier: GPL-2.0-or-later */ #include "keygroup.h" #include #include using namespace Kleo; using namespace GpgME; static const KeyGroup::Id nullId = -1; class KeyGroup::Private { public: explicit Private(Id id, const QString &name, const std::vector &keys, Source source); Id id; QString name; QString configName; Keys keys; Source source; + bool isImmutable = true; }; KeyGroup::Private::Private(Id id, const QString &name, const std::vector &keys, Source source) : id(id) , name(name) , keys(keys.cbegin(), keys.cend()) , source(source) { } KeyGroup::KeyGroup() : KeyGroup(nullId, QString(), {}, UnknownSource) { } KeyGroup::~KeyGroup() = default; KeyGroup::KeyGroup(Id id, const QString &name, const std::vector &keys, Source source) : d(new Private(id, name, keys, source)) { } KeyGroup::KeyGroup(const KeyGroup &other) : d(new Private(*other.d)) { } KeyGroup &KeyGroup::operator=(const KeyGroup &other) { *d = *other.d; return *this; } KeyGroup::KeyGroup(KeyGroup &&other) = default; KeyGroup &KeyGroup::operator=(KeyGroup &&other) = default; bool KeyGroup::isNull() const { return !d || d->id == nullId; } KeyGroup::Id KeyGroup::id() const { return d ? d->id : nullId; } QString KeyGroup::name() const { return d ? d->name : QString(); } const KeyGroup::Keys &KeyGroup::keys() const { static const Keys empty; return d ? d->keys : empty; } KeyGroup::Source KeyGroup::source() const { return d ? d->source : UnknownSource; } void KeyGroup::setConfigName(const QString &configName) { if (d) { d->configName = configName; } } QString KeyGroup::configName() const { return d ? d->configName : QString(); } +void KeyGroup::setIsImmutable(bool isImmutable) +{ + if (d) { + d->isImmutable = isImmutable; + } +} + +bool KeyGroup::isImmutable() const +{ + return d ? d->isImmutable : true; +} + bool KeyGroup::insert(const GpgME::Key &key) { if (!d || key.isNull()) { return false; } return d->keys.insert(key).second; } bool KeyGroup::erase(const GpgME::Key &key) { if (!d || key.isNull()) { return false; } return d->keys.erase(key) > 0; } diff --git a/src/kleo/keygroup.h b/src/kleo/keygroup.h index 5c15cafe4..b4866d01e 100644 --- a/src/kleo/keygroup.h +++ b/src/kleo/keygroup.h @@ -1,76 +1,79 @@ /* kleo/keygroup.h This file is part of libkleopatra, the KDE keymanagement library SPDX-FileCopyrightText: 2021 g10 Code GmbH SPDX-FileContributor: Ingo Klöcker SPDX-License-Identifier: GPL-2.0-or-later */ #ifndef LIBKLEO_KEYGROUP_H #define LIBKLEO_KEYGROUP_H #include "kleo_export.h" #include #include #include #include class QString; namespace GpgME { class Key; } namespace Kleo { class KLEO_EXPORT KeyGroup { public: typedef int32_t Id; typedef std::set> Keys; enum Source { UnknownSource, ApplicationConfig, GnuPGConfig, Tags }; KeyGroup(); ~KeyGroup(); explicit KeyGroup(Id id, const QString &name, const std::vector &keys, Source source); KeyGroup(const KeyGroup &other); KeyGroup &operator=(const KeyGroup &other); KeyGroup(KeyGroup &&other); KeyGroup &operator=(KeyGroup &&other); bool isNull() const; Id id() const; QString name() const; const Keys &keys() const; Source source() const; void setConfigName(const QString &configName); QString configName() const; + void setIsImmutable(bool isImmutable); + bool isImmutable() const; + bool insert(const GpgME::Key &key); bool erase(const GpgME::Key &key); private: class Private; std::unique_ptr d; }; } #endif // LIBKLEO_KEYGROUP_H diff --git a/src/models/keycache.cpp b/src/models/keycache.cpp index 780df5517..74f8b490b 100644 --- a/src/models/keycache.cpp +++ b/src/models/keycache.cpp @@ -1,1456 +1,1500 @@ /* -*- mode: c++; c-basic-offset:4 -*- models/keycache.cpp This file is part of Kleopatra, the KDE keymanager SPDX-FileCopyrightText: 2007, 2008 Klarälvdalens Datakonsult AB SPDX-FileCopyrightText: 2018 Intevation GmbH SPDX-FileCopyrightText: 2020 g10 Code GmbH SPDX-FileContributor: Ingo Klöcker SPDX-License-Identifier: GPL-2.0-or-later */ #include "keycache.h" #include "keycache_p.h" #include "libkleo_debug.h" #include "kleo/keygroup.h" #include "kleo/predicates.h" #include "kleo/stl_util.h" #include "kleo/dn.h" #include "utils/filesystemwatcher.h" #include #include #include #include #include #include #include #include #include #include #include #include //#include #include #include #include #include #include #include #include using namespace Kleo; using namespace GpgME; using namespace KMime::Types; static const unsigned int hours2ms = 1000 * 60 * 60; +static const QString groupNamePrefix = QStringLiteral("Group-"); + // // // KeyCache // // namespace { make_comparator_str(ByEMail, .first.c_str()); } class KeyCache::Private { friend class ::Kleo::KeyCache; KeyCache *const q; public: explicit Private(KeyCache *qq) : q(qq), m_refreshInterval(1), m_initalized(false), m_pgpOnly(true), m_remarks_enabled(false) { connect(&m_autoKeyListingTimer, &QTimer::timeout, q, [this]() { q->startKeyListing(); }); updateAutoKeyListingTimer(); } ~Private() { if (m_refreshJob) { m_refreshJob->cancel(); } } template < template