aboutsummaryrefslogtreecommitdiffstats
path: root/composer
diff options
context:
space:
mode:
Diffstat (limited to 'composer')
-rw-r--r--composer/ChangeLog7
-rw-r--r--composer/e-msg-composer.c29
2 files changed, 26 insertions, 10 deletions
diff --git a/composer/ChangeLog b/composer/ChangeLog
index 4a51c08109..d077cd9316 100644
--- a/composer/ChangeLog
+++ b/composer/ChangeLog
@@ -1,3 +1,10 @@
+2003-08-19 Jeffrey Stedfast <fejj@ximian.com>
+
+ * Original patch from David Woodhouse, but modified a bit by me.
+
+ * e-msg-composer.c (handle_mailto): Fix insertion of arbitrary
+ headers from mailto: links. Ignore From: and Reply-To: headers.
+
2003-08-13 Lorenzo Gil Sanchez <lgs@sicem.biz>
* e-msg-composer-hdrs.c (account_removed_cb): fixed an insulting
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index a7021fcba5..5a78a68a02 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -3839,14 +3839,16 @@ handle_mailto (EMsgComposer *composer, const char *mailto)
GList *to = NULL, *cc = NULL, *bcc = NULL;
EDestination **tov, **ccv, **bccv;
char *subject = NULL, *body = NULL;
- const char *p, *header;
+ char *header, *content, *buf;
size_t nread, nwritten;
- char *content;
+ const char *p;
int len, clen;
CamelURL *url;
+ buf = g_strdup (mailto);
+
/* Parse recipients (everything after ':' until '?' or eos). */
- p = mailto + 7;
+ p = buf + 7;
len = strcspn (p, "?");
if (len) {
content = g_strndup (p, len);
@@ -3866,7 +3868,8 @@ handle_mailto (EMsgComposer *composer, const char *mailto)
if (p[len] != '=')
break;
- header = p;
+ header = (char *) p;
+ header[len] = '\0';
p += len + 1;
clen = strcspn (p, "&");
@@ -3874,13 +3877,13 @@ handle_mailto (EMsgComposer *composer, const char *mailto)
content = g_strndup (p, clen);
camel_url_decode (content);
- if (!strncasecmp (header, "to", len)) {
+ if (!strcasecmp (header, "to")) {
to = add_recipients (to, content, FALSE);
- } else if (!strncasecmp (header, "cc", len)) {
+ } else if (!strcasecmp (header, "cc")) {
cc = add_recipients (cc, content, FALSE);
- } else if (!strncasecmp (header, "bcc", len)) {
+ } else if (!strcasecmp (header, "bcc")) {
bcc = add_recipients (bcc, content, FALSE);
- } else if (!strncasecmp (header, "subject", len)) {
+ } else if (!strcasecmp (header, "subject")) {
g_free (subject);
if (g_utf8_validate (content, -1, NULL)) {
subject = content;
@@ -3893,7 +3896,7 @@ handle_mailto (EMsgComposer *composer, const char *mailto)
subject[nwritten] = '\0';
}
}
- } else if (!strncasecmp (header, "body", len)) {
+ } else if (!strcasecmp (header, "body")) {
g_free (body);
if (g_utf8_validate (content, -1, NULL)) {
body = content;
@@ -3906,7 +3909,7 @@ handle_mailto (EMsgComposer *composer, const char *mailto)
body[nwritten] = '\0';
}
}
- } else if (!strncasecmp (header, "attach", len)) {
+ } else if (!strcasecmp (header, "attach")) {
/*Change file url to absolute path*/
if (!strncasecmp (content, "file:", 5)) {
url = camel_url_new (content, NULL);
@@ -3917,6 +3920,10 @@ handle_mailto (EMsgComposer *composer, const char *mailto)
e_msg_composer_attachment_bar_attach (E_MSG_COMPOSER_ATTACHMENT_BAR (composer->attachment_bar),
content);
}
+ } else if (!strcasecmp (header, "from")) {
+ /* Ignore */
+ } else if (!strcasecmp (header, "reply-to")) {
+ /* ignore */
} else {
/* add an arbitrary header? */
e_msg_composer_add_header (composer, header, content);
@@ -3933,6 +3940,8 @@ handle_mailto (EMsgComposer *composer, const char *mailto)
}
}
+ g_free (buf);
+
tov = e_destination_list_to_vector (to);
ccv = e_destination_list_to_vector (cc);
bccv = e_destination_list_to_vector (bcc);