blob: cfec77fe583f6139da23d605734d39fa82526906 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
/*
* Copyright (C) 2019 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/>.
*/
#ifndef KEEPASSXC_FDOSECRETS_ITEM_H
#define KEEPASSXC_FDOSECRETS_ITEM_H
#include "fdosecrets/objects/DBusObject.h"
#include "fdosecrets/objects/adaptors/ItemAdaptor.h"
#include <QPointer>
class Entry;
namespace FdoSecrets
{
namespace ItemAttributes
{
constexpr const auto UuidKey = "Uuid";
constexpr const auto PathKey = "Path";
} // namespace ItemAttributes
class Session;
class Collection;
class PromptBase;
class Item : public DBusObject
{
Q_OBJECT
public:
explicit Item(Collection* parent, Entry* backend);
DBusReturn<bool> locked() const;
DBusReturn<const StringStringMap> attributes() const;
DBusReturn<void> setAttributes(const StringStringMap& attrs);
DBusReturn<QString> label() const;
DBusReturn<void> setLabel(const QString& label);
DBusReturn<qulonglong> created() const;
DBusReturn<qulonglong> modified() const;
DBusReturn<PromptBase*> deleteItem();
DBusReturn<SecretStruct> getSecret(Session* session);
DBusReturn<void> setSecret(const SecretStruct& secret);
signals:
void itemChanged();
void itemAboutToDelete();
public:
static const QSet<QString> ReadOnlyAttributes;
/**
* Due to the limitation in EntrySearcher, custom attr key cannot contain ':',
* Thus we encode the key when saving and decode it when returning.
* @param key
* @return
*/
static QString encodeAttributeKey(const QString& key);
static QString decodeAttributeKey(const QString& key);
DBusReturn<void> setProperties(const QVariantMap& properties);
Entry* backend() const;
Collection* collection() const;
Service* service() const;
/**
* Compute the entry path relative to the exposed group
* @return the entry path
*/
QString path() const;
public slots:
void doDelete();
private:
/**
* Check if the backend is a valid object, send error reply if not.
* @return No error if the backend is valid.
*/
DBusReturn<void> ensureBackend() const;
/**
* Ensure the database is unlocked, send error reply if locked.
* @return true if the database is locked
*/
DBusReturn<void> ensureUnlocked() const;
private:
QPointer<Entry> m_backend;
};
} // namespace FdoSecrets
#endif // KEEPASSXC_FDOSECRETS_ITEM_H
|