diff options
author | Christian Mollekopf <chrigi_1@fastmail.fm> | 2016-06-23 17:05:47 +0200 |
---|---|---|
committer | Christian Mollekopf <chrigi_1@fastmail.fm> | 2016-06-25 23:34:51 +0200 |
commit | b29a17465d1e52bd7dd5c57f08e7af53e915eee6 (patch) | |
tree | ab618b5f0a1c89ba1332723b5ebad03bce92fb2c /examples/imapresource/imapresource.cpp | |
parent | 2ce8dcf40f22dd4e9cf4a6b1c8f5386993ebba6e (diff) | |
download | sink-b29a17465d1e52bd7dd5c57f08e7af53e915eee6.tar.gz sink-b29a17465d1e52bd7dd5c57f08e7af53e915eee6.zip |
Share special purpose preprocessor implementation.
Diffstat (limited to 'examples/imapresource/imapresource.cpp')
-rw-r--r-- | examples/imapresource/imapresource.cpp | 88 |
1 files changed, 5 insertions, 83 deletions
diff --git a/examples/imapresource/imapresource.cpp b/examples/imapresource/imapresource.cpp index 18747bf..605dbc2 100644 --- a/examples/imapresource/imapresource.cpp +++ b/examples/imapresource/imapresource.cpp | |||
@@ -48,6 +48,7 @@ | |||
48 | #include "imapserverproxy.h" | 48 | #include "imapserverproxy.h" |
49 | #include "entityreader.h" | 49 | #include "entityreader.h" |
50 | #include "mailpreprocessor.h" | 50 | #include "mailpreprocessor.h" |
51 | #include "specialpurposepreprocessor.h" | ||
51 | 52 | ||
52 | //This is the resources entity type, and not the domain type | 53 | //This is the resources entity type, and not the domain type |
53 | #define ENTITY_TYPE_MAIL "mail" | 54 | #define ENTITY_TYPE_MAIL "mail" |
@@ -59,85 +60,6 @@ | |||
59 | using namespace Imap; | 60 | using namespace Imap; |
60 | using namespace Sink; | 61 | using namespace Sink; |
61 | 62 | ||
62 | static QHash<QByteArray, QString> specialPurposeFolders() | ||
63 | { | ||
64 | QHash<QByteArray, QString> hash; | ||
65 | //FIXME localize | ||
66 | hash.insert("drafts", "Drafts"); | ||
67 | hash.insert("trash", "Trash"); | ||
68 | return hash; | ||
69 | } | ||
70 | |||
71 | static QHash<QString, QByteArray> specialPurposeNames() | ||
72 | { | ||
73 | QHash<QString, QByteArray> hash; | ||
74 | for (const auto &value : specialPurposeFolders().values()) { | ||
75 | hash.insert(value.toLower(), specialPurposeFolders().key(value)); | ||
76 | } | ||
77 | return hash; | ||
78 | } | ||
79 | |||
80 | //specialpurpose, name | ||
81 | static QHash<QByteArray, QString> sSpecialPurposeFolders = specialPurposeFolders(); | ||
82 | //Lowercase-name, specialpurpose | ||
83 | static QHash<QString, QByteArray> sSpecialPurposeNames = specialPurposeNames(); | ||
84 | |||
85 | class SpecialPurposeProcessor : public Sink::Preprocessor | ||
86 | { | ||
87 | public: | ||
88 | SpecialPurposeProcessor(const QByteArray &resourceType, const QByteArray &resourceInstanceIdentifier) : mResourceType(resourceType), mResourceInstanceIdentifier(resourceInstanceIdentifier) {} | ||
89 | |||
90 | QByteArray ensureFolder(Sink::Storage::Transaction &transaction, const QByteArray &specialPurpose) | ||
91 | { | ||
92 | if (!mSpecialPurposeFolders.contains(specialPurpose)) { | ||
93 | //Try to find an existing drafts folder | ||
94 | Sink::EntityReader<ApplicationDomain::Folder> reader(mResourceType, mResourceInstanceIdentifier, transaction); | ||
95 | reader.query(Sink::Query().filter<ApplicationDomain::Folder::SpecialPurpose>(Query::Comparator("drafts", Query::Comparator::Contains)), | ||
96 | [this, specialPurpose](const ApplicationDomain::Folder &f) -> bool{ | ||
97 | mSpecialPurposeFolders.insert(specialPurpose, f.identifier()); | ||
98 | return false; | ||
99 | }); | ||
100 | if (!mSpecialPurposeFolders.contains(specialPurpose)) { | ||
101 | Trace() << "Failed to find a drafts folder, creating a new one"; | ||
102 | auto folder = ApplicationDomain::Folder::create(mResourceInstanceIdentifier); | ||
103 | folder.setSpecialPurpose(QByteArrayList() << specialPurpose); | ||
104 | folder.setName(sSpecialPurposeFolders.value(specialPurpose)); | ||
105 | folder.setIcon("folder"); | ||
106 | //This processes the pipeline synchronously | ||
107 | createEntity(folder); | ||
108 | mSpecialPurposeFolders.insert(specialPurpose, folder.identifier()); | ||
109 | } | ||
110 | } | ||
111 | return mSpecialPurposeFolders.value(specialPurpose); | ||
112 | } | ||
113 | |||
114 | void moveToFolder(Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) | ||
115 | { | ||
116 | if (newEntity.getProperty("trash").toBool()) { | ||
117 | newEntity.setProperty("folder", ensureFolder(transaction, "trash")); | ||
118 | return; | ||
119 | } | ||
120 | if (newEntity.getProperty("draft").toBool()) { | ||
121 | newEntity.setProperty("folder", ensureFolder(transaction, "drafts")); | ||
122 | } | ||
123 | } | ||
124 | |||
125 | void newEntity(const QByteArray &uid, qint64 revision, Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) Q_DECL_OVERRIDE | ||
126 | { | ||
127 | moveToFolder(newEntity, transaction); | ||
128 | } | ||
129 | |||
130 | void modifiedEntity(const QByteArray &uid, qint64 revision, const Sink::ApplicationDomain::BufferAdaptor &oldEntity, Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) Q_DECL_OVERRIDE | ||
131 | { | ||
132 | moveToFolder(newEntity, transaction); | ||
133 | } | ||
134 | |||
135 | QHash<QByteArray, QByteArray> mSpecialPurposeFolders; | ||
136 | QByteArray mResourceType; | ||
137 | QByteArray mResourceInstanceIdentifier; | ||
138 | }; | ||
139 | |||
140 | |||
141 | static qint64 uidFromMailRid(const QByteArray &remoteId) | 63 | static qint64 uidFromMailRid(const QByteArray &remoteId) |
142 | { | 64 | { |
143 | auto ridParts = remoteId.split(':'); | 65 | auto ridParts = remoteId.split(':'); |
@@ -180,8 +102,8 @@ public: | |||
180 | folder.setProperty(ApplicationDomain::Folder::Name::name, folderName); | 102 | folder.setProperty(ApplicationDomain::Folder::Name::name, folderName); |
181 | folder.setProperty(ApplicationDomain::Folder::Icon::name, icon); | 103 | folder.setProperty(ApplicationDomain::Folder::Icon::name, icon); |
182 | QHash<QByteArray, Query::Comparator> mergeCriteria; | 104 | QHash<QByteArray, Query::Comparator> mergeCriteria; |
183 | if (sSpecialPurposeNames.contains(folderName.toLower())) { | 105 | if (SpecialPurpose::isSpecialPurposeFolderName(folderName)) { |
184 | auto type = sSpecialPurposeNames.value(folderName.toLower()); | 106 | auto type = SpecialPurpose::getSpecialPurposeType(folderName); |
185 | folder.setProperty(ApplicationDomain::Folder::SpecialPurpose::name, QVariant::fromValue(QByteArrayList() << type)); | 107 | folder.setProperty(ApplicationDomain::Folder::SpecialPurpose::name, QVariant::fromValue(QByteArrayList() << type)); |
186 | mergeCriteria.insert(ApplicationDomain::Folder::SpecialPurpose::name, Query::Comparator(type, Query::Comparator::Contains)); | 108 | mergeCriteria.insert(ApplicationDomain::Folder::SpecialPurpose::name, Query::Comparator(type, Query::Comparator::Contains)); |
187 | } | 109 | } |
@@ -481,8 +403,8 @@ public: | |||
481 | auto mergeJob = imap->login(mUser, mPassword) | 403 | auto mergeJob = imap->login(mUser, mPassword) |
482 | .then<void>(imap->fetchFolders([=](const QVector<Imap::Folder> &folders) { | 404 | .then<void>(imap->fetchFolders([=](const QVector<Imap::Folder> &folders) { |
483 | for (const auto &f : folders) { | 405 | for (const auto &f : folders) { |
484 | if (sSpecialPurposeNames.contains(f.pathParts.last().toLower())) { | 406 | if (SpecialPurpose::isSpecialPurposeFolderName(f.pathParts.last())) { |
485 | specialPurposeFolders->insert(sSpecialPurposeNames.value(f.pathParts.last().toLower()), f.path); | 407 | specialPurposeFolders->insert(SpecialPurpose::getSpecialPurposeType(f.pathParts.last()), f.path); |
486 | }; | 408 | }; |
487 | } | 409 | } |
488 | })) | 410 | })) |