diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2021-04-14 13:58:58 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2021-04-14 13:58:58 +0100 |
commit | 202c18cb66b7cf16ecfe6542580e38b7e3c4bab6 (patch) | |
tree | 2e2a1db07b3b0ee3e9a96d4c93fb7463b35d2f51 /src/libserver | |
parent | 33d268331ab00e377a83e3078c53042254630cf1 (diff) | |
download | rspamd-202c18cb66b7cf16ecfe6542580e38b7e3c4bab6.tar.gz rspamd-202c18cb66b7cf16ecfe6542580e38b7e3c4bab6.zip |
[Minor] Improve rspamd_url structure layout and remove `raw` field
Diffstat (limited to 'src/libserver')
-rw-r--r-- | src/libserver/url.c | 41 | ||||
-rw-r--r-- | src/libserver/url.h | 31 |
2 files changed, 38 insertions, 34 deletions
diff --git a/src/libserver/url.c b/src/libserver/url.c index 1548c4535..fb4b4da94 100644 --- a/src/libserver/url.c +++ b/src/libserver/url.c @@ -428,22 +428,24 @@ const gchar * rspamd_url_strerror (int err) { switch (err) { - case URI_ERRNO_OK: - return "Parsing went well"; - case URI_ERRNO_EMPTY: - return "The URI string was empty"; - case URI_ERRNO_INVALID_PROTOCOL: - return "No protocol was found"; - case URI_ERRNO_BAD_FORMAT: - return "Bad URL format"; - case URI_ERRNO_BAD_ENCODING: - return "Invalid symbols encoded"; - case URI_ERRNO_INVALID_PORT: - return "Port number is bad"; - case URI_ERRNO_TLD_MISSING: - return "TLD part is not detected"; - case URI_ERRNO_HOST_MISSING: - return "Host part is missing"; + case URI_ERRNO_OK: + return "Parsing went well"; + case URI_ERRNO_EMPTY: + return "The URI string was empty"; + case URI_ERRNO_INVALID_PROTOCOL: + return "No protocol was found"; + case URI_ERRNO_BAD_FORMAT: + return "Bad URL format"; + case URI_ERRNO_BAD_ENCODING: + return "Invalid symbols encoded"; + case URI_ERRNO_INVALID_PORT: + return "Port number is bad"; + case URI_ERRNO_TLD_MISSING: + return "TLD part is not detected"; + case URI_ERRNO_HOST_MISSING: + return "Host part is missing"; + case URI_ERRNO_TOO_LONG: + return "URL is too long"; } return NULL; @@ -2187,6 +2189,10 @@ rspamd_url_parse (struct rspamd_url *uri, return URI_ERRNO_EMPTY; } + if (len >= G_MAXUINT16 / 2) { + return URI_ERRNO_TOO_LONG; + } + p = uristring; uri->protocol = PROTOCOL_UNKNOWN; @@ -2219,9 +2225,6 @@ rspamd_url_parse (struct rspamd_url *uri, len = end - uristring; } - uri->raw = p; - uri->rawlen = len; - if (flags & RSPAMD_URL_FLAG_MISSINGSLASHES) { len += 2; uri->string = rspamd_mempool_alloc (pool, len + 1); diff --git a/src/libserver/url.h b/src/libserver/url.h index 59485ab9a..0a36ca17b 100644 --- a/src/libserver/url.h +++ b/src/libserver/url.h @@ -46,20 +46,25 @@ struct rspamd_url_tag { }; struct rspamd_url { - gchar *raw; gchar *string; + gchar *visible_part; + struct rspamd_url *phished_url; + + guint32 flags; + guint16 protocol; + guint16 protocollen; guint16 port; - guint usershift; - guint hostshift; - guint datashift; - guint queryshift; - guint fragmentshift; - guint tldshift; + guint16 usershift; + guint16 hostshift; + guint16 datashift; + guint16 queryshift; + guint16 fragmentshift; + guint16 tldshift; + - guint16 protocollen; guint16 userlen; guint16 hostlen; guint16 datalen; @@ -68,12 +73,7 @@ struct rspamd_url { guint16 tldlen; guint16 count; - guint urllen; - guint rawlen; - guint32 flags; - - gchar *visible_part; - struct rspamd_url *phished_url; + guint16 urllen; }; #define rspamd_url_user(u) ((u)->userlen > 0 ? (u)->string + (u)->usershift : NULL) @@ -95,7 +95,8 @@ enum uri_errno { URI_ERRNO_BAD_ENCODING, /* Bad characters encoding */ URI_ERRNO_BAD_FORMAT, URI_ERRNO_TLD_MISSING, - URI_ERRNO_HOST_MISSING + URI_ERRNO_HOST_MISSING, + URI_ERRNO_TOO_LONG, }; enum rspamd_url_protocol { |