You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

271 lines
7.2 KiB

/* KMail Mail Sender
*
* Author: Stefan Taferner <taferner@alpin.or.at>
*/
#ifndef kmsender_h
#define kmsender_h
#include <qcstring.h>
#include <qstring.h>
#include <qstringlist.h>
#include <qobject.h>
#include "kio/global.h"
class KMMessage;
class KMFolder;
class KMFolderMgr;
class KConfig;
class KProcess;
class KMIOStatusDlg;
class KMSendProc;
class QStrList;
class KMTransportInfo;
class KMPrecommand;
namespace KIO
{
class Job;
class TransferJob;
class Slave;
}
class KMSender: public QObject
{
Q_OBJECT
friend class KMSendProc;
public:
KMSender();
virtual ~KMSender();
/** Send given message. The message is either queued or sent
immediately. The default behaviour, as selected with
setSendImmediate(), can be overwritten with the parameter
sendNow (by specifying TRUE or FALSE).
The sender takes ownership of the given message on success,
so DO NOT DELETE OR MODIFY the message further.
Returns TRUE on success. */
virtual bool send(KMMessage* msg, short sendNow=-1);
/** Start sending all queued messages. Returns TRUE on success. */
virtual bool sendQueued();
virtual bool sendSingleMail(KMMessage *msg);
/** Returns TRUE if sending is in progress. */
bool sending(void) const { return mSendInProgress; }
/** Shall messages be sent immediately (TRUE), or shall they be
queued and sent later upon call of sendQueued() ? */
bool sendImmediate(void) const { return mSendImmediate; }
virtual void setSendImmediate(bool);
/** Shall messages be sent quoted-printable encoded. No encoding
happens otherwise. */
bool sendQuotedPrintable(void) const { return mSendQuotedPrintable; }
virtual void setSendQuotedPrintable(bool);
/** Get the transport information */
KMTransportInfo * transportInfo() { return mTransportInfo; }
/** Read configuration from global config. */
virtual void readConfig(void);
/** Write configuration to global config with optional sync() */
virtual void writeConfig(bool withSync=TRUE);
/** sets a status msg and emits statusMsg() */
void setStatusMsg(const QString&);
/** sets replied/forwarded status in the linked message for @p aMsg. */
void setStatusByLink(const KMMessage *aMsg);
signals:
/** Emitted regularly to inform the user of what is going on */
void statusMsg(const QString&);
protected slots:
/** Start sending */
virtual void slotPrecommandFinished(bool);
virtual void slotIdle();
/** abort sending of the current message */
virtual void slotAbortSend();
/** initialization sequence has finised */
virtual void sendProcStarted(bool success);
/** note when a msg gets added to outbox during sending */
void outboxMsgAdded();
protected:
/** handle sending of messages */
virtual void doSendMsg();
/** second part of handling sending of messages */
virtual void doSendMsgAux();
/** cleanup after sending */
virtual void cleanup(void);
/** Test if all required settings are set.
Reports problems to user via dialogs and returns FALSE.
Returns TRUE if everything is Ok. */
virtual bool settingsOk(void) const;
/** Parse protocol '://' (host port? | mailer) string and
set transport settings */
virtual KMSendProc* createSendProcFromString(QString transport);
private:
bool mSendImmediate;
bool mSendQuotedPrintable;
KMTransportInfo *mTransportInfo;
KMPrecommand *mPrecommand;
bool mSentOk, mSendAborted;
QString mErrorMsg;
KMIOStatusDlg* mSendDlg;
KMSendProc *mSendProc;
QString mMethodStr;
bool mSendProcStarted;
bool mSendInProgress;
KMMessage * mCurrentMsg;
int mSentMessages, mTotalMessages;
};
//-----------------------------------------------------------------------------
#define KMSendProcInherited QObject
class KMSendProc: public QObject
{
Q_OBJECT
public:
KMSendProc(KMSender*);
virtual ~KMSendProc() {}
/** Initialize sending of one or more messages. */
virtual void start(void);
/** Initializes variables directly before send() is called. */
virtual void preSendInit(void);
/** Send given message. May return before message is sent. */
virtual bool send(KMMessage* msg) = 0;
/** Cleanup after sending messages. */
virtual bool finish(bool destructive);
/** Abort sending the current message. Sets mSending to false */
virtual void abort() = 0;
/** Returns TRUE if send was successful, and FALSE otherwise.
Returns FALSE if sending is still in progress. */
bool sendOk(void) const { return mSendOk; }
/** Returns TRUE if sending is still in progress. */
bool sending(void) const { return mSending; }
/** Returns error message of last call of failed(). */
QString message(void) const { return mMsg; }
signals:
/** Emitted when the current message is sent or an error occured. */
void idle();
/** Emitted when the initialization sequence has finished */
void started(bool);
protected:
/** Called to signal a transmission error. The sender then
calls finish() and terminates sending of messages.
Sets mSending to FALSE. */
virtual void failed(const QString &msg);
/** Prepare message for sending. */
virtual QCString prepareStr(const QCString &str, bool toCRLF=FALSE,
bool noSingleDot=TRUE);
/** Informs the user about what is going on. */
virtual void statusMsg(const QString&);
/** Called once for the contents of the header fields To, Cc, and Bcc.
Returns TRUE on success and FALSE on failure.
Calls addOneRecipient() for each recipient in the list. Aborts and
returns FALSE if addOneRecipient() returns FALSE. */
virtual bool addRecipients(const QStrList& aRecpList);
/** Called from within addRecipients() once for each recipient in
the list after all surplus characters have been stripped. E.g.
for: "Stefan Taferner" <taferner@kde.org>
addRecpient(taferner@kde.org) is called.
Returns TRUE on success and FALSE on failure. */
virtual bool addOneRecipient(const QString& aRecipient) = 0;
protected:
bool mSendOk, mSending;
QString mMsg;
KMSender* mSender;
};
//-----------------------------------------------------------------------------
#define KMSendSendmailInherited KMSendProc
class KMSendSendmail: public KMSendProc
{
Q_OBJECT
public:
KMSendSendmail(KMSender*);
virtual ~KMSendSendmail();
virtual void start(void);
virtual bool send(KMMessage* msg);
virtual bool finish(bool destructive);
virtual void abort();
protected slots:
void receivedStderr(KProcess*,char*,int);
void wroteStdin(KProcess*);
void sendmailExited(KProcess*);
protected:
virtual bool addOneRecipient(const QString& aRecipient);
QCString mMsgStr;
char* mMsgPos;
int mMsgRest;
KProcess* mMailerProc;
};
//-----------------------------------------------------------------------------
class KMSendSMTP : public KMSendProc
{
Q_OBJECT
public:
KMSendSMTP(KMSender *sender);
~KMSendSMTP();
virtual bool send(KMMessage *);
virtual void abort();
virtual bool finish(bool);
protected:
virtual bool addOneRecipient(const QString& aRecipient);
private slots:
void dataReq(KIO::Job *, QByteArray &);
void result(KIO::Job *);
void slaveError(KIO::Slave *, int, const QString &);
private:
QString mQuery;
QString mQueryField;
QCString mMessage;
bool mInProcess;
KIO::TransferJob *mJob;
KIO::Slave *mSlave;
};
#endif /*kmsender_h*/