/usr/include/KF5/mailcommon/mailkernel.h is in libkf5mailcommon-dev 4:16.04.2-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 | /*
Copyright (c) 2010 Klarälvdalens Datakonsult AB, a KDAB Group company, info@kdab.com
Copyright (c) 2010 Andras Mantia <andras@kdab.com>
This program is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License, version 2, as
published by the Free Software Foundation.
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, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef MAILCOMMON_MAILKERNEL_H
#define MAILCOMMON_MAILKERNEL_H
#include "mailcommon_export.h"
#include "mailcommon/mailinterfaces.h"
#include <Collection>
#include <Akonadi/KMime/SpecialMailCollections>
#include <KConfigGroup>
#include <KSharedConfig>
#include <QObject>
namespace PimCommon
{
class ImapResourceCapabilitiesManager;
}
namespace MailCommon
{
/**
* Deals with common mail application related operations. The required interfaces
* MUST be registered before using it!
* Be careful when using in multi-threaded applications, as Kernel is a QObject
* singleton, created in the main thread, thus event handling for Kernel::self()
* will happen in the main thread.
*/
class MAILCOMMON_EXPORT Kernel : public QObject
{
Q_OBJECT
public:
virtual ~Kernel();
static Kernel *self();
/**
* Registers the interface dealing with main mail functionality. This function
* MUST be called with a valid interface pointer, before any Kernel::self()
* method is used. The pointer ownership will not be transferred to Kernel.
*/
void registerKernelIf(IKernel *kernelIf);
bool kernelIsRegistered() const;
IKernel *kernelIf() const;
/**
* Registers the interface dealing with mail settings. This function
* MUST be called with a valid interface pointer, before any Kernel::self()
* method is used. The pointer ownership will not be transferred to Kernel.
*/
void registerSettingsIf(ISettings *settingsIf);
ISettings *settingsIf() const;
/**
* Registers the interface dealing with mail settings. This function
* MUST be called with a valid interface pointer, before any Kernel::self()
* method is used. The pointer ownership will not be transferred to Kernel.
*/
void registerFilterIf(IFilter *filterIf);
IFilter *filterIf() const;
/**
* Returns the collection associated with the given @p id, or an invalid
* collection if not found. The EntityTreeModel of the kernel is searched for
* the collection. Since the ETM is loaded async, this method will not find
* the collection right after startup, when the ETM is not yet fully loaded.
*/
Akonadi::Collection collectionFromId(Akonadi::Collection::Id id) const;
Akonadi::Collection inboxCollectionFolder();
Akonadi::Collection outboxCollectionFolder();
Akonadi::Collection sentCollectionFolder();
Akonadi::Collection trashCollectionFolder();
Akonadi::Collection draftsCollectionFolder();
Akonadi::Collection templatesCollectionFolder();
bool isSystemFolderCollection(const Akonadi::Collection &col);
/**
* Returns true if this folder is the inbox on the local disk
*/
bool isMainFolderCollection(const Akonadi::Collection &col);
/**
* Returns true if the folder is either the outbox or one of the drafts-folders.
*/
bool folderIsDraftOrOutbox(const Akonadi::Collection &collection);
bool folderIsDrafts(const Akonadi::Collection &);
bool folderIsTemplates(const Akonadi::Collection &collection);
/**
* Returns true if the folder is a trash folder.
*
* When calling this too early (before the SpecialMailCollectionsDiscoveryJob from initFolders finishes),
* it will say false erroneously. However you can connect to SpecialMailCollections::collectionsChanged
* to react on dynamic changes and call this again.
*/
bool folderIsTrash(const Akonadi::Collection &collection);
/**
* Returns the trash folder for the resource which @p col belongs to.
*
* When calling this too early (before the SpecialMailCollectionsDiscoveryJob from initFolders finishes),
* it will return an invalid collection erroneously. However you can connect to SpecialMailCollections::collectionsChanged
* to react on dynamic changes and call this again.
*/
Akonadi::Collection trashCollectionFromResource(const Akonadi::Collection &col);
/**
* Returns true if the folder is one of the sent-mail folders.
*/
bool folderIsSentMailFolder(const Akonadi::Collection &);
static bool folderIsInbox(const Akonadi::Collection &, bool withoutPop3InboxSetting = false);
void initFolders();
void emergencyExit(const QString &reason);
PimCommon::ImapResourceCapabilitiesManager *imapResourceManager() const;
private:
void findCreateDefaultCollection(Akonadi::SpecialMailCollections::Type);
private Q_SLOTS:
void createDefaultCollectionDone(KJob *job);
void slotDefaultCollectionsChanged();
Q_SIGNALS:
void requestConfigSync();
void requestSystemTrayUpdate();
private:
Kernel(QObject *parent = Q_NULLPTR);
friend class KernelPrivate;
IKernel *mKernelIf;
IFilter *mFilterIf;
ISettings *mSettingsIf;
PimCommon::ImapResourceCapabilitiesManager *mImapResourceManager;
};
}
#define KernelIf MailCommon::Kernel::self()->kernelIf()
#define FilterIf MailCommon::Kernel::self()->filterIf()
#define SettingsIf MailCommon::Kernel::self()->settingsIf()
#define CommonKernel MailCommon::Kernel::self()
#endif
|