util: run uncrustify
[notmuch] / util / gmime-extra.c
1 #include "gmime-extra.h"
2 #include <string.h>
3
4 static
5 GMimeStream *
6 _gzfile_maybe_filter (GMimeStream *file_stream)
7 {
8     char buf[4];
9     int bytes_read;
10
11     if ((bytes_read = g_mime_stream_read (file_stream, buf, sizeof (buf))) < 0)
12         return NULL;
13
14     if (g_mime_stream_reset (file_stream))
15         return NULL;
16
17     /* check for gzipped input */
18     if (bytes_read >= 2 && buf[0] == 0x1f && (unsigned char) buf[1] == 0x8b) {
19         GMimeStream *gzstream;
20         GMimeFilter *gzfilter;
21
22         gzfilter = g_mime_filter_gzip_new (GMIME_FILTER_GZIP_MODE_UNZIP, 0);
23         if (! gzfilter)
24             return NULL;
25
26         gzstream = g_mime_stream_filter_new (file_stream);
27         if (! gzstream)
28             return NULL;
29
30         /* ignore filter id */
31         (void) g_mime_stream_filter_add ((GMimeStreamFilter *) gzstream, gzfilter);
32         return gzstream;
33     } else {
34         return file_stream;
35     }
36 }
37
38 GMimeStream *
39 g_mime_stream_gzfile_new (int fd)
40 {
41     GMimeStream *file_stream;
42
43     file_stream = g_mime_stream_fs_new (fd);
44     if (! file_stream)
45         return NULL;
46
47     return _gzfile_maybe_filter (file_stream);
48 }
49
50 GMimeStream *
51 g_mime_stream_gzfile_open (const char *filename)
52 {
53     GMimeStream *file_stream;
54
55     file_stream = g_mime_stream_fs_open (filename, 0, 0, NULL);
56     if (! file_stream)
57         return NULL;
58
59     return _gzfile_maybe_filter (file_stream);
60 }
61
62 GMimeStream *
63 g_mime_stream_stdout_new ()
64 {
65     GMimeStream *stream_stdout = NULL;
66     GMimeStream *stream_buffered = NULL;
67
68     stream_stdout = g_mime_stream_pipe_new (STDOUT_FILENO);
69     if (! stream_stdout)
70         return NULL;
71
72     g_mime_stream_pipe_set_owner (GMIME_STREAM_PIPE (stream_stdout), FALSE);
73
74     stream_buffered = g_mime_stream_buffer_new (stream_stdout, GMIME_STREAM_BUFFER_BLOCK_WRITE);
75
76     g_object_unref (stream_stdout);
77
78     return stream_buffered;
79 }
80
81 /**
82  * copy a glib string into a talloc context, and free it.
83  */
84 static char *
85 g_string_talloc_strdup (void *ctx, char *g_string)
86 {
87     char *new_str = talloc_strdup (ctx, g_string);
88
89     g_free (g_string);
90     return new_str;
91 }
92
93 const char *
94 g_mime_certificate_get_valid_userid (GMimeCertificate *cert)
95 {
96     /* output user id only if validity is FULL or ULTIMATE. */
97     const char *uid = g_mime_certificate_get_user_id (cert);
98
99     if (uid == NULL)
100         return uid;
101     GMimeValidity validity = g_mime_certificate_get_id_validity (cert);
102     if (validity == GMIME_VALIDITY_FULL || validity == GMIME_VALIDITY_ULTIMATE)
103         return uid;
104     return NULL;
105 }
106
107 const char *
108 g_mime_certificate_get_fpr16 (GMimeCertificate *cert)
109 {
110     const char *fpr = g_mime_certificate_get_fingerprint (cert);
111
112     if (! fpr || strlen (fpr) < 16)
113         return fpr;
114
115     return fpr + (strlen (fpr) - 16);
116 }
117
118 char *
119 g_mime_message_get_address_string (GMimeMessage *message, GMimeAddressType type)
120 {
121     InternetAddressList *list = g_mime_message_get_addresses (message, type);
122
123     return internet_address_list_to_string (list, NULL, 0);
124 }
125
126 char *
127 g_mime_message_get_date_string (void *ctx, GMimeMessage *message)
128 {
129     GDateTime *parsed_date = g_mime_message_get_date (message);
130
131     if (parsed_date) {
132         char *date = g_mime_utils_header_format_date (parsed_date);
133         return g_string_talloc_strdup (ctx, date);
134     } else {
135         return talloc_strdup (ctx, "Thu, 01 Jan 1970 00:00:00 +0000");
136     }
137 }
138
139 InternetAddressList *
140 g_mime_message_get_reply_to_list (GMimeMessage *message)
141 {
142     return g_mime_message_get_reply_to (message);
143 }
144
145 const char *
146 g_mime_message_get_from_string (GMimeMessage *message)
147 {
148     return g_mime_object_get_header (GMIME_OBJECT (message), "From");
149 }
150
151 char *
152 g_mime_message_get_reply_to_string (void *ctx, GMimeMessage *message)
153 {
154     InternetAddressList *list = g_mime_message_get_reply_to (message);
155
156     return g_string_talloc_strdup (ctx, internet_address_list_to_string (list, NULL, 0));
157 }
158
159 void
160 g_mime_parser_set_scan_from (GMimeParser *parser, gboolean flag)
161 {
162     g_mime_parser_set_format (parser, flag ? GMIME_FORMAT_MBOX : GMIME_FORMAT_MESSAGE);
163 }
164
165 /* In GMime 3.0, status GOOD and VALID both imply something about the
166  * validity of the UIDs attached to the signing key. This forces us to
167  * use following somewhat relaxed definition of a "good" signature to
168  * preserve current notmuch semantics.
169  */
170
171 gboolean
172 g_mime_signature_status_good (GMimeSignatureStatus status)
173 {
174     return ((status & (GMIME_SIGNATURE_STATUS_RED | GMIME_SIGNATURE_STATUS_ERROR_MASK)) == 0);
175 }
176
177 gboolean
178 g_mime_signature_status_bad (GMimeSignatureStatus status)
179 {
180     return (status & GMIME_SIGNATURE_STATUS_RED);
181 }
182
183 gboolean
184 g_mime_signature_status_error (GMimeSignatureStatus status)
185 {
186     return (status & GMIME_SIGNATURE_STATUS_ERROR_MASK);
187 }
188
189 gint64
190 g_mime_utils_header_decode_date_unix (const char *date)
191 {
192     GDateTime *parsed_date = g_mime_utils_header_decode_date (date);
193     time_t ret;
194
195     if (parsed_date) {
196         ret = g_date_time_to_unix (parsed_date);
197         g_date_time_unref (parsed_date);
198     } else {
199         ret = 0;
200     }
201
202     return ret;
203 }