This PR fixes an issue with the PROXY protocol where the reader index of a consumed byte array was not set correctly.

Motivation:

When using the AF_UNIX PROXY protocol, the reader index was not set correctly after consuming the message bytes of the original header ByteBuf. This caused no immediate harm because after the codepath there is no consumer of the ByteBuf in the current implementation. It’s a bug nevertheless, because consumers of the ByteBuf for extensions (like TLVs, which are allowed by the PROXY protocol spec) would consume a ByteBuf that has a wrong readerIndex when using AF_UNIX instead of e.g. IPv4 (which has correct behaviour)

Modifications:

Increase the reader index of the ByteBuf after it was read

Result:

Correct and consistent behaviour of the AF_UNIX codepath
This commit is contained in:
Dominik Obermaier 2016-09-29 15:30:18 +02:00 committed by Norman Maurer
parent a26f02d249
commit 79f2827fbe

View File

@ -182,6 +182,9 @@ public final class HAProxyMessage {
addressLen = addressEnd - startIdx; addressLen = addressEnd - startIdx;
} }
dstAddress = header.toString(startIdx, addressLen, CharsetUtil.US_ASCII); dstAddress = header.toString(startIdx, addressLen, CharsetUtil.US_ASCII);
// AF_UNIX defines that exactly 108 bytes are reserved for the address. The previous methods
// did not increase the reader index although we already consumed the information.
header.readerIndex(startIdx + 108);
} else { } else {
if (addressFamily == AddressFamily.AF_IPv4) { if (addressFamily == AddressFamily.AF_IPv4) {
// IPv4 requires 12 bytes for address information // IPv4 requires 12 bytes for address information