aboutsummaryrefslogblamecommitdiffstats
path: root/em-format/e-mail-formatter-print-headers.c
blob: a74b94f2cd90acb7ac4f19a8ecf2487b4284e150 (plain) (tree)









































































































































































































































                                                                                             
                                                                                  
 




















                                                                                                   
/*
 * e-mail-formatter-print-headers.c
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) version 3.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with the program; if not, see <http://www.gnu.org/licenses/>
 *
 */

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include "e-mail-format-extensions.h"

#include <glib/gi18n-lib.h>

#include <em-format/e-mail-formatter-extension.h>
#include <em-format/e-mail-formatter.h>
#include <em-format/e-mail-formatter-utils.h>
#include <em-format/e-mail-inline-filter.h>
#include <libemail-engine/e-mail-utils.h>
#include <e-util/e-util.h>

#include <camel/camel.h>

#include <string.h>

typedef struct _EMailFormatterPrintHeaders {
    GObject parent;
} EMailFormatterPrintHeaders;

typedef struct _EMailFormatterPrintHeadersClass {
    GObjectClass parent_class;
} EMailFormatterPrintHeadersClass;

static const gchar *formatter_mime_types[] = { "application/vnd.evolution.headers", NULL };

static void e_mail_formatter_print_formatter_extension_interface_init
                    (EMailFormatterExtensionInterface *iface);
static void e_mail_formatter_print_mail_extension_interface_init
                    (EMailExtensionInterface *iface);

G_DEFINE_TYPE_EXTENDED (
    EMailFormatterPrintHeaders,
    e_mail_formatter_print_headers,
    G_TYPE_OBJECT,
    0,
    G_IMPLEMENT_INTERFACE (
        E_TYPE_MAIL_EXTENSION,
        e_mail_formatter_print_mail_extension_interface_init)
    G_IMPLEMENT_INTERFACE (
        E_TYPE_MAIL_FORMATTER_EXTENSION,
        e_mail_formatter_print_formatter_extension_interface_init))

