2004-10-05 10:28:21 +00:00
|
|
|
//
|
2005-03-18 21:33:11 +00:00
|
|
|
// VMime library (http://www.vmime.org)
|
2005-01-03 12:26:48 +00:00
|
|
|
// Copyright (C) 2002-2005 Vincent Richard <vincent@vincent-richard.net>
|
2004-10-05 10:28:21 +00:00
|
|
|
//
|
|
|
|
// 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; either version 2 of
|
|
|
|
// the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// 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., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef VMIME_MESSAGEBUILDER_HPP_INCLUDED
|
|
|
|
#define VMIME_MESSAGEBUILDER_HPP_INCLUDED
|
|
|
|
|
|
|
|
|
2004-12-26 20:23:29 +00:00
|
|
|
#include "vmime/base.hpp"
|
|
|
|
|
|
|
|
#include "vmime/mailbox.hpp"
|
|
|
|
#include "vmime/addressList.hpp"
|
|
|
|
#include "vmime/text.hpp"
|
|
|
|
#include "vmime/message.hpp"
|
|
|
|
#include "vmime/mediaType.hpp"
|
|
|
|
#include "vmime/attachment.hpp"
|
|
|
|
#include "vmime/textPart.hpp"
|
|
|
|
#include "vmime/bodyPart.hpp"
|
2004-10-05 10:28:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
namespace vmime
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/** A helper for building MIME messages.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class messageBuilder
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
messageBuilder();
|
|
|
|
~messageBuilder();
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
2004-10-21 15:05:47 +00:00
|
|
|
/** Return the expeditor of the message (From:).
|
|
|
|
*
|
|
|
|
* @return expeditor of the message
|
|
|
|
*/
|
|
|
|
const mailbox& getExpeditor() const;
|
|
|
|
|
|
|
|
/** Set the expeditor of the message (From:).
|
|
|
|
*
|
|
|
|
* @param expeditor expeditor of the message
|
|
|
|
*/
|
|
|
|
void setExpeditor(const mailbox& expeditor);
|
|
|
|
|
|
|
|
/** Return the recipients of the message (To:).
|
|
|
|
*
|
|
|
|
* return recipients of the message
|
|
|
|
*/
|
|
|
|
const addressList& getRecipients() const;
|
|
|
|
|
2004-10-25 22:02:58 +00:00
|
|
|
/** Return the recipients of the message (To:).
|
|
|
|
*
|
|
|
|
* return recipients of the message
|
|
|
|
*/
|
|
|
|
addressList& getRecipients();
|
|
|
|
|
2004-10-21 15:05:47 +00:00
|
|
|
/** Set the recipients of the message (To:).
|
|
|
|
*
|
|
|
|
* @param recipients list of recipients
|
|
|
|
*/
|
|
|
|
void setRecipients(const addressList& recipients);
|
|
|
|
|
|
|
|
/** Return the copy recipients of the message (Cc:).
|
|
|
|
*
|
|
|
|
* @return copy recipients of the message
|
|
|
|
*/
|
|
|
|
const addressList& getCopyRecipients() const;
|
|
|
|
|
2004-10-25 22:02:58 +00:00
|
|
|
/** Return the copy recipients of the message (Cc:).
|
|
|
|
*
|
|
|
|
* @return copy recipients of the message
|
|
|
|
*/
|
|
|
|
addressList& getCopyRecipients();
|
|
|
|
|
2004-10-21 15:05:47 +00:00
|
|
|
/** Set the copy recipients of the message (Cc:).
|
|
|
|
*
|
|
|
|
* @param cc list of copy recipients
|
|
|
|
*/
|
|
|
|
void setCopyRecipients(const addressList& cc);
|
|
|
|
|
|
|
|
/** Return the blind-copy recipients of the message (Bcc:).
|
|
|
|
*
|
|
|
|
* @return blind-copy recipients of the message
|
|
|
|
*/
|
|
|
|
const addressList& getBlindCopyRecipients() const;
|
|
|
|
|
2004-10-25 22:02:58 +00:00
|
|
|
/** Return the blind-copy recipients of the message (Bcc:).
|
|
|
|
*
|
|
|
|
* @return blind-copy recipients of the message
|
|
|
|
*/
|
|
|
|
addressList& getBlindCopyRecipients();
|
|
|
|
|
2004-10-21 15:05:47 +00:00
|
|
|
/** Set the blind-copy recipients of the message (Bcc:).
|
|
|
|
*
|
|
|
|
* @param bcc list of blind-copy recipients
|
|
|
|
*/
|
|
|
|
void setBlindCopyRecipients(const addressList& bcc);
|
|
|
|
|
|
|
|
/** Return the subject of the message.
|
|
|
|
*
|
|
|
|
* @return subject of the message
|
|
|
|
*/
|
|
|
|
const text& getSubject() const;
|
|
|
|
|
|
|
|
/** Set the subject of the message.
|
|
|
|
*
|
|
|
|
* @param subject message subject
|
|
|
|
*/
|
|
|
|
void setSubject(const text& subject);
|
|
|
|
|
|
|
|
/** Attach a new object to the message.
|
2005-07-12 22:28:02 +00:00
|
|
|
* \deprecated Use messageBuilder::appendAttachment() instead.
|
2004-10-21 15:05:47 +00:00
|
|
|
*
|
|
|
|
* @param attach new attachment
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
void attach(ref <attachment> attach);
|
2004-10-05 10:28:21 +00:00
|
|
|
|
2004-10-25 22:10:13 +00:00
|
|
|
/** Attach a new object to the message.
|
|
|
|
*
|
|
|
|
* @param attach new attachment
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
void appendAttachment(ref <attachment> attach);
|
2004-10-25 22:10:13 +00:00
|
|
|
|
2004-10-21 15:05:47 +00:00
|
|
|
/** Remove the attachment at the specified position.
|
|
|
|
*
|
|
|
|
* @param pos position of the attachment to remove
|
|
|
|
*/
|
|
|
|
void removeAttachment(const int pos);
|
|
|
|
|
|
|
|
/** Return the attachment at the specified position.
|
|
|
|
*
|
|
|
|
* @param pos position of the attachment
|
|
|
|
* @return attachment at the specified position
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
const ref <const attachment> getAttachmentAt(const int pos) const;
|
2004-10-21 15:05:47 +00:00
|
|
|
|
|
|
|
/** Return the attachment at the specified position.
|
|
|
|
*
|
|
|
|
* @param pos position of the attachment
|
|
|
|
* @return attachment at the specified position
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
ref <attachment> getAttachmentAt(const int pos);
|
2004-10-21 15:05:47 +00:00
|
|
|
|
|
|
|
/** Return the number of attachments in the message.
|
|
|
|
*
|
|
|
|
* @return number of attachments
|
|
|
|
*/
|
|
|
|
const int getAttachmentCount() const;
|
|
|
|
|
|
|
|
/** Return the list of attachments.
|
|
|
|
*
|
|
|
|
* @return list of attachments
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
const std::vector <ref <const attachment> > getAttachmentList() const;
|
2004-10-21 15:05:47 +00:00
|
|
|
|
|
|
|
/** Return the list of attachments.
|
|
|
|
*
|
|
|
|
* @return list of attachments
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
const std::vector <ref <attachment> > getAttachmentList();
|
2004-10-21 15:05:47 +00:00
|
|
|
|
|
|
|
/** Change the type of the text part and construct a new part.
|
|
|
|
*
|
|
|
|
* @param type media type of the text part
|
|
|
|
*/
|
2004-10-05 10:28:21 +00:00
|
|
|
void constructTextPart(const mediaType& type);
|
|
|
|
|
2004-10-21 15:05:47 +00:00
|
|
|
/** Return the text part of the message.
|
|
|
|
*
|
|
|
|
* @return text part of the message
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
ref <textPart> getTextPart();
|
2004-10-21 15:05:47 +00:00
|
|
|
|
|
|
|
/** Construct a new message based on the information specified
|
|
|
|
* in this object.
|
|
|
|
*
|
|
|
|
* @return a new message
|
|
|
|
*/
|
2005-07-12 22:28:02 +00:00
|
|
|
ref <message> construct() const;
|
2004-10-05 10:28:21 +00:00
|
|
|
|
2004-10-21 15:05:47 +00:00
|
|
|
private:
|
2004-10-05 10:28:21 +00:00
|
|
|
|
|
|
|
mailbox m_from;
|
|
|
|
|
|
|
|
addressList m_to;
|
|
|
|
addressList m_cc;
|
|
|
|
addressList m_bcc;
|
|
|
|
|
|
|
|
text m_subject;
|
|
|
|
|
2005-07-12 22:28:02 +00:00
|
|
|
ref <textPart> m_textPart;
|
2004-10-05 10:28:21 +00:00
|
|
|
|
2005-07-12 22:28:02 +00:00
|
|
|
std::vector <ref <attachment> > m_attach;
|
2004-10-05 10:28:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // vmime
|
|
|
|
|
|
|
|
|
|
|
|
#endif // VMIME_MESSAGEBUILDER_HPP_INCLUDED
|