]> git.ipfire.org Git - thirdparty/haproxy.git/commitdiff
BUG/MINOR: stick-table/cli: Check for invalid ipv6 key
authorChristopher Faulet <cfaulet@haproxy.com>
Mon, 15 Nov 2021 08:17:25 +0000 (09:17 +0100)
committerChristopher Faulet <cfaulet@haproxy.com>
Mon, 15 Nov 2021 08:17:27 +0000 (09:17 +0100)
When an ipv6 key is used to filter a CLI command on a stick table
(clear/set/show table ...), the return value of inet_pton() call must be
checked to be sure the key is valid.

This patch should fix the issue #1163. It should be backported to all
supported versions.

src/stick_table.c

index ae22b8349bb203f4e7f09de424b589b3a8986654..331ee19a035cd8a82ee34cf477553e34bcf910c4 100644 (file)
@@ -4411,7 +4411,8 @@ static int table_process_entry_per_key(struct appctx *appctx, char **args)
                static_table_key.key = &uint32_key;
                break;
        case SMP_T_IPV6:
-               inet_pton(AF_INET6, args[4], ip6_key);
+               if (inet_pton(AF_INET6, args[4], ip6_key) <= 0)
+                       return cli_err(appctx, "Invalid key\n");
                static_table_key.key = &ip6_key;
                break;
        case SMP_T_SINT: