keepassxc/src/core/EntryAttachments.cpp

171 lines
3.9 KiB
C++
Raw Normal View History

/*
* 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"
2019-01-17 01:23:22 -05:00
#include "core/Global.h"
#include <QSet>
2018-03-31 16:01:30 -04:00
#include <QStringList>
EntryAttachments::EntryAttachments(QObject* parent)
: QObject(parent)
{
}
QList<QString> EntryAttachments::keys() const
{
return m_attachments.keys();
}
2014-12-03 17:36:24 -05:00
bool EntryAttachments::hasKey(const QString& key) const
{
2017-09-24 05:45:58 -04:00
return m_attachments.contains(key);
2014-12-03 17:36:24 -05:00
}
QSet<QByteArray> EntryAttachments::values() const
{
2019-01-17 01:23:22 -05:00
return asConst(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);
2018-03-31 16:01:30 -04:00
} else {
emit keyModified(key);
}
if (emitModified) {
emit entryAttachmentsModified();
}
}
void EntryAttachments::remove(const QString& key)
{
if (!m_attachments.contains(key)) {
2018-03-31 16:01:30 -04:00
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;
2018-03-31 16:01:30 -04:00
for (const QString& key : keys) {
if (!m_attachments.contains(key)) {
2018-03-31 16:01:30 -04:00
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();
}
}
void EntryAttachments::rename(const QString& key, const QString& newKey)
{
const QByteArray val = value(key);
remove(key);
set(newKey, val);
}
2017-12-13 15:22:31 -05:00
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;
}