Fix client simulation

In `create_client_simulation_tls_clienthello()` the variable `sni_extension_found` should be set if the ClientHello includes an SNI extension. Instead it was being set if and only if the ClientHello included some extension other than SNI.

This bug wasn't detected before for two reasons:

    It is rare to have a ClientHello that includes an SNI extension, but no other extensions.

    The code still works correctly if `sni_extension_found` is set even if there is no SNI in the ClientHello.

So, the bug only creates a problem if the browser's ClientHello include an SNI extension and no other extensions (see "BingPreview Jun 2014" in the client_simulation branch).
This commit is contained in:
David Cooper 2017-03-24 11:48:01 -04:00 committed by GitHub
parent faefe62bea
commit 3451083bbd

View File

@ -2118,29 +2118,32 @@ create_client_simulation_tls_clienthello() {
len_extensions=2*$(hex2dec "${tls_handshake_ascii:$offset:4}") len_extensions=2*$(hex2dec "${tls_handshake_ascii:$offset:4}")
offset=$offset+4 offset=$offset+4
for (( 1; offset < tls_handshake_ascii_len; 1 )); do for (( 1; offset < tls_handshake_ascii_len; 1 )); do
extension_type="${tls_handshake_ascii:$offset:4}" extension_type="${tls_handshake_ascii:$offset:4}"
offset=$offset+4 offset=$offset+4
len_extension=2*$(hex2dec "${tls_handshake_ascii:$offset:4}") len_extension=2*$(hex2dec "${tls_handshake_ascii:$offset:4}")
if [[ "$extension_type" != "0000" ]]; then if [[ "$extension_type" != "0000" ]]; then
# The extension will just be copied into the revised ClientHello # The extension will just be copied into the revised ClientHello
sni_extension_found=true sni_extension_found=true
offset=$offset-4 offset=$offset-4
len=$len_extension+8 len=$len_extension+8
tls_extensions+="${tls_handshake_ascii:$offset:$len}" tls_extensions+="${tls_handshake_ascii:$offset:$len}"
offset=$offset+$len offset=$offset+$len
elif [[ -n "$SNI" ]]; then else
# Create a server name extension that corresponds to $SNI sni_extension_found=true
len_servername=${#NODE} if [[ -n "$SNI" ]]; then
hexdump_format_str="$len_servername/1 \"%02x\"" # Create a server name extension that corresponds to $SNI
servername_hexstr=$(printf $NODE | hexdump -v -e "${hexdump_format_str}") len_servername=${#NODE}
# convert lengths we need to fill in from dec to hex: hexdump_format_str="$len_servername/1 \"%02x\""
len_servername_hex=$(printf "%02x\n" $len_servername) servername_hexstr=$(printf $NODE | hexdump -v -e "${hexdump_format_str}")
len_sni_listlen=$(printf "%02x\n" $((len_servername+3))) # convert lengths we need to fill in from dec to hex:
len_sni_ext=$(printf "%02x\n" $((len_servername+5))) len_servername_hex=$(printf "%02x\n" $len_servername)
tls_extensions+="000000${len_sni_ext}00${len_sni_listlen}0000${len_servername_hex}${servername_hexstr}" len_sni_listlen=$(printf "%02x\n" $((len_servername+3)))
offset=$offset+$len_extension+4 len_sni_ext=$(printf "%02x\n" $((len_servername+5)))
fi tls_extensions+="000000${len_sni_ext}00${len_sni_listlen}0000${len_servername_hex}${servername_hexstr}"
offset=$offset+$len_extension+4
fi
fi
done done
if ! $sni_extension_found; then if ! $sni_extension_found; then