summaryrefslogtreecommitdiffstats
path: root/src/libutil/radix.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2014-10-01 15:58:23 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2014-10-01 15:58:23 +0100
commit6ec67947dadeba207104ac0e2c65c9e10a3a580d (patch)
tree85e7fdbbf5081c779bdec6bba723fb35815f2ff9 /src/libutil/radix.c
parenta8c9abd046add08c8ac8f91c3c12d5c823fb44e3 (diff)
downloadrspamd-6ec67947dadeba207104ac0e2c65c9e10a3a580d.tar.gz
rspamd-6ec67947dadeba207104ac0e2c65c9e10a3a580d.zip
Rework addresses parsing.
Diffstat (limited to 'src/libutil/radix.c')
-rw-r--r--src/libutil/radix.c72
1 files changed, 72 insertions, 0 deletions
diff --git a/src/libutil/radix.c b/src/libutil/radix.c
index acf276285..240a7d67d 100644
--- a/src/libutil/radix.c
+++ b/src/libutil/radix.c
@@ -887,6 +887,78 @@ radix_find_compressed_addr (radix_compressed_t *tree, rspamd_inet_addr_t *addr)
return RADIX_NO_VALUE;
}
+gint
+rspamd_radix_add_iplist (const gchar *list, const gchar *separators,
+ radix_compressed_t *tree)
+{
+ gchar *token, *ipnet, *err_str, **strv, **cur;
+ struct in_addr ina;
+ struct in6_addr ina6;
+ guint k = 0;
+ gint af;
+ gint res = 0;
+
+ /* Split string if there are multiple items inside a single string */
+ strv = g_strsplit_set (list, separators, 0);
+ cur = strv;
+ while (*cur) {
+ af = AF_UNSPEC;
+ if (**cur == '\0') {
+ cur++;
+ continue;
+ }
+ /* Extract ipnet */
+ ipnet = *cur;
+ token = strsep (&ipnet, "/");
+
+ if (ipnet != NULL) {
+ errno = 0;
+ /* Get mask */
+ k = strtoul (ipnet, &err_str, 10);
+ if (errno != 0) {
+ msg_warn (
+ "invalid netmask, error detected on symbol: %s, erorr: %s",
+ err_str,
+ strerror (errno));
+ k = 32;
+ }
+ }
+
+ /* Check IP */
+ if (inet_pton (AF_INET, token, &ina) == 1) {
+ af = AF_INET;
+ }
+ else if (inet_pton (AF_INET6, token, &ina6) == 1) {
+ af = AF_INET6;
+ }
+ else {
+ msg_warn ("invalid IP address: %s", token);
+ }
+
+ if (af == AF_INET) {
+ if (k > 32) {
+ k = 32;
+ }
+ radix_insert_compressed (tree, (guint8 *)&ina, sizeof (ina),
+ 32 - k, 1);
+ res ++;
+ }
+ else if (af == AF_INET6){
+ if (k > 128) {
+ k = 128;
+ }
+ radix_insert_compressed (tree, (guint8 *)&ina6, sizeof (ina6),
+ 128 - k, 1);
+ res ++;
+ }
+ cur++;
+ }
+
+ g_strfreev (strv);
+
+ return res;
+}
+
/*
* vi:ts=4
*/