vmime/src/messageBuilder.hpp

220 lines
5.1 KiB
C++
Raw Normal View History

2004-10-05 10:28:21 +00:00
//
// VMime library (http://vmime.sourceforge.net)
// Copyright (C) 2002-2004 Vincent Richard <vincent@vincent-richard.net>
//
// 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
#include "base.hpp"
#include "mailbox.hpp"
#include "addressList.hpp"
#include "text.hpp"
#include "message.hpp"
#include "mediaType.hpp"
#include "attachment.hpp"
#include "textPart.hpp"
#include "bodyPart.hpp"
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.
* This is a synonym for messageBuilder::appendAttachment().
2004-10-21 15:05:47 +00:00
*
* @param attach new attachment
*/
2004-10-05 10:28:21 +00:00
void attach(attachment* attach);
/** Attach a new object to the message.
*
* @param attach new attachment
*/
void appendAttachment(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
*/
const attachment* getAttachmentAt(const int pos) const;
/** Return the attachment at the specified position.
*
* @param pos position of the attachment
* @return attachment at the specified position
*/
attachment* getAttachmentAt(const int pos);
/** 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
*/
const std::vector <const attachment*> getAttachmentList() const;
/** Return the list of attachments.
*
* @return list of attachments
*/
const std::vector <attachment*> getAttachmentList();
/** 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
*/
textPart* getTextPart();
/** Construct a new message based on the information specified
* in this object.
*
* @return a new message
*/
2004-10-05 10:28:21 +00:00
message* construct() const;
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;
2004-10-21 15:05:47 +00:00
textPart* m_textPart;
2004-10-05 10:28:21 +00:00
std::vector <attachment*> m_attach;
};
} // vmime
#endif // VMIME_MESSAGEBUILDER_HPP_INCLUDED