2020-04-29 00:32:25 +02:00
|
|
|
/*
|
|
|
|
* mail.h - Mail editing toolset
|
|
|
|
* The author licenses this file
|
|
|
|
* to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance
|
|
|
|
* with the License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing,
|
|
|
|
* software distributed under the License is distributed on an
|
|
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
|
|
* KIND, either express or implied. See the License for the
|
|
|
|
* specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MAIL_H
|
|
|
|
#define MAIL_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stddef.h>
|
2020-04-29 02:01:35 +02:00
|
|
|
#include <stdbool.h>
|
2020-04-29 16:29:36 +02:00
|
|
|
#include <sys/types.h>
|
2020-04-29 00:32:25 +02:00
|
|
|
|
|
|
|
struct email_t{
|
|
|
|
char* message;
|
|
|
|
/* From the below values you can say pretty much anything about the
|
|
|
|
* message. The line delimiting body and header is left out. The header
|
|
|
|
* len includes the last \r\n of the header. If header len is zero,
|
|
|
|
* there was no clear distinction between header and body...
|
|
|
|
*/
|
|
|
|
size_t header_len, body_offset, message_length;
|
2020-04-29 13:43:45 +02:00
|
|
|
|
|
|
|
/* Apparently emails consist of several smaller emails if you send an
|
|
|
|
* attachment alongside them. This also happens when you send an email
|
|
|
|
* as html. Therefore emails are recursive. Ask apple, their mail client
|
|
|
|
* is basically insane by this point...
|
|
|
|
*/
|
2020-04-29 02:01:35 +02:00
|
|
|
bool is_multipart;
|
2020-04-29 15:42:24 +02:00
|
|
|
|
|
|
|
/* The boundary only needs to be defined if this is a multipart message
|
|
|
|
*/
|
2020-04-29 13:43:45 +02:00
|
|
|
size_t boundary_len;
|
2020-04-29 02:01:35 +02:00
|
|
|
char* boundary;
|
2020-04-29 15:42:24 +02:00
|
|
|
|
|
|
|
/* The content type tells us the MIME type of this message part. May not
|
|
|
|
* be specified, so don't assume it is here! */
|
|
|
|
size_t ct_len;
|
|
|
|
char* content_type;
|
|
|
|
|
2020-04-29 02:01:35 +02:00
|
|
|
size_t submes_cnt;
|
|
|
|
struct email_t** submes;
|
2020-04-29 14:47:50 +02:00
|
|
|
struct email_t* parent;
|
2020-04-29 00:32:25 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
int append_header(struct email_t* mail, const char* key, const char* value);
|
|
|
|
int append_to_header(struct email_t* mail, const char* pair);
|
|
|
|
|
2020-04-29 16:29:36 +02:00
|
|
|
struct email_t* get_root_mail(struct email_t* mail);
|
|
|
|
|
|
|
|
void propagate_insert_delete(struct email_t* mail, char* change_p,
|
|
|
|
ssize_t change);
|
2020-04-29 16:44:48 +02:00
|
|
|
void propagate_root_pointer(struct email_t* mail, char* change_p, char* old_p);
|
2020-04-29 16:29:36 +02:00
|
|
|
|
2020-04-29 03:00:12 +02:00
|
|
|
#define MULTIPART_MIME "multipart/"
|
|
|
|
|
2020-04-29 00:32:25 +02:00
|
|
|
#endif /* MAIL_H */
|