From 175de9b09446460c4572117c9685ed7e4df14810 Mon Sep 17 00:00:00 2001 From: Art Cancro Date: Sun, 15 Nov 2020 16:11:15 -0500 Subject: [PATCH] serv_rssclient.c: RFC2047-encode fields where needed --- citadel/modules/rssclient/serv_rssclient.c | 23 +++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/citadel/modules/rssclient/serv_rssclient.c b/citadel/modules/rssclient/serv_rssclient.c index 85d7f0c1b..7af7b5103 100644 --- a/citadel/modules/rssclient/serv_rssclient.c +++ b/citadel/modules/rssclient/serv_rssclient.c @@ -118,6 +118,11 @@ void rss_start_element(void *data, const char *el, const char **attribute) void rss_end_element(void *data, const char *el) { struct rssparser *r = (struct rssparser *)data; + StrBuf *encoded_field; + + if (StrLength(r->CData) > 0) { // strip leading/trailing whitespace from field + StrBufTrim(r->CData); + } if ( // end of a new item(rss) or entry(atom) (!strcasecmp(el, "entry")) @@ -199,22 +204,25 @@ void rss_end_element(void *data, const char *el) else if (!strcasecmp(el, "title")) { // item subject (rss and atom) if ((r->msg != NULL) && (CM_IsEmpty(r->msg, eMsgSubject))) { - CM_SetField(r->msg, eMsgSubject, ChrPtr(r->CData), StrLength(r->CData)); - striplt(r->msg->cm_fields[eMsgSubject]); + encoded_field = NewStrBuf(); + StrBufRFC2047encode(&encoded_field, r->CData); + CM_SetAsFieldSB(r->msg, eMsgSubject, &encoded_field); } } else if (!strcasecmp(el, "creator")) { // can be used if is not present if ((r->msg != NULL) && (CM_IsEmpty(r->msg, eAuthor))) { - CM_SetField(r->msg, eAuthor, ChrPtr(r->CData), StrLength(r->CData)); - striplt(r->msg->cm_fields[eAuthor]); + encoded_field = NewStrBuf(); + StrBufRFC2047encode(&encoded_field, r->CData); + CM_SetAsFieldSB(r->msg, eAuthor, &encoded_field); } } else if (!strcasecmp(el, "author")) { // supercedes if both are present if (r->msg != NULL) { - CM_SetField(r->msg, eAuthor, ChrPtr(r->CData), StrLength(r->CData)); // CM_SetField will free() the previous value - striplt(r->msg->cm_fields[eAuthor]); + encoded_field = NewStrBuf(); + StrBufRFC2047encode(&encoded_field, r->CData); + CM_SetAsFieldSB(r->msg, eAuthor, &encoded_field); } } @@ -242,7 +250,6 @@ void rss_end_element(void *data, const char *el) r->link = NULL; } r->link = strdup(ChrPtr(r->CData)); - striplt(r->link); } else if ( @@ -254,7 +261,6 @@ void rss_end_element(void *data, const char *el) r->item_id = NULL; } r->item_id = strdup(ChrPtr(r->CData)); - striplt(r->item_id); } else if ( @@ -267,7 +273,6 @@ void rss_end_element(void *data, const char *el) r->description = NULL; } r->description = strdup(ChrPtr(r->CData)); - striplt(r->description); } if (r->CData != NULL) { -- 2.30.2