diff options
Diffstat (limited to 'kmail/popaccount.h')
-rw-r--r-- | kmail/popaccount.h | 242 |
1 files changed, 242 insertions, 0 deletions
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 <qvaluelist.h> +#include <qstringlist.h> +#include <qvaluevector.h> +#include <qtimer.h> +#include <qdict.h> + +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<QString, int> mMsgsPendingDownload; + + QPtrList<KMPopHeaders> headersOnServer; + QPtrListIterator<KMPopHeaders> headerIt; + bool headers; + + QMap<QString, bool> mHeaderDeleteUids; + QMap<QString, bool> mHeaderDownUids; + QMap<QString, bool> mHeaderLaterUids; + + QStringList idsOfMsgs; //used for ids and for count + QValueList<int> lensOfMsgs; + QMap<QString, QString> mUidForIdMap; // maps message ID (i.e. index on the server) to UID + QDict<int> mUidsOfSeenMsgsDict; // set of UIDs of previously seen messages (for fast lookup) + QDict<int> mUidsOfNextSeenMsgsDict; // set of UIDs of seen messages (for the next check) + QValueVector<int> mTimeOfSeenMsgsVector; // list of times of previously seen messages + QMap<QString, int> mTimeOfNextSeenMsgsMap; // map of uid to times of seen messages + QDict<int> mSizeOfNextSeenMsgsDict; + QStringList idsOfMsgsToDelete; + QStringList idsOfForcedDeletes; + int indexOfCurrentMsg; + + QValueList<KMMessage*> 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*/ |