static gboolean
emfpe_headers_format (EMailFormatterExtension *extension,
                      EMailFormatter *formatter,
                      EMailFormatterContext *context,
                      EMailPart *part,
                      CamelStream *stream,
                      GCancellable *cancellable)
{
    struct _camel_header_raw raw_header;
    GString *str, *tmp;
    gchar *subject;
    const gchar *buf;
    GSList *parts_iter;
    GList *iter;
    gint attachments_count;
    gchar *part_id_prefix;
    const GQueue *headers;

    buf = camel_medium_get_header (CAMEL_MEDIUM (part->part), "subject");
    subject = camel_header_decode_string (buf, "UTF-8");
    str = g_string_new ("");
    g_string_append_printf (str, "<h1>%s</h1>\n", subject);
    g_free (subject);

    g_string_append (
        str,
        "<table border=\"0\" cellspacing=\"5\" "
        "cellpadding=\"0\" class=\"printing-header\">\n");

    headers = e_mail_formatter_get_headers (formatter);
    for (iter = headers->head; iter; iter = iter->next) {

        EMailFormatterHeader *header = iter->data;
        raw_header.name = header->name;

        /* Skip 'Subject' header, it's already displayed. */
        if (g_ascii_strncasecmp (header->name, "Subject", 7) == 0)
            continue;

        if (header->value && *header->value) {
            raw_header.value = header->value;
            e_mail_formatter_format_header (formatter, str,
                CAMEL_MEDIUM (part->part), &raw_header,
                header->flags | E_MAIL_FORMATTER_HEADER_FLAG_NOLINKS,
                "UTF-8");
        } else {
            raw_header.value = g_strdup (camel_medium_get_header (
                CAMEL_MEDIUM (context->message), header->name));

            if (raw_header.value && *raw_header.value) {
                e_mail_formatter_format_header (formatter, str,
                    CAMEL_MEDIUM (part->part), &raw_header,
                    header->flags | E_MAIL_FORMATTER_HEADER_FLAG_NOLINKS,
                    "UTF-8");
            }

            if (raw_header.value)
                g_free (raw_header.value);
        }
    }

        /* Get prefix of this PURI */
    part_id_prefix = g_strndup (part->id, g_strrstr (part->id, ".") - part->id);

    /* Add encryption/signature header */
    raw_header.name = _("Security");
    tmp = g_string_new ("");
    /* Find first secured part. */
    for (parts_iter = context->parts; parts_iter; parts_iter = parts_iter->next) {

        EMailPart *mail_part = parts_iter->data;
        if (mail_part == NULL)
            continue;

        if (mail_part->validity_type == 0)
            continue;

        if (!g_str_has_prefix (mail_part->id, part_id_prefix))
            continue;

        if ((mail_part->validity_type & E_MAIL_PART_VALIDITY_PGP) &&
            (mail_part->validity_type & E_MAIL_PART_VALIDITY_SIGNED)) {
            g_string_append (tmp, _("GPG signed"));
        }
        if ((mail_part->validity_type & E_MAIL_PART_VALIDITY_PGP) &&
            (mail_part->validity_type & E_MAIL_PART_VALIDITY_ENCRYPTED)) {
            if (tmp->len > 0) g_string_append (tmp, ", ");
            g_string_append (tmp, _("GPG encrpyted"));
        }
        if ((mail_part->validity_type & E_MAIL_PART_VALIDITY_SMIME) &&
            (mail_part->validity_type & E_MAIL_PART_VALIDITY_SIGNED)) {

            if (tmp->len > 0) g_string_append (tmp, ", ");
            g_string_append (tmp, _("S/MIME signed"));
        }
        if ((mail_part->validity_type & E_MAIL_PART_VALIDITY_SMIME) &&
            (mail_part->validity_type & E_MAIL_PART_VALIDITY_ENCRYPTED)) {

            if (tmp->len > 0) g_string_append (tmp, ", ");
            g_string_append (tmp, _("S/MIME encrpyted"));
        }

        break;
    }

    if (tmp->len > 0) {
        raw_header.value = tmp->str;
        e_mail_formatter_format_header (
            formatter, str, CAMEL_MEDIUM (part->part), &raw_header,
            E_MAIL_FORMATTER_HEADER_FLAG_BOLD |
            E_MAIL_FORMATTER_HEADER_FLAG_NOLINKS, "UTF-8");
    }
    g_string_free (tmp, TRUE);

    /* Count attachments and display the number as a header */
    attachments_count = 0;

    for (parts_iter = context->parts; parts_iter; parts_iter = parts_iter->next) {

        EMailPart *mail_part = parts_iter->data;
        if (!mail_part)
            continue;

        if (!g_str_has_prefix (mail_part->id, part_id_prefix))
            continue;

        if (mail_part->is_attachment && !mail_part->cid &&
            !mail_part->is_hidden) {
            attachments_count++;
        }
    }

    if (attachments_count > 0) {
        raw_header.name = _("Attachments");
        raw_header.value = g_strdup_printf ("%d", attachments_count);
        e_mail_formatter_format_header (
            formatter, str, CAMEL_MEDIUM (part->part), &raw_header,
            E_MAIL_FORMATTER_HEADER_FLAG_BOLD |
            E_MAIL_FORMATTER_HEADER_FLAG_NOLINKS, "UTF-8");
        g_free (raw_header.value);
    }

    g_string_append (str, "</table>");

    camel_stream_write_string (stream, str->str, cancellable, NULL);
    g_string_free (str, TRUE);
    g_free (part_id_prefix);

    return TRUE;
}

static const gchar *
emfpe_headers_get_display_name (EMailFormatterExtension *extension)
{
    return NULL;
}

static const gchar *
emfpe_headers_get_description (EMailFormatterExtension *extension)
{
    return NULL;
}

static const gchar **
emfpe_headers_mime_types (EMailExtension *extension)
{
    return formatter_mime_types;
}

static void
e_mail_formatter_print_headers_class_init (EMailFormatterPrintHeadersClass *class)
{
}

static void
e_mail_formatter_print_formatter_extension_interface_init (EMailFormatterExtensionInterface *iface)
{
    iface->format = emfpe_headers_format;
    iface->get_display_name = emfpe_headers_get_display_name;
    iface->get_description = emfpe_headers_get_description;
}

static void
e_mail_formatter_print_mail_extension_interface_init (EMailExtensionInterface *iface)
{
    iface->mime_types = emfpe_headers_mime_types;
}

static void
e_mail_formatter_print_headers_init (EMailFormatterPrintHeaders *formatter)
{

}