summaryrefslogtreecommitdiffstats
path: root/src/lib-imap/imap-bodystructure.h
blob: a7cc6cda7baafe2d5079d2d7e72ee11fc39e3511 (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
#ifndef IMAP_BODYSTRUCTURE_H
#define IMAP_BODYSTRUCTURE_H

struct message_part;
struct message_header_line;
struct imap_arg;

/* Write a BODY/BODYSTRUCTURE from given message_part. The message_part->data
   field must be set. part->body_size.virtual_size and .lines are also used
   for writing it. Returns 0 on success, -1 if parts don't internally match
   (e.g. broken cached mime.parts mixed with parsed message). */
int imap_bodystructure_write(const struct message_part *part,
			     string_t *dest, bool extended,
			     const char **error_r);

/* Parse BODYSTRUCTURE and save the contents to message_part->data for each
   message tree node. If the parts argument points to NULL, the message_part
   tree is created from the BODYSTRUCTURE. Otherwise, existing tree is used.
   Returns 0 if ok, -1 if bodystructure wasn't valid. */
int imap_bodystructure_parse_full(const char *bodystructure, pool_t pool,
			     struct message_part **parts, const char **error_r);

/* Same as imap_bodystructure_parse_full(), but read the input from imap_args
   instead of a string. */
int imap_bodystructure_parse_args(const struct imap_arg *args, pool_t pool,
			     struct message_part **parts, const char **error_r);

/* Parse BODYSTRUCTURE and save the contents to message_part->data for each
   message tree node. The parts argument must point to an existing message_part
   tree. Returns 0 if ok, -1 if bodystructure wasn't valid. */
int imap_bodystructure_parse(const char *bodystructure, pool_t pool,
			     struct message_part *parts, const char **error_r);

/* Get BODY part from BODYSTRUCTURE and write it to dest.
   Returns 0 if ok, -1 if bodystructure wasn't valid. */
int imap_body_parse_from_bodystructure(const char *bodystructure,
				       string_t *dest, const char **error_r);

#endif