aboutsummaryrefslogtreecommitdiff
path: root/vmime-master/src/vmime/attachmentHelper.hpp
blob: f28819fb3b61394908d0f3b55741969d9b75202e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
//
// VMime library (http://www.vmime.org)
// Copyright (C) 2002 Vincent Richard <vincent@vmime.org>
//
// 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 3 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.,
// 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.
//

#ifndef VMIME_ATTACHMENTHELPER_HPP_INCLUDED
#define VMIME_ATTACHMENTHELPER_HPP_INCLUDED


#include "vmime/config.hpp"

#include "vmime/attachment.hpp"
#include "vmime/message.hpp"


namespace vmime {


/** Retrieve attachment information from message parts.
  */
class VMIME_EXPORT attachmentHelper {

public:

	/** Options for use with the following functions:
	  *     findAttachmentsInMessage,
	  *     getBodyPartAttachment,
	  * and isBodyPartAnAttachment.
	  */
	enum FindOptions {
		INLINE_OBJECTS = (1 << 0)        /**< Recognize and return inline objects. The aim is to
		                                      consider MHTML objects (parts with a "Content-Id" or
		                                      a "Content-Location", such as inline images) as attachments. */
	};

	/** Test whether a body part is an attachment.
	  *
	  * @param part message part to test
	  * @param options search options (see FindOptions)
	  * @return true if the part is an attachment, false otherwise
	  */
	static bool isBodyPartAnAttachment(
		const shared_ptr <const bodyPart>& part,
		const unsigned int options = 0
	);

	/** Return attachment information in the specified body part.
	  * If the specified body part does not contain attachment
	  * information (ie. is not an attachment), NULL is returned.
	  *
	  * @param part message part in which to search
	  * @param options search options (see FindOptions)
	  * @return attachment found in the part, or NULL
	  */
	static shared_ptr <const attachment> getBodyPartAttachment(
		const shared_ptr <const bodyPart>& part,
		const unsigned int options = 0
	);

	/** Find all attachments contained in the specified part
	  * and all its children parts.
	  * This is simply a recursive call to getBodyPartAttachment().
	  *
	  * @param part part in which to search
	  * @param options search options (see FindOptions)
	  * @return a list of attachments found
	  */
	static const std::vector <shared_ptr <const attachment> >
		findAttachmentsInBodyPart(
			const shared_ptr <const bodyPart>& part,
			const unsigned int options = 0
		);

	/** Find all attachments contained in the specified message.
	  * This is simply a recursive call to getBodyPartAttachment().
	  *
	  * @param msg message in which to search
	  * @param options search options (see FindOptions)
	  * @return a list of attachments found
	  */
	static const std::vector <shared_ptr <const attachment> >
		findAttachmentsInMessage(
			const shared_ptr <const message>& msg,
			const unsigned int options = 0
		);

	/** Add an attachment to the specified message.
	  *
	  * @param msg message into which to add the attachment
	  * @param att attachment to add
	  */
	static void addAttachment(
		const shared_ptr <message>& msg,
		const shared_ptr <attachment>& att
	);

	/** Add a message attachment to the specified message.
	  *
	  * @param msg message into which to add the attachment
	  * @param amsg message to attach
	  */
	static void addAttachment(
		const shared_ptr <message>& msg,
		const shared_ptr <message>& amsg
	);

protected:

	static shared_ptr <bodyPart> findBodyPart(
		const shared_ptr <bodyPart>& part,
		const mediaType& type
	);
};


} // vmime


#endif // VMIME_ATTACHMENTHELPER_HPP_INCLUDED