1 #include "gmime-extra.h"
6 _gzfile_maybe_filter (GMimeStream *file_stream)
11 if ((bytes_read = g_mime_stream_read (file_stream, buf, sizeof (buf))) < 0)
14 if (g_mime_stream_reset (file_stream))
17 /* check for gzipped input */
18 if (bytes_read >= 2 && buf[0] == 0x1f && (unsigned char) buf[1] == 0x8b) {
19 GMimeStream *gzstream;
20 GMimeFilter *gzfilter;
22 gzfilter = g_mime_filter_gzip_new (GMIME_FILTER_GZIP_MODE_UNZIP, 0);
26 gzstream = g_mime_stream_filter_new (file_stream);
30 /* ignore filter id */
31 (void) g_mime_stream_filter_add ((GMimeStreamFilter *) gzstream, gzfilter);
39 g_mime_stream_gzfile_new (int fd)
41 GMimeStream *file_stream;
43 file_stream = g_mime_stream_fs_new (fd);
47 return _gzfile_maybe_filter (file_stream);
51 g_mime_stream_gzfile_open (const char *filename)
53 GMimeStream *file_stream;
55 file_stream = g_mime_stream_fs_open (filename, 0, 0, NULL);
59 return _gzfile_maybe_filter (file_stream);
63 g_mime_stream_stdout_new ()
65 GMimeStream *stream_stdout = NULL;
66 GMimeStream *stream_buffered = NULL;
68 stream_stdout = g_mime_stream_pipe_new (STDOUT_FILENO);
72 g_mime_stream_pipe_set_owner (GMIME_STREAM_PIPE (stream_stdout), FALSE);
74 stream_buffered = g_mime_stream_buffer_new (stream_stdout, GMIME_STREAM_BUFFER_BLOCK_WRITE);
76 g_object_unref (stream_stdout);
78 return stream_buffered;
82 * copy a glib string into a talloc context, and free it.
85 g_string_talloc_strdup (void *ctx, char *g_string)
87 char *new_str = talloc_strdup (ctx, g_string);
94 g_mime_certificate_get_valid_userid (GMimeCertificate *cert)
96 /* output user id only if validity is FULL or ULTIMATE. */
97 const char *uid = g_mime_certificate_get_user_id (cert);
101 GMimeValidity validity = g_mime_certificate_get_id_validity (cert);
102 if (validity == GMIME_VALIDITY_FULL || validity == GMIME_VALIDITY_ULTIMATE)
108 g_mime_certificate_get_fpr16 (GMimeCertificate *cert)
110 const char *fpr = g_mime_certificate_get_fingerprint (cert);
112 if (! fpr || strlen (fpr) < 16)
115 return fpr + (strlen (fpr) - 16);
119 g_mime_message_get_address_string (GMimeMessage *message, GMimeAddressType type)
121 InternetAddressList *list = g_mime_message_get_addresses (message, type);
123 return internet_address_list_to_string (list, NULL, 0);
127 g_mime_message_get_date_string (void *ctx, GMimeMessage *message)
129 GDateTime *parsed_date = g_mime_message_get_date (message);
132 char *date = g_mime_utils_header_format_date (parsed_date);
133 return g_string_talloc_strdup (ctx, date);
135 return talloc_strdup (ctx, "Thu, 01 Jan 1970 00:00:00 +0000");
139 InternetAddressList *
140 g_mime_message_get_reply_to_list (GMimeMessage *message)
142 return g_mime_message_get_reply_to (message);
146 g_mime_message_get_from_string (GMimeMessage *message)
148 return g_mime_object_get_header (GMIME_OBJECT (message), "From");
152 g_mime_message_get_reply_to_string (void *ctx, GMimeMessage *message)
154 InternetAddressList *list = g_mime_message_get_reply_to (message);
156 return g_string_talloc_strdup (ctx, internet_address_list_to_string (list, NULL, 0));
160 g_mime_parser_set_scan_from (GMimeParser *parser, gboolean flag)
162 g_mime_parser_set_format (parser, flag ? GMIME_FORMAT_MBOX : GMIME_FORMAT_MESSAGE);
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.
172 g_mime_signature_status_good (GMimeSignatureStatus status)
174 return ((status & (GMIME_SIGNATURE_STATUS_RED | GMIME_SIGNATURE_STATUS_ERROR_MASK)) == 0);
178 g_mime_signature_status_bad (GMimeSignatureStatus status)
180 return (status & GMIME_SIGNATURE_STATUS_RED);
184 g_mime_signature_status_error (GMimeSignatureStatus status)
186 return (status & GMIME_SIGNATURE_STATUS_ERROR_MASK);
190 g_mime_utils_header_decode_date_unix (const char *date)
192 GDateTime *parsed_date = g_mime_utils_header_decode_date (date);
196 ret = g_date_time_to_unix (parsed_date);
197 g_date_time_unref (parsed_date);