Fixed INET6 sockaddr processing in nxt_sockaddr_text().
This commit is contained in:
@@ -222,7 +222,7 @@ nxt_sockaddr_text(nxt_sockaddr_t *sa)
|
|||||||
offset = offsetof(nxt_sockaddr_t, u) + sizeof(struct sockaddr_in6);
|
offset = offsetof(nxt_sockaddr_t, u) + sizeof(struct sockaddr_in6);
|
||||||
|
|
||||||
sa->start = offset;
|
sa->start = offset;
|
||||||
sa->address_start = offset;
|
sa->address_start = offset + 1;
|
||||||
|
|
||||||
start = nxt_pointer_to(sa, offset);
|
start = nxt_pointer_to(sa, offset);
|
||||||
p = start;
|
p = start;
|
||||||
@@ -483,7 +483,10 @@ nxt_inet6_ntop(u_char *addr, u_char *buf, u_char *end)
|
|||||||
size_t zero_groups, last_zero_groups, ipv6_bytes;
|
size_t zero_groups, last_zero_groups, ipv6_bytes;
|
||||||
nxt_uint_t i, zero_start, last_zero_start;
|
nxt_uint_t i, zero_start, last_zero_start;
|
||||||
|
|
||||||
if (buf + NXT_INET6_ADDR_STR_LEN > end) {
|
const size_t max_inet6_length =
|
||||||
|
sizeof("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff") - 1;
|
||||||
|
|
||||||
|
if (buf + max_inet6_length > end) {
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user