From b29a17465d1e52bd7dd5c57f08e7af53e915eee6 Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Thu, 23 Jun 2016 17:05:47 +0200 Subject: Share special purpose preprocessor implementation. --- examples/imapresource/imapresource.cpp | 88 ++-------------------------------- 1 file changed, 5 insertions(+), 83 deletions(-) (limited to 'examples/imapresource/imapresource.cpp') 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 @@ #include "imapserverproxy.h" #include "entityreader.h" #include "mailpreprocessor.h" +#include "specialpurposepreprocessor.h" //This is the resources entity type, and not the domain type #define ENTITY_TYPE_MAIL "mail" @@ -59,85 +60,6 @@ using namespace Imap; using namespace Sink; -static QHash specialPurposeFolders() -{ - QHash hash; - //FIXME localize - hash.insert("drafts", "Drafts"); - hash.insert("trash", "Trash"); - return hash; -} - -static QHash specialPurposeNames() -{ - QHash hash; - for (const auto &value : specialPurposeFolders().values()) { - hash.insert(value.toLower(), specialPurposeFolders().key(value)); - } - return hash; -} - -//specialpurpose, name -static QHash sSpecialPurposeFolders = specialPurposeFolders(); -//Lowercase-name, specialpurpose -static QHash sSpecialPurposeNames = specialPurposeNames(); - -class SpecialPurposeProcessor : public Sink::Preprocessor -{ -public: - SpecialPurposeProcessor(const QByteArray &resourceType, const QByteArray &resourceInstanceIdentifier) : mResourceType(resourceType), mResourceInstanceIdentifier(resourceInstanceIdentifier) {} - - QByteArray ensureFolder(Sink::Storage::Transaction &transaction, const QByteArray &specialPurpose) - { - if (!mSpecialPurposeFolders.contains(specialPurpose)) { - //Try to find an existing drafts folder - Sink::EntityReader reader(mResourceType, mResourceInstanceIdentifier, transaction); - reader.query(Sink::Query().filter(Query::Comparator("drafts", Query::Comparator::Contains)), - [this, specialPurpose](const ApplicationDomain::Folder &f) -> bool{ - mSpecialPurposeFolders.insert(specialPurpose, f.identifier()); - return false; - }); - if (!mSpecialPurposeFolders.contains(specialPurpose)) { - Trace() << "Failed to find a drafts folder, creating a new one"; - auto folder = ApplicationDomain::Folder::create(mResourceInstanceIdentifier); - folder.setSpecialPurpose(QByteArrayList() << specialPurpose); - folder.setName(sSpecialPurposeFolders.value(specialPurpose)); - folder.setIcon("folder"); - //This processes the pipeline synchronously - createEntity(folder); - mSpecialPurposeFolders.insert(specialPurpose, folder.identifier()); - } - } - return mSpecialPurposeFolders.value(specialPurpose); - } - - void moveToFolder(Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) - { - if (newEntity.getProperty("trash").toBool()) { - newEntity.setProperty("folder", ensureFolder(transaction, "trash")); - return; - } - if (newEntity.getProperty("draft").toBool()) { - newEntity.setProperty("folder", ensureFolder(transaction, "drafts")); - } - } - - void newEntity(const QByteArray &uid, qint64 revision, Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) Q_DECL_OVERRIDE - { - moveToFolder(newEntity, transaction); - } - - void modifiedEntity(const QByteArray &uid, qint64 revision, const Sink::ApplicationDomain::BufferAdaptor &oldEntity, Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) Q_DECL_OVERRIDE - { - moveToFolder(newEntity, transaction); - } - - QHash mSpecialPurposeFolders; - QByteArray mResourceType; - QByteArray mResourceInstanceIdentifier; -}; - - static qint64 uidFromMailRid(const QByteArray &remoteId) { auto ridParts = remoteId.split(':'); @@ -180,8 +102,8 @@ public: folder.setProperty(ApplicationDomain::Folder::Name::name, folderName); folder.setProperty(ApplicationDomain::Folder::Icon::name, icon); QHash mergeCriteria; - if (sSpecialPurposeNames.contains(folderName.toLower())) { - auto type = sSpecialPurposeNames.value(folderName.toLower()); + if (SpecialPurpose::isSpecialPurposeFolderName(folderName)) { + auto type = SpecialPurpose::getSpecialPurposeType(folderName); folder.setProperty(ApplicationDomain::Folder::SpecialPurpose::name, QVariant::fromValue(QByteArrayList() << type)); mergeCriteria.insert(ApplicationDomain::Folder::SpecialPurpose::name, Query::Comparator(type, Query::Comparator::Contains)); } @@ -481,8 +403,8 @@ public: auto mergeJob = imap->login(mUser, mPassword) .then(imap->fetchFolders([=](const QVector &folders) { for (const auto &f : folders) { - if (sSpecialPurposeNames.contains(f.pathParts.last().toLower())) { - specialPurposeFolders->insert(sSpecialPurposeNames.value(f.pathParts.last().toLower()), f.path); + if (SpecialPurpose::isSpecialPurposeFolderName(f.pathParts.last())) { + specialPurposeFolders->insert(SpecialPurpose::getSpecialPurposeType(f.pathParts.last()), f.path); }; } })) -- cgit v1.2.3