diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-02-28 11:52:28 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-02-28 11:52:28 +0000 |
commit | ac150373d6ed5ccf9f273d35a36c2f4f1062f3ed (patch) | |
tree | f662ab8639591b65cf1f512f43db5f207e231d63 /src/libserver/html.c | |
parent | 1564b37d8b8f9ed7018ee5afef50ad2bf4409b28 (diff) | |
download | rspamd-ac150373d6ed5ccf9f273d35a36c2f4f1062f3ed.tar.gz rspamd-ac150373d6ed5ccf9f273d35a36c2f4f1062f3ed.zip |
[Minor] Support old libicu
Diffstat (limited to 'src/libserver/html.c')
-rw-r--r-- | src/libserver/html.c | 24 |
1 files changed, 15 insertions, 9 deletions
diff --git a/src/libserver/html.c b/src/libserver/html.c index aa769372f..6ce1ec906 100644 --- a/src/libserver/html.c +++ b/src/libserver/html.c @@ -21,7 +21,10 @@ #include "html_tags.h" #include "html_colors.h" #include "url.h" +#include <unicode/uvernum.h> +#if U_ICU_VERSION_MAJOR_NUM >= 46 #include <unicode/uidna.h> +#endif static sig_atomic_t tags_sorted = 0; static sig_atomic_t entities_sorted = 0; @@ -774,12 +777,14 @@ rspamd_html_url_is_phished (rspamd_mempool_t *pool, gint rc; gchar *url_str = NULL, *idn_hbuf; const guchar *end = url_text + len; +#if U_ICU_VERSION_MAJOR_NUM >= 46 static UIDNA *udn; UErrorCode uc_err = U_ZERO_ERROR; UIDNAInfo uinfo = UIDNA_INFO_INITIALIZER; +#endif *url_found = FALSE; - +#if U_ICU_VERSION_MAJOR_NUM >= 46 if (udn == NULL) { udn = uidna_openUTS46 (UIDNA_DEFAULT, &uc_err); @@ -787,6 +792,7 @@ rspamd_html_url_is_phished (rspamd_mempool_t *pool, msg_err_pool ("cannot init idna convertor: %s", u_errorName (uc_err)); } } +#endif while (url_text < end && g_ascii_isspace (*url_text)) { url_text ++; @@ -800,7 +806,7 @@ rspamd_html_url_is_phished (rspamd_mempool_t *pool, if (rc == URI_ERRNO_OK) { disp_tok.len = text_url->hostlen; disp_tok.begin = text_url->host; - +#if U_ICU_VERSION_MAJOR_NUM >= 46 if (rspamd_substring_search_caseless (text_url->host, text_url->hostlen, "xn--", 4) != -1) { idn_hbuf = rspamd_mempool_alloc (pool, text_url->hostlen * 2 + 1); @@ -818,10 +824,10 @@ rspamd_html_url_is_phished (rspamd_mempool_t *pool, disp_tok.begin = idn_hbuf; } } - +#endif href_tok.len = href_url->hostlen; href_tok.begin = href_url->host; - +#if U_ICU_VERSION_MAJOR_NUM >= 46 if (rspamd_substring_search_caseless (href_url->host, href_url->hostlen, "xn--", 4) != -1) { idn_hbuf = rspamd_mempool_alloc (pool, href_url->hostlen * 2 + 1); @@ -839,13 +845,13 @@ rspamd_html_url_is_phished (rspamd_mempool_t *pool, href_tok.begin = idn_hbuf; } } - +#endif if (rspamd_ftok_casecmp (&disp_tok, &href_tok) != 0) { /* Apply the same logic for TLD */ disp_tok.len = text_url->tldlen; disp_tok.begin = text_url->tld; - +#if U_ICU_VERSION_MAJOR_NUM >= 46 if (rspamd_substring_search_caseless (text_url->tld, text_url->tldlen, "xn--", 4) != -1) { idn_hbuf = rspamd_mempool_alloc (pool, text_url->tldlen * 2 + 1); @@ -863,10 +869,10 @@ rspamd_html_url_is_phished (rspamd_mempool_t *pool, disp_tok.begin = idn_hbuf; } } - +#endif href_tok.len = href_url->tldlen; href_tok.begin = href_url->tld; - +#if U_ICU_VERSION_MAJOR_NUM >= 46 if (rspamd_substring_search_caseless (href_url->tld, href_url->tldlen, "xn--", 4) != -1) { idn_hbuf = rspamd_mempool_alloc (pool, href_url->tldlen * 2 + 1); @@ -884,7 +890,7 @@ rspamd_html_url_is_phished (rspamd_mempool_t *pool, href_tok.begin = idn_hbuf; } } - +#endif if (rspamd_ftok_casecmp (&disp_tok, &href_tok) != 0) { href_url->flags |= RSPAMD_URL_FLAG_PHISHED; href_url->phished_url = text_url; |