aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/libserver/protocol.c5
-rw-r--r--src/libserver/re_cache.c2
-rw-r--r--src/libserver/url.c23
-rw-r--r--src/libserver/url.h8
-rw-r--r--src/lua/lua_url.c11
5 files changed, 28 insertions, 21 deletions
diff --git a/src/libserver/protocol.c b/src/libserver/protocol.c
index ee5cc1f4d..4c1a94d99 100644
--- a/src/libserver/protocol.c
+++ b/src/libserver/protocol.c
@@ -994,9 +994,8 @@ emails_protocol_cb (gpointer key, gpointer value, gpointer ud)
struct rspamd_url *url = value;
ucl_object_t *obj;
- if (url->userlen > 0 && url->hostlen > 0 &&
- url->host == url->user + url->userlen + 1) {
- obj = ucl_object_fromlstring (url->user,
+ if (url->userlen > 0 && url->hostlen > 0) {
+ obj = ucl_object_fromlstring (rspamd_url_user_unsafe (url),
url->userlen + url->hostlen + 1);
ucl_array_append (cb->top, obj);
}
diff --git a/src/libserver/re_cache.c b/src/libserver/re_cache.c
index 862ffc351..995af8ddf 100644
--- a/src/libserver/re_cache.c
+++ b/src/libserver/re_cache.c
@@ -1223,7 +1223,7 @@ rspamd_re_cache_exec_re (struct rspamd_task *task,
continue;
}
- in = url->user;
+ in = rspamd_url_user_unsafe (url);
len = url->userlen + 1 + url->hostlen;
scvec[i] = (guchar *) in;
lenvec[i++] = len;
diff --git a/src/libserver/url.c b/src/libserver/url.c
index f4c5783ab..a2a9d852f 100644
--- a/src/libserver/url.c
+++ b/src/libserver/url.c
@@ -1874,7 +1874,7 @@ rspamd_url_shift (struct rspamd_url *uri, gsize nlen,
switch (field) {
case UF_SCHEMA:
if (uri->userlen > 0) {
- uri->user -= shift;
+ uri->usershift -= shift;
}
if (uri->hostlen > 0) {
uri->host -= shift;
@@ -2038,7 +2038,7 @@ rspamd_url_parse (struct rspamd_url *uri,
uri->fragmentlen = complen;
break;
case UF_USERINFO:
- uri->user = comp;
+ uri->usershift = u.field_data[i].off;
uri->userlen = complen;
break;
default:
@@ -3382,7 +3382,7 @@ rspamd_email_hash (gconstpointer u)
}
if (url->userlen > 0) {
- rspamd_cryptobox_fast_hash_update (&st, url->user, url->userlen);
+ rspamd_cryptobox_fast_hash_update (&st, rspamd_url_user_unsafe(url), url->userlen);
}
return (guint)rspamd_cryptobox_fast_hash_final (&st);
@@ -3404,8 +3404,9 @@ rspamd_emails_cmp (gconstpointer a, gconstpointer b)
return FALSE;
}
else {
- return rspamd_lc_cmp (u1->user, u2->user, u1->userlen) ==
- 0;
+ return (rspamd_lc_cmp (rspamd_url_user_unsafe(u1),
+ rspamd_url_user_unsafe(u2),
+ u1->userlen) == 0);
}
}
else {
@@ -3606,7 +3607,7 @@ static const unsigned char rspamd_url_encoding_classes[256] = {
#define CHECK_URL_COMPONENT(beg, len, flags) do { \
for (i = 0; i < (len); i ++) { \
- if ((rspamd_url_encoding_classes[(beg)[i]] & (flags)) == 0) { \
+ if ((rspamd_url_encoding_classes[(guchar)(beg)[i]] & (flags)) == 0) { \
dlen += 2; \
} \
} \
@@ -3614,10 +3615,10 @@ static const unsigned char rspamd_url_encoding_classes[256] = {
#define ENCODE_URL_COMPONENT(beg, len, flags) do { \
for (i = 0; i < (len) && dend > d; i ++) { \
- if ((rspamd_url_encoding_classes[(beg)[i]] & (flags)) == 0) { \
+ if ((rspamd_url_encoding_classes[(guchar)(beg)[i]] & (flags)) == 0) { \
*d++ = '%'; \
- *d++ = hexdigests[((beg)[i] >> 4) & 0xf]; \
- *d++ = hexdigests[(beg)[i] & 0xf]; \
+ *d++ = hexdigests[(guchar)((beg)[i] >> 4) & 0xf]; \
+ *d++ = hexdigests[(guchar)(beg)[i] & 0xf]; \
} \
else { \
*d++ = (beg)[i]; \
@@ -3638,7 +3639,7 @@ rspamd_url_encode (struct rspamd_url *url, gsize *pdlen,
CHECK_URL_COMPONENT ((guchar *)url->host, url->hostlen,
RSPAMD_URL_FLAGS_HOSTSAFE);
- CHECK_URL_COMPONENT ((guchar *)url->user, url->userlen,
+ CHECK_URL_COMPONENT (rspamd_url_user_unsafe(url), url->userlen,
RSPAMD_URL_FLAGS_USERSAFE);
CHECK_URL_COMPONENT ((guchar *)url->data, url->datalen,
RSPAMD_URL_FLAGS_PATHSAFE);
@@ -3677,7 +3678,7 @@ rspamd_url_encode (struct rspamd_url *url, gsize *pdlen,
}
if (url->userlen > 0) {
- ENCODE_URL_COMPONENT ((guchar *)url->user, url->userlen,
+ ENCODE_URL_COMPONENT (rspamd_url_user_unsafe (url), url->userlen,
RSPAMD_URL_FLAGS_USERSAFE);
*d++ = ':';
}
diff --git a/src/libserver/url.h b/src/libserver/url.h
index 53c4abbeb..78330d814 100644
--- a/src/libserver/url.h
+++ b/src/libserver/url.h
@@ -47,7 +47,9 @@ struct rspamd_url {
guint protocol;
guint port;
- gchar *user;
+ guint usershift;
+ guint userlen;
+
gchar *host;
gchar *data;
gchar *query;
@@ -58,7 +60,6 @@ struct rspamd_url {
struct rspamd_url *phished_url;
guint protocollen;
- guint userlen;
guint hostlen;
guint datalen;
guint querylen;
@@ -71,6 +72,9 @@ struct rspamd_url {
guint count;
};
+#define rspamd_url_user(u) ((u)->userlen > 0 ? (u)->string + (u)->usershift : NULL)
+#define rspamd_url_user_unsafe(u) ((u)->string + (u)->usershift)
+
enum uri_errno {
URI_ERRNO_OK = 0, /* Parsing went well */
URI_ERRNO_EMPTY, /* The URI string was empty */
diff --git a/src/lua/lua_url.c b/src/lua/lua_url.c
index 0bd4f1c7e..7b0dee89b 100644
--- a/src/lua/lua_url.c
+++ b/src/lua/lua_url.c
@@ -198,8 +198,8 @@ lua_url_get_user (lua_State *L)
LUA_TRACE_POINT;
struct rspamd_lua_url *url = lua_check_url (L, 1);
- if (url != NULL && url->url->user != NULL) {
- lua_pushlstring (L, url->url->user, url->url->userlen);
+ if (url != NULL && rspamd_url_user (url->url) != NULL) {
+ lua_pushlstring (L, rspamd_url_user (url->url), url->url->userlen);
}
else {
lua_pushnil (L);
@@ -307,7 +307,10 @@ lua_url_tostring (lua_State *L)
if (url->url->protocol == PROTOCOL_MAILTO) {
gchar *tmp = g_malloc (url->url->userlen + 1 +
url->url->hostlen);
- memcpy (tmp, url->url->user, url->url->userlen);
+ if (url->url->userlen) {
+ memcpy (tmp, url->url->string + url->url->usershift, url->url->userlen);
+ }
+
tmp[url->url->userlen] = '@';
memcpy (tmp + url->url->userlen + 1, url->url->host,
url->url->hostlen);
@@ -675,7 +678,7 @@ lua_url_to_table (lua_State *L)
if (u->userlen > 0) {
lua_pushstring (L, "user");
- lua_pushlstring (L, u->user, u->userlen);
+ lua_pushlstring (L, rspamd_url_user (u), u->userlen);
lua_settable (L, -3);
}