vmime/vmime/messageBuilder.hpp

224 lines
5.4 KiB
C++
Raw Normal View History

2004-10-05 10:28:21 +00:00
//
2005-03-18 21:33:11 +00:00
// VMime library (http://www.vmime.org)
// 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.
//
2005-09-17 10:10:29 +00:00
// 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.
//
// Linking this library statically or dynamically with other modules is making
// a combined work based on this library. Thus, the terms and conditions of
// the GNU General Public License cover the whole combination.
2004-10-05 10:28:21 +00:00
//
#ifndef VMIME_MESSAGEBUILDER_HPP_INCLUDED
#define VMIME_MESSAGEBUILDER_HPP_INCLUDED
#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;
/** 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;
/** 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;
/** 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
/** 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-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