mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-10 14:59:51 -05:00
d612cad09a
The Database, DatabaseWidget, and DatabaseTabWidget classes share many responsibilities in inconsistent ways resulting in impenetrable and unmaintainable code and a diverse set of bugs and architecture restrictions. This patch reworks the architecture, responsibilities of, and dependencies between these classes. The core changes are: * Move loading and saving logic from widgets into the Database class * Get rid of the DatabaseManagerStruct and move all the information contained in it into the Database * Let database objects keep track of modifications and dirty/clean state instead of handing this to external widgets * Move GUI interactions for loading and saving from the DatabaseTabWidget into the DatabaseWidget (resolves #2494 as a side-effect) * Heavily clean up DatabaseTabWidget and degrade it to a slightly glorified QTabWidget * Use QSharedPointers for all Database objects * Remove the modifiedImmediate signal and replace it with a markAsModified() method * Implement proper tabName() method instead of reading back titles from GUI widgets (resolves #1389 and its duplicates #2146 #855) * Fix unwanted AES-KDF downgrade if database uses Argon2 and has CustomData * Improve code This patch is also the first major step towards solving issues #476 and #2322.
162 lines
3.7 KiB
C++
162 lines
3.7 KiB
C++
/*
|
|
* Copyright (C) 2012 Felix Geyer <debfx@fobos.de>
|
|
*
|
|
* 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 "EntryAttachments.h"
|
|
|
|
#include <QSet>
|
|
#include <QStringList>
|
|
|
|
EntryAttachments::EntryAttachments(QObject* parent)
|
|
: QObject(parent)
|
|
{
|
|
}
|
|
|
|
QList<QString> EntryAttachments::keys() const
|
|
{
|
|
return m_attachments.keys();
|
|
}
|
|
|
|
bool EntryAttachments::hasKey(const QString& key) const
|
|
{
|
|
return m_attachments.contains(key);
|
|
}
|
|
|
|
QSet<QByteArray> EntryAttachments::values() const
|
|
{
|
|
return m_attachments.values().toSet();
|
|
}
|
|
|
|
QByteArray EntryAttachments::value(const QString& key) const
|
|
{
|
|
return m_attachments.value(key);
|
|
}
|
|
|
|
void EntryAttachments::set(const QString& key, const QByteArray& value)
|
|
{
|
|
bool emitModified = false;
|
|
bool addAttachment = !m_attachments.contains(key);
|
|
|
|
if (addAttachment) {
|
|
emit aboutToBeAdded(key);
|
|
}
|
|
|
|
if (addAttachment || m_attachments.value(key) != value) {
|
|
m_attachments.insert(key, value);
|
|
emitModified = true;
|
|
}
|
|
|
|
if (addAttachment) {
|
|
emit added(key);
|
|
} else {
|
|
emit keyModified(key);
|
|
}
|
|
|
|
if (emitModified) {
|
|
emit entryAttachmentsModified();
|
|
}
|
|
}
|
|
|
|
void EntryAttachments::remove(const QString& key)
|
|
{
|
|
if (!m_attachments.contains(key)) {
|
|
Q_ASSERT_X(false, "EntryAttachments::remove", qPrintable(QString("Can't find attachment for key %1").arg(key)));
|
|
return;
|
|
}
|
|
|
|
emit aboutToBeRemoved(key);
|
|
|
|
m_attachments.remove(key);
|
|
|
|
emit removed(key);
|
|
emit entryAttachmentsModified();
|
|
}
|
|
|
|
void EntryAttachments::remove(const QStringList& keys)
|
|
{
|
|
if (keys.isEmpty()) {
|
|
return;
|
|
}
|
|
|
|
bool isModified = false;
|
|
for (const QString& key : keys) {
|
|
if (!m_attachments.contains(key)) {
|
|
Q_ASSERT_X(
|
|
false, "EntryAttachments::remove", qPrintable(QString("Can't find attachment for key %1").arg(key)));
|
|
continue;
|
|
}
|
|
|
|
isModified = true;
|
|
emit aboutToBeRemoved(key);
|
|
m_attachments.remove(key);
|
|
emit removed(key);
|
|
}
|
|
|
|
if (isModified) {
|
|
emit entryAttachmentsModified();
|
|
}
|
|
}
|
|
|
|
bool EntryAttachments::isEmpty() const
|
|
{
|
|
return m_attachments.isEmpty();
|
|
}
|
|
|
|
void EntryAttachments::clear()
|
|
{
|
|
if (m_attachments.isEmpty()) {
|
|
return;
|
|
}
|
|
|
|
emit aboutToBeReset();
|
|
|
|
m_attachments.clear();
|
|
|
|
emit reset();
|
|
emit entryAttachmentsModified();
|
|
}
|
|
|
|
void EntryAttachments::copyDataFrom(const EntryAttachments* other)
|
|
{
|
|
if (*this != *other) {
|
|
emit aboutToBeReset();
|
|
|
|
m_attachments = other->m_attachments;
|
|
|
|
emit reset();
|
|
emit entryAttachmentsModified();
|
|
}
|
|
}
|
|
|
|
bool EntryAttachments::operator==(const EntryAttachments& other) const
|
|
{
|
|
return m_attachments == other.m_attachments;
|
|
}
|
|
|
|
bool EntryAttachments::operator!=(const EntryAttachments& other) const
|
|
{
|
|
return m_attachments != other.m_attachments;
|
|
}
|
|
|
|
int EntryAttachments::attachmentsSize() const
|
|
{
|
|
int size = 0;
|
|
for (auto it = m_attachments.constBegin(); it != m_attachments.constEnd(); ++it) {
|
|
size += it.key().toUtf8().size() + it.value().size();
|
|
}
|
|
return size;
|
|
}
|