/* * messagecomposer.cpp * * Copyright (c) 2004 Bo Thorsen <bo@sonofthor.dk> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License * * 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. * * In addition, as a special exception, the copyright holders give * permission to link the code of this program with any edition of * the TQt library by Trolltech AS, Norway (or with modified versions * of TQt that use the same license as TQt), and distribute linked * combinations including the two. You must obey the GNU General * Public License in all respects for all of the code used other than * TQt. If you modify this file, you may extend this exception to * your version of the file, but you are not obligated to do so. If * you do not wish to do so, delete this exception statement from * your version. */ #ifndef MESSAGECOMPOSER_H #define MESSAGECOMPOSER_H #include "kmmsgpart.h" #include "keyresolver.h" #include <tqobject.h> #include <tqvaluevector.h> #include <mimelib/mediatyp.h> #include <kleo/cryptobackend.h> #include <kpgp.h> #include <vector> class KMMessage; class KMComposeWin; class MessageComposerJob; class EncryptMessageJob; class SetLastMessageAsUnencryptedVersionOfLastButOne; namespace Kleo { class KeyResolver; } namespace GpgME { class Key; } namespace KPIM { class Identity; } class MessageComposer : public TQObject { Q_OBJECT friend class ::MessageComposerJob; friend class ::EncryptMessageJob; friend class ::SetLastMessageAsUnencryptedVersionOfLastButOne; public: class KeyResolver; MessageComposer( KMComposeWin* win, const char* name=0 ); ~MessageComposer(); /** * Applies the user changes to the message object of the composer * and signs/encrypts the message if activated. Returns FALSE in * case of an error (e.g. if PGP encryption fails). * If backgroundMode is true then no functions which might require * user interaction (like signing/encrypting) are performed */ void applyChanges( bool disableCrypto ); TQString originalBCC() const { return mBcc; } void setDisableBreaking( bool b ) { mDisableBreaking = b; } const TQValueVector<KMMessage*> & composedMessageList() const { return mMessageList; } bool isPerformingSignOperation() const { return mPerformingSignOperation; } signals: void done( bool ); private: void readFromComposeWin(); void adjustCryptFlags(); bool encryptWithChiasmus( const Kleo::CryptoBackend::Protocol * chiasmus, const TQByteArray& body, TQByteArray& resultData ); void chiasmusEncryptAllAttachments(); void composeChiasmusMessage( KMMessage& theMessage, Kleo::CryptoMessageFormat format ); // This is the composeMessage method void composeMessage(); // And these two are the parts that should be run after job completions void createUnencryptedMessageVersion(); /** * Internal helper function called from applyChanges(void) to allow * processing several messages (encrypted or unencrypted) based on * the same composer content. * That's useful for storing decrypted versions of messages which * were sent in encrypted form. (khz, 2002/06/24) */ void composeMessage( KMMessage& theMessage, bool doSign, bool doEncrypt, Kleo::CryptoMessageFormat format ); void continueComposeMessage( KMMessage& theMessage, bool doSign, bool doEncrypt, Kleo::CryptoMessageFormat format ); /** * Called by composeMessage for inline-openpgp messages */ void composeInlineOpenPGPMessage( KMMessage& theMessage, bool doSign, bool doEncrypt ); /** * Get message ready for sending or saving. * This must be done _before_ signing and/or encrypting it. */ TQByteArray breakLinesAndApplyCodec(); /** * Create a plain text version of a marked up mail for use as the plain * part in a multipart/alternative mail. */ TQCString plainTextFromMarkup( const TQString& markupText ); /** * Get signature for a message (into mMessage). * To build nice S/MIME objects signing and encoding must be separated. */ void pgpSignedMsg( const TQByteArray& cText, Kleo::CryptoMessageFormat f ); /** * Get encrypted message. * To build nice S/MIME objects signing and encrypting must be separate. */ Kpgp::Result pgpEncryptedMsg( TQByteArray& rEncryptedBody, const TQByteArray& cText, const std::vector<GpgME::Key> & encryptionKeys, Kleo::CryptoMessageFormat f ); /** * Get signed & encrypted message. * To build nice S/MIME objects signing and encrypting must be separate. */ Kpgp::Result pgpSignedAndEncryptedMsg( TQByteArray& rEncryptedBody, const TQByteArray& cText, const std::vector<GpgME::Key> & signingKeys, const std::vector<GpgME::Key> & encryptionKeys, Kleo::CryptoMessageFormat f ); /** * Check for expiry of various certificates. */ bool checkForEncryptCertificateExpiry( const TQString& recipient, const TQCString& certFingerprint ); /** * Build a MIME object (or a flat text resp.) based upon * structuring information returned by a crypto plugin that was * called via pgpSignedMsg() (or pgpEncryptedMsg(), resp.). * * NOTE: The c string representation of the MIME object (or the * flat text, resp.) is returned in resultingPart, so just * use this string as body text of the surrounding MIME object. * This string *is* encoded according to contentTEncClear * and thus should be ready for being sent via SMTP. */ bool processStructuringInfo( const TQString bugURL, const TQString contentDescriptionClear, const TQCString contentTypeClear, const TQCString contentSubtypeClear, const TQCString contentDispClear, const TQCString contentTEncClear, const TQByteArray& bodytext, const TQString contentDescriptionCiph, const TQByteArray& ciphertext, KMMessagePart& resultingPart, bool signing, Kleo::CryptoMessageFormat format ); void encryptMessage( KMMessage* msg, const Kleo::KeyResolver::SplitInfo & si, bool doSign, bool doEncrypt, KMMessagePart newBodyPart, Kleo::CryptoMessageFormat format ); void addBodyAndAttachments( KMMessage* msg, const Kleo::KeyResolver::SplitInfo & si, bool doSign, bool doEncrypt, const KMMessagePart& ourFineBodyPart, Kleo::CryptoMessageFormat format ); private slots: void slotDoNextJob(); private: void doNextJob(); void emitDone( bool ok ); int encryptionPossible( const TQStringList & recipients, bool openPGP ); bool determineWhetherToSign( bool doSignCompletely ); bool determineWhetherToEncrypt( bool doEncryptCompletely ); void markAllAttachmentsForSigning( bool sign ); void markAllAttachmentsForEncryption( bool enc ); KMComposeWin* mComposeWin; MessageComposerJob * mCurrentJob; KMMessage* mReferenceMessage; TQValueVector<KMMessage*> mMessageList; Kleo::KeyResolver * mKeyResolver; TQCString mSignCertFingerprint; struct Attachment { Attachment( KMMessagePart * p=0, bool s=false, bool e=false ) : part( p ), sign( s ), encrypt( e ) {} KMMessagePart * part; bool sign; bool encrypt; }; TQValueVector<Attachment> mAttachments; TQString mPGPSigningKey, mSMIMESigningKey; bool mUseOpportunisticEncryption; bool mSignBody, mEncryptBody; bool mSigningRequested, mEncryptionRequested; bool mDoSign, mDoEncrypt; unsigned int mAllowedCryptoMessageFormats; bool mDisableCrypto; bool mDisableBreaking; TQString mBcc; TQStringList mTo, mCc, mBccList; bool mDebugComposerCrypto; bool mAutoCharset; TQCString mCharset; bool mIsRichText; uint mIdentityUid; bool mRc; // Set this to false, if something fails during the processes bool mHoldJobs; // Don't run the next job yet TQByteArray mText; // textual representation of the message text, encoded unsigned int mLineBreakColumn; // used for line breaking // These are the variables of the big composeMessage(X,Y,Z) message KMMessagePart* mNewBodyPart; TQByteArray mSignature; TQByteArray mEncodedBody; // Only needed if signing and/or encrypting bool mEarlyAddAttachments, mAllAttachmentsAreInBody; KMMessagePart mOldBodyPart; int mPreviousBoundaryLevel; // The boundary is saved for later addition into mp/a body DwString mSaveBoundary; TQCString mMultipartMixedBoundary; TQValueList<MessageComposerJob*> mJobs; bool mEncryptWithChiasmus; bool mPerformingSignOperation; }; #endif /* MESSAGECOMPOSER_H */