diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-07-11 15:20:17 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-07-11 15:20:17 +0100 |
commit | db8b9b74f9f91b60d4aab211342c945ecb857700 (patch) | |
tree | 63e999acc0cb4470d196d38a5199deb5bb5277a8 /src/libserver/html.c | |
parent | 4bedefb1e77150fcaaf03c4d17ba6a32b9e80e7a (diff) | |
download | rspamd-db8b9b74f9f91b60d4aab211342c945ecb857700.tar.gz rspamd-db8b9b74f9f91b60d4aab211342c945ecb857700.zip |
[CritFix] Fix decoding of UTF HTML entitles
Diffstat (limited to 'src/libserver/html.c')
-rw-r--r-- | src/libserver/html.c | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/src/libserver/html.c b/src/libserver/html.c index 33ee10d83..7fbe58523 100644 --- a/src/libserver/html.c +++ b/src/libserver/html.c @@ -612,7 +612,7 @@ rspamd_html_decode_entitles_inplace (gchar *s, guint len) } break; case 1: - if (*h == ';') { + if (*h == ';' && h > e) { /* Determine base */ /* First find in entities table */ @@ -621,14 +621,18 @@ rspamd_html_decode_entitles_inplace (gchar *s, guint len) if (*(e + 1) != '#' && (found = bsearch (&key, entities_defs, G_N_ELEMENTS (entities_defs), - sizeof (entity), entity_cmp)) != NULL) { + sizeof (entity), entity_cmp)) != NULL) { if (found->replacement) { rep_len = strlen (found->replacement); memcpy (t, found->replacement, rep_len); t += rep_len; } + else { + memcpy (t, e, h - e); + t += h - e; + } } - else { + else if (e + 2 < h) { if (*(e + 2) == 'x' || *(e + 2) == 'X') { base = 16; } @@ -646,7 +650,8 @@ rspamd_html_decode_entitles_inplace (gchar *s, guint len) } if (end_ptr != NULL && *end_ptr != '\0') { /* Skip undecoded */ - t = h; + memcpy (t, e, h - e); + t += h - e; } else { /* Search for a replacement */ @@ -662,12 +667,24 @@ rspamd_html_decode_entitles_inplace (gchar *s, guint len) t += rep_len; } } + else { + /* Unicode point */ + if (g_unichar_isgraph (val)) { + t += g_unichar_to_utf8 (val, t); + } + else { + memcpy (t, e, h - e); + t += h - e; + } + } } } + *h = ';'; state = 0; } h++; + break; } } |