From 460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kmail/popaccount.h | 242 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 242 insertions(+) create mode 100644 kmail/popaccount.h (limited to 'kmail/popaccount.h') diff --git a/kmail/popaccount.h b/kmail/popaccount.h new file mode 100644 index 000000000..718ac3165 --- /dev/null +++ b/kmail/popaccount.h @@ -0,0 +1,242 @@ +// -*- c++ -*- +#ifndef KMAcctExpPop_h +#define KMAcctExpPop_h + +#include "networkaccount.h" + +#include +#include +#include +#include +#include + +class KMPopHeaders; +class KMMessage; +class QDataStream; +namespace KIO { + class MetaData; + class Slave; + class SimpleJob; + class Job; +} + +/** The namespace where all classes of KMail can be found in. */ +namespace KMail { +/** + * KMail account for pop mail account + */ +class PopAccount: public NetworkAccount { + Q_OBJECT + +public: + virtual ~PopAccount(); + virtual void init(void); + + virtual KIO::MetaData slaveConfig() const; + + /** A weak assignment operator */ + virtual void pseudoAssign( const KMAccount * a ); + + virtual QString protocol() const; + virtual unsigned short int defaultPort() const; + + /** + * Sending of several commands at once + */ + bool usePipelining(void) const { return mUsePipelining; } + virtual void setUsePipelining(bool); + + /** + * Shall messages be left on the server upon retreival (TRUE) + * or deleted (FALSE). + */ + bool leaveOnServer(void) const { return mLeaveOnServer; } + virtual void setLeaveOnServer(bool); + + /** + * If value is positive, leave mail on the server for so many days. + */ + int leaveOnServerDays(void) const { return mLeaveOnServerDays; } + virtual void setLeaveOnServerDays(int); + + /** + * If value is positive, leave so many messages on the server. + */ + int leaveOnServerCount(void) const { return mLeaveOnServerCount; } + virtual void setLeaveOnServerCount(int); + + /** + * If value is positive, leave so many MBs on the server. + */ + int leaveOnServerSize(void) const { return mLeaveOnServerSize; } + virtual void setLeaveOnServerSize(int); + + /** + * Shall messages be filter on the server (TRUE) + * or not (FALSE). + */ + bool filterOnServer(void) const { return mFilterOnServer; } + virtual void setFilterOnServer(bool); + + /** + * Size of messages which should be check on the + * pop server before download + */ + unsigned int filterOnServerCheckSize(void) const { return mFilterOnServerCheckSize; } + virtual void setFilterOnServerCheckSize(unsigned int); + + /** + * Inherited methods. + */ + virtual QString type(void) const; + virtual void readConfig(KConfig&); + virtual void writeConfig(KConfig&); + virtual void processNewMail(bool _interactive); + + virtual void killAllJobs( bool disconnectSlave=false ); // NOOP currently + +protected: + enum Stage { Idle, List, Uidl, Head, Retr, Dele, Quit }; + friend class ::AccountManager; + PopAccount(AccountManager* owner, const QString& accountName, uint id); + + /** + * Start a KIO Job to get a list of messages on the pop server + */ + void startJob(); + + /** + * Connect up the standard signals/slots for the KIO Jobs + */ + void connectJob(); + + /** + * Process any queued messages + */ + void processRemainingQueuedMessages(); + + /** + * Save the list of seen uids for this user/server + */ + void saveUidList(); + + bool mUsePipelining; + bool mLeaveOnServer; + int mLeaveOnServerDays; + int mLeaveOnServerCount; + int mLeaveOnServerSize; + bool gotMsgs; + bool mFilterOnServer; + unsigned int mFilterOnServerCheckSize; + + KIO::SimpleJob *job; + //Map of ID's vs. sizes of messages which should be downloaded + QMap mMsgsPendingDownload; + + QPtrList headersOnServer; + QPtrListIterator headerIt; + bool headers; + + QMap mHeaderDeleteUids; + QMap mHeaderDownUids; + QMap mHeaderLaterUids; + + QStringList idsOfMsgs; //used for ids and for count + QValueList lensOfMsgs; + QMap mUidForIdMap; // maps message ID (i.e. index on the server) to UID + QDict mUidsOfSeenMsgsDict; // set of UIDs of previously seen messages (for fast lookup) + QDict mUidsOfNextSeenMsgsDict; // set of UIDs of seen messages (for the next check) + QValueVector mTimeOfSeenMsgsVector; // list of times of previously seen messages + QMap mTimeOfNextSeenMsgsMap; // map of uid to times of seen messages + QDict mSizeOfNextSeenMsgsDict; + QStringList idsOfMsgsToDelete; + QStringList idsOfForcedDeletes; + int indexOfCurrentMsg; + + QValueList msgsAwaitingProcessing; + QStringList msgIdsAwaitingProcessing; + QStringList msgUidsAwaitingProcessing; + + QByteArray curMsgData; + QDataStream *curMsgStrm; + + int curMsgLen; + Stage stage; + QTimer processMsgsTimer; + int processingDelay; + int numMsgs, numBytes, numBytesToRead, numBytesRead, numMsgBytesRead; + bool interactive; + bool mProcessing; + bool mUidlFinished; + int dataCounter; + +protected slots: + /** + * Messages are downloaded in the background and then once every x seconds + * a batch of messages are processed. Messages are processed in batches to + * reduce flicker (multiple refreshes of the qlistview of messages headers + * in a single second causes flicker) when using a fast pop server such as + * one on a lan. + * + * Processing a message means applying KMAccount::processNewMsg to it and + * adding its UID to the list of seen UIDs + */ + void slotProcessPendingMsgs(); + + /** + * If there are more messages to be downloaded then start a new kio job + * to get the message whose id is at the head of the queue + */ + void slotGetNextMsg(); + + /** + * A messages has been retrieved successfully. The next data belongs to the + * next message. + */ + void slotMsgRetrieved(KIO::Job*, const QString &); + + /** + * New data has arrived append it to the end of the current message + */ + void slotData( KIO::Job*, const QByteArray &); + + /** + * Finished downloading the current kio job, either due to an error + * or because the job has been canceled or because the complete message + * has been downloaded + */ + void slotResult( KIO::Job* ); + + /** + * Cleans up after a user cancels the current job + */ + void slotCancel(); + + /** + * Kills the job if still stage == List + */ + void slotAbortRequested(); + + /** + * Called when a job is finished. Basically a finite state machine for + * cycling through the Idle, List, Uidl, Retr, Quit stages + */ + void slotJobFinished(); + + /** + * Slave error handling + */ + void slotSlaveError(KIO::Slave *, int, const QString &); + + /** + * If there are more headers to be downloaded then start a new kio job + * to get the next header + */ + void slotGetNextHdr(); +}; + +} // namespace KMail + + + +#endif /*KMAcctExpPop_h*/ -- cgit v1.2.1