]> git.notmuchmail.org Git - notmuch/blob - util/gmime-extra.c
notmuch (0.27-2) unstable; urgency=medium
[notmuch] / util / gmime-extra.c
1 #include "gmime-extra.h"
2 #include <string.h>
3
4 GMimeStream *
5 g_mime_stream_stdout_new()
6 {
7     GMimeStream *stream_stdout = NULL;
8     GMimeStream *stream_buffered = NULL;
9
10     stream_stdout = g_mime_stream_pipe_new (STDOUT_FILENO);
11     if (!stream_stdout)
12         return NULL;
13
14     g_mime_stream_pipe_set_owner (GMIME_STREAM_PIPE (stream_stdout), FALSE);
15
16     stream_buffered = g_mime_stream_buffer_new (stream_stdout, GMIME_STREAM_BUFFER_BLOCK_WRITE);
17
18     g_object_unref (stream_stdout);
19
20     return stream_buffered;
21 }
22
23 /**
24  * copy a glib string into a talloc context, and free it.
25  */
26 static char*
27 g_string_talloc_strdup (void *ctx, char *g_string)
28 {
29     char *new_str = talloc_strdup (ctx, g_string);
30     g_free (g_string);
31     return new_str;
32 }
33
34 #if (GMIME_MAJOR_VERSION < 3)
35
36 const char *
37 g_mime_certificate_get_valid_userid (GMimeCertificate *cert)
38 {
39     /* output user id only if validity is FULL or ULTIMATE. */
40     /* note that gmime 2.6 is using the term "trust" here, which
41      * is WRONG.  It's actually user id "validity". */
42     const char *name = g_mime_certificate_get_name (cert);
43     if (name == NULL)
44         return name;
45     GMimeCertificateTrust trust = g_mime_certificate_get_trust (cert);
46     if (trust == GMIME_CERTIFICATE_TRUST_FULLY || trust == GMIME_CERTIFICATE_TRUST_ULTIMATE)
47         return name;
48     return NULL;
49 }
50
51 char *
52 g_mime_message_get_address_string (GMimeMessage *message, GMimeRecipientType type)
53 {
54     InternetAddressList *list = g_mime_message_get_recipients (message, type);
55     return internet_address_list_to_string (list, 0);
56 }
57
58 inline InternetAddressList *
59 g_mime_message_get_addresses (GMimeMessage *message, GMimeRecipientType type)
60 {
61     return g_mime_message_get_recipients (message, type);
62 }
63
64 char *
65 g_mime_message_get_date_string (void *ctx, GMimeMessage *message)
66 {
67     char *date = g_mime_message_get_date_as_string (message);
68     return g_string_talloc_strdup (ctx, date);
69 }
70
71 InternetAddressList *
72 g_mime_message_get_from (GMimeMessage *message)
73 {
74     return internet_address_list_parse_string (g_mime_message_get_sender (message));
75 }
76
77 const char *
78 g_mime_message_get_from_string (GMimeMessage *message) {
79     return  g_mime_message_get_sender (message);
80 }
81
82 InternetAddressList *
83 g_mime_message_get_reply_to_list (GMimeMessage *message)
84 {
85     const char *reply_to;
86
87     reply_to = g_mime_message_get_reply_to (message);
88     if (reply_to && *reply_to)
89         return internet_address_list_parse_string (reply_to);
90     else
91         return NULL;
92 }
93
94 /**
95  * return talloc allocated reply-to string
96  */
97 char *
98 g_mime_message_get_reply_to_string (void *ctx, GMimeMessage *message)
99 {
100     return talloc_strdup(ctx, g_mime_message_get_reply_to (message));
101 }
102
103 gboolean
104 g_mime_signature_status_good (GMimeSignatureStatus status) {
105     return (status == GMIME_SIGNATURE_STATUS_GOOD);
106 }
107
108 gboolean
109 g_mime_signature_status_bad (GMimeSignatureStatus status) {
110     return (status == GMIME_SIGNATURE_STATUS_BAD);
111 }
112
113 gboolean
114 g_mime_signature_status_error (GMimeSignatureError error) {
115     return (error != GMIME_SIGNATURE_ERROR_NONE);
116 }
117
118 gint64
119 g_mime_utils_header_decode_date_unix (const char *date) {
120     return (gint64) g_mime_utils_header_decode_date (date, NULL);
121 }
122
123 #else /* GMime >= 3.0 */
124
125 const char *
126 g_mime_certificate_get_valid_userid (GMimeCertificate *cert)
127 {
128     /* output user id only if validity is FULL or ULTIMATE. */
129     const char *uid = g_mime_certificate_get_user_id (cert);
130     if (uid == NULL)
131         return uid;
132     GMimeValidity validity = g_mime_certificate_get_id_validity (cert);
133     if (validity == GMIME_VALIDITY_FULL || validity == GMIME_VALIDITY_ULTIMATE)
134         return uid;
135     return NULL;
136 }
137
138 const char*
139 g_mime_certificate_get_fpr16 (GMimeCertificate *cert) {
140     const char *fpr = g_mime_certificate_get_fingerprint (cert);
141     if (!fpr || strlen (fpr) < 16)
142         return fpr;
143
144     return fpr + (strlen (fpr) - 16);
145 }
146
147 char *
148 g_mime_message_get_address_string (GMimeMessage *message, GMimeAddressType type)
149 {
150     InternetAddressList *list = g_mime_message_get_addresses (message, type);
151     return internet_address_list_to_string (list, NULL, 0);
152 }
153
154 char *
155 g_mime_message_get_date_string (void *ctx, GMimeMessage *message)
156 {
157     GDateTime* parsed_date = g_mime_message_get_date (message);
158     if (parsed_date) {
159         char *date = g_mime_utils_header_format_date (parsed_date);
160         return g_string_talloc_strdup (ctx, date);
161     } else {
162         return talloc_strdup(ctx, "Thu, 01 Jan 1970 00:00:00 +0000");
163     }
164 }
165
166 InternetAddressList *
167 g_mime_message_get_reply_to_list(GMimeMessage *message)
168 {
169     return g_mime_message_get_reply_to (message);
170 }
171
172 const char *
173 g_mime_message_get_from_string (GMimeMessage *message)
174 {
175     return g_mime_object_get_header (GMIME_OBJECT (message), "From");
176 }
177
178 char *
179 g_mime_message_get_reply_to_string (void *ctx, GMimeMessage *message)
180 {
181     InternetAddressList *list = g_mime_message_get_reply_to (message);
182     return g_string_talloc_strdup (ctx, internet_address_list_to_string (list, NULL, 0));
183 }
184
185 void
186 g_mime_parser_set_scan_from (GMimeParser *parser, gboolean flag)
187 {
188     g_mime_parser_set_format (parser, flag ? GMIME_FORMAT_MBOX : GMIME_FORMAT_MESSAGE);
189 }
190
191 /* In GMime 3.0, status GOOD and VALID both imply something about the
192  * validity of the UIDs attached to the signing key. This forces us to
193  * use following somewhat relaxed definition of a "good" signature to
194  * preserve current notmuch semantics.
195  */
196
197 gboolean
198 g_mime_signature_status_good (GMimeSignatureStatus status) {
199     return ((status  & (GMIME_SIGNATURE_STATUS_RED | GMIME_SIGNATURE_STATUS_ERROR_MASK)) == 0);
200 }
201
202 gboolean
203 g_mime_signature_status_bad (GMimeSignatureStatus status) {
204     return (status & GMIME_SIGNATURE_STATUS_RED);
205 }
206
207 gboolean
208 g_mime_signature_status_error (GMimeSignatureStatus status) {
209     return (status & GMIME_SIGNATURE_STATUS_ERROR_MASK);
210 }
211
212 gint64
213 g_mime_utils_header_decode_date_unix (const char *date) {
214     GDateTime* parsed_date = g_mime_utils_header_decode_date (date);
215     time_t ret;
216
217     if (parsed_date) {
218         ret = g_date_time_to_unix (parsed_date);
219         g_date_time_unref (parsed_date);
220     } else {
221         ret = 0;
222     }
223
224     return ret;
225 }
226
227 #endif