Merge pull request #1498 from dcooper16/minor_code_cleanup

Minor code cleanup
This commit is contained in:
Dirk Wetter 2020-02-08 10:32:46 +01:00 committed by GitHub
commit 6da6335e5b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1455,7 +1455,7 @@ out_row_aligned_max_width() {
tm_out "${text:0:i}" tm_out "${text:0:i}"
[[ $i -eq $len ]] && break [[ $i -eq $len ]] && break
len=$len-$i-1 len=$len-$i-1
i=$i+1 i+=1
text="${text:i:len}" text="${text:i:len}"
first=false first=false
[[ $len -eq 0 ]] && break [[ $len -eq 0 ]] && break
@ -1915,7 +1915,7 @@ asciihex_to_binary() {
len=${#string} len=${#string}
[[ $len%2 -ne 0 ]] && return 1 [[ $len%2 -ne 0 ]] && return 1
for (( i=0; i <= len-16 ; i=i+16 )); do for (( i=0; i <= len-16 ; i+=16 )); do
ip2=$((i+2)); ip4=$((i+4)); ip6=$((i+6)); ip8=$((i+8)); ip10=$((i+10)); ip12=$((i+12)); ip14=$((i+14)) ip2=$((i+2)); ip4=$((i+4)); ip6=$((i+6)); ip8=$((i+8)); ip10=$((i+10)); ip12=$((i+12)); ip14=$((i+14))
printf -- "\x${string:i:2}\x${string:ip2:2}\x${string:ip4:2}\x${string:ip6:2}\x${string:ip8:2}\x${string:ip10:2}\x${string:ip12:2}\x${string:ip14:2}" printf -- "\x${string:i:2}\x${string:ip2:2}\x${string:ip4:2}\x${string:ip6:2}\x${string:ip8:2}\x${string:ip10:2}\x${string:ip12:2}\x${string:ip14:2}"
done done
@ -3405,7 +3405,7 @@ run_cipher_match(){
local -a ciphers_found ciphers_found2 ciph2 rfc_ciph rfc_ciph2 ossl_supported local -a ciphers_found ciphers_found2 ciph2 rfc_ciph rfc_ciph2 ossl_supported
local -a -i index local -a -i index
local -i nr_ciphers=0 nr_ossl_ciphers=0 nr_nonossl_ciphers=0 local -i nr_ciphers=0 nr_ossl_ciphers=0 nr_nonossl_ciphers=0
local -i num_bundles mod_check bundle_size bundle end_of_bundle local -i num_bundles bundle_size bundle end_of_bundle
local dhlen has_dh_bits="$HAS_DH_BITS" local dhlen has_dh_bits="$HAS_DH_BITS"
local cipher proto protos_to_try local cipher proto protos_to_try
local available local available
@ -3552,12 +3552,10 @@ run_cipher_match(){
# Some servers can't handle a handshake with >= 128 ciphers. So, # Some servers can't handle a handshake with >= 128 ciphers. So,
# test cipher suites in bundles of 128 or less. # test cipher suites in bundles of 128 or less.
num_bundles=$nr_ossl_ciphers/128 num_bundles=$nr_ossl_ciphers/128
mod_check=$nr_ossl_ciphers%128 [[ $((nr_ossl_ciphers%128)) -ne 0 ]] && num_bundles+=1
[[ $mod_check -ne 0 ]] && num_bundles=$num_bundles+1
bundle_size=$nr_ossl_ciphers/$num_bundles bundle_size=$nr_ossl_ciphers/$num_bundles
mod_check=$nr_ossl_ciphers%$num_bundles [[ $((nr_ossl_ciphers%num_bundles)) -ne 0 ]] && bundle_size+=1
[[ $mod_check -ne 0 ]] && bundle_size+=1
fi fi
if "$HAS_TLS13"; then if "$HAS_TLS13"; then
@ -3573,7 +3571,7 @@ run_cipher_match(){
bundle_size=$nr_ossl_ciphers bundle_size=$nr_ossl_ciphers
fi fi
for (( bundle=0; bundle < num_bundles; bundle++ )); do for (( bundle=0; bundle < num_bundles; bundle++ )); do
end_of_bundle=$bundle*$bundle_size+$bundle_size end_of_bundle=$(( (bundle+1)*bundle_size ))
[[ $end_of_bundle -gt $nr_ossl_ciphers ]] && end_of_bundle=$nr_ossl_ciphers [[ $end_of_bundle -gt $nr_ossl_ciphers ]] && end_of_bundle=$nr_ossl_ciphers
while true; do while true; do
ciphers_to_test="" ciphers_to_test=""
@ -3629,17 +3627,15 @@ run_cipher_match(){
# Some servers can't handle a handshake with >= 128 ciphers. So, # Some servers can't handle a handshake with >= 128 ciphers. So,
# test cipher suites in bundles of 128 or less. # test cipher suites in bundles of 128 or less.
num_bundles=$nr_nonossl_ciphers/128 num_bundles=$nr_nonossl_ciphers/128
mod_check=$nr_nonossl_ciphers%128 [[ $((nr_nonossl_ciphers%128)) -ne 0 ]] && num_bundles+=1
[[ $mod_check -ne 0 ]] && num_bundles=$num_bundles+1
bundle_size=$nr_nonossl_ciphers/$num_bundles bundle_size=$nr_nonossl_ciphers/$num_bundles
mod_check=$nr_nonossl_ciphers%$num_bundles [[ $((nr_nonossl_ciphers%num_bundles)) -ne 0 ]] && bundle_size+=1
[[ $mod_check -ne 0 ]] && bundle_size+=1
fi fi
for proto in 04 03 02 01 00; do for proto in 04 03 02 01 00; do
for (( bundle=0; bundle < num_bundles; bundle++ )); do for (( bundle=0; bundle < num_bundles; bundle++ )); do
end_of_bundle=$bundle*$bundle_size+$bundle_size end_of_bundle=$(( (bundle+1)*bundle_size ))
[[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers [[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers
while true; do while true; do
ciphers_to_test="" ciphers_to_test=""
@ -3707,7 +3703,7 @@ run_allciphers() {
local -i nr_ciphers_tested=0 nr_ciphers=0 nr_ossl_ciphers=0 nr_nonossl_ciphers=0 sclient_success=0 local -i nr_ciphers_tested=0 nr_ciphers=0 nr_ossl_ciphers=0 nr_nonossl_ciphers=0 sclient_success=0
local n auth mac hexc sslv2_ciphers="" s local n auth mac hexc sslv2_ciphers="" s
local -a normalized_hexcode hexcode ciph sslvers kx enc export2 sigalg ossl_supported local -a normalized_hexcode hexcode ciph sslvers kx enc export2 sigalg ossl_supported
local -i i end_of_bundle bundle bundle_size num_bundles mod_check local -i i end_of_bundle bundle bundle_size num_bundles
local -a ciphers_found ciphers_found2 hexcode2 ciph2 rfc_ciph2 local -a ciphers_found ciphers_found2 hexcode2 ciph2 rfc_ciph2
local -i -a index local -i -a index
local proto protos_to_try local proto protos_to_try
@ -3828,12 +3824,10 @@ run_allciphers() {
# Some servers can't handle a handshake with >= 128 ciphers. So, # Some servers can't handle a handshake with >= 128 ciphers. So,
# test cipher suites in bundles of 128 or less. # test cipher suites in bundles of 128 or less.
num_bundles=$nr_ossl_ciphers/128 num_bundles=$nr_ossl_ciphers/128
mod_check=$nr_ossl_ciphers%128 [[ $((nr_ossl_ciphers%128)) -ne 0 ]] && num_bundles+=1
[[ $mod_check -ne 0 ]] && num_bundles=$num_bundles+1
bundle_size=$nr_ossl_ciphers/$num_bundles bundle_size=$nr_ossl_ciphers/$num_bundles
mod_check=$nr_ossl_ciphers%$num_bundles [[ $((nr_ossl_ciphers%num_bundles)) -ne 0 ]] && bundle_size+=1
[[ $mod_check -ne 0 ]] && bundle_size+=1
fi fi
if "$HAS_TLS13"; then if "$HAS_TLS13"; then
@ -3851,7 +3845,7 @@ run_allciphers() {
[[ "$proto" != "-no_ssl2" ]] && [[ $(has_server_protocol "${proto:1}") -eq 1 ]] && continue [[ "$proto" != "-no_ssl2" ]] && [[ $(has_server_protocol "${proto:1}") -eq 1 ]] && continue
for (( bundle=0; bundle < num_bundles; bundle++ )); do for (( bundle=0; bundle < num_bundles; bundle++ )); do
end_of_bundle=$bundle*$bundle_size+$bundle_size end_of_bundle=$(( (bundle+1)*bundle_size ))
[[ $end_of_bundle -gt $nr_ossl_ciphers ]] && end_of_bundle=$nr_ossl_ciphers [[ $end_of_bundle -gt $nr_ossl_ciphers ]] && end_of_bundle=$nr_ossl_ciphers
while true; do while true; do
ciphers_to_test="" ciphers_to_test=""
@ -3908,17 +3902,15 @@ run_allciphers() {
# Some servers can't handle a handshake with >= 128 ciphers. So, # Some servers can't handle a handshake with >= 128 ciphers. So,
# test cipher suites in bundles of 128 or less. # test cipher suites in bundles of 128 or less.
num_bundles=$nr_nonossl_ciphers/128 num_bundles=$nr_nonossl_ciphers/128
mod_check=$nr_nonossl_ciphers%128 [[ $((nr_nonossl_ciphers%128)) -ne 0 ]] && num_bundles+=1
[[ $mod_check -ne 0 ]] && num_bundles=$num_bundles+1
bundle_size=$nr_nonossl_ciphers/$num_bundles bundle_size=$nr_nonossl_ciphers/$num_bundles
mod_check=$nr_nonossl_ciphers%$num_bundles [[ $((nr_nonossl_ciphers%num_bundles)) -ne 0 ]] && bundle_size+=1
[[ $mod_check -ne 0 ]] && bundle_size+=1
fi fi
for proto in 04 03 02 01 00; do for proto in 04 03 02 01 00; do
for (( bundle=0; bundle < num_bundles; bundle++ )); do for (( bundle=0; bundle < num_bundles; bundle++ )); do
end_of_bundle=$bundle*$bundle_size+$bundle_size end_of_bundle=$(( (bundle+1)*bundle_size ))
[[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers [[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers
while true; do while true; do
ciphers_to_test="" ciphers_to_test=""
@ -3988,7 +3980,7 @@ ciphers_by_strength() {
local n sslvers auth mac hexc sslv2_ciphers="" cipher local n sslvers auth mac hexc sslv2_ciphers="" cipher
local -a hexcode normalized_hexcode ciph rfc_ciph kx enc export2 local -a hexcode normalized_hexcode ciph rfc_ciph kx enc export2
local -a hexcode2 ciph2 rfc_ciph2 local -a hexcode2 ciph2 rfc_ciph2
local -i i bundle end_of_bundle bundle_size num_bundles mod_check local -i i bundle end_of_bundle bundle_size num_bundles
local -a ciphers_found ciphers_found2 sigalg ossl_supported index local -a ciphers_found ciphers_found2 sigalg ossl_supported index
local dhlen supported_sslv2_ciphers ciphers_to_test tls13_ciphers_to_test addcmd temp local dhlen supported_sslv2_ciphers ciphers_to_test tls13_ciphers_to_test addcmd temp
local available local available
@ -4125,16 +4117,14 @@ ciphers_by_strength() {
# Some servers can't handle a handshake with >= 128 ciphers. So, # Some servers can't handle a handshake with >= 128 ciphers. So,
# test cipher suites in bundles of 128 or less. # test cipher suites in bundles of 128 or less.
num_bundles=$nr_ossl_ciphers/128 num_bundles=$nr_ossl_ciphers/128
mod_check=$nr_ossl_ciphers%128 [[ $((nr_ossl_ciphers%128)) -ne 0 ]] && num_bundles+=1
[[ $mod_check -ne 0 ]] && num_bundles=$num_bundles+1
bundle_size=$nr_ossl_ciphers/$num_bundles bundle_size=$nr_ossl_ciphers/$num_bundles
mod_check=$nr_ossl_ciphers%$num_bundles [[ $((nr_ossl_ciphers%num_bundles)) -ne 0 ]] && bundle_size+=1
[[ $mod_check -ne 0 ]] && bundle_size+=1
fi fi
for (( bundle=0; bundle < num_bundles; bundle++ )); do for (( bundle=0; bundle < num_bundles; bundle++ )); do
end_of_bundle=$bundle*$bundle_size+$bundle_size end_of_bundle=$(( (bundle+1)*bundle_size ))
[[ $end_of_bundle -gt $nr_ossl_ciphers ]] && end_of_bundle=$nr_ossl_ciphers [[ $end_of_bundle -gt $nr_ossl_ciphers ]] && end_of_bundle=$nr_ossl_ciphers
for (( success=0; success==0 ; 1 )); do for (( success=0; success==0 ; 1 )); do
ciphers_to_test="" ciphers_to_test=""
@ -4193,16 +4183,14 @@ ciphers_by_strength() {
# Some servers can't handle a handshake with >= 128 ciphers. So, # Some servers can't handle a handshake with >= 128 ciphers. So,
# test cipher suites in bundles of 128 or less. # test cipher suites in bundles of 128 or less.
num_bundles=$nr_nonossl_ciphers/128 num_bundles=$nr_nonossl_ciphers/128
mod_check=$nr_nonossl_ciphers%128 [[ $((nr_nonossl_ciphers%128)) -ne 0 ]] && num_bundles+=1
[[ $mod_check -ne 0 ]] && num_bundles=$num_bundles+1
bundle_size=$nr_nonossl_ciphers/$num_bundles bundle_size=$nr_nonossl_ciphers/$num_bundles
mod_check=$nr_nonossl_ciphers%$num_bundles [[ $((nr_nonossl_ciphers%num_bundles)) -ne 0 ]] && bundle_size+=1
[[ $mod_check -ne 0 ]] && bundle_size+=1
fi fi
for (( bundle=0; bundle < num_bundles; bundle++ )); do for (( bundle=0; bundle < num_bundles; bundle++ )); do
end_of_bundle=$bundle*$bundle_size+$bundle_size end_of_bundle=$(( (bundle+1)*bundle_size ))
[[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers [[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers
for (( success=0; success==0 ; 1 )); do for (( success=0; success==0 ; 1 )); do
ciphers_to_test="" ciphers_to_test=""
@ -4431,7 +4419,7 @@ client_simulation_sockets() {
TLS_CLIENT_HELLO="" TLS_CLIENT_HELLO=""
fi fi
len=${#clienthello} len=${#clienthello}
for (( i=0; i < len; i=i+2 )); do for (( i=0; i < len; i+=2 )); do
data+=", ${clienthello:i:2}" data+=", ${clienthello:i:2}"
done done
# same as above. If a CIPHER_SUITES string was provided, then check that it is in the ServerHello # same as above. If a CIPHER_SUITES string was provided, then check that it is in the ServerHello
@ -4449,7 +4437,7 @@ client_simulation_sockets() {
else else
# Extact list of cipher suites from SSLv2 ClientHello # Extact list of cipher suites from SSLv2 ClientHello
len=2*$(hex2dec "${clienthello:12:2}") len=2*$(hex2dec "${clienthello:12:2}")
for (( i=22; i < 22+len; i=i+6 )); do for (( i=22; i < 22+len; i+=6 )); do
offset1=$i+2 offset1=$i+2
offset2=$i+4 offset2=$i+4
[[ "${clienthello:i:2}" == 00 ]] && cipher_list_2send+=", ${clienthello:offset1:2},${clienthello:offset2:2}" [[ "${clienthello:i:2}" == 00 ]] && cipher_list_2send+=", ${clienthello:offset1:2},${clienthello:offset2:2}"
@ -5643,7 +5631,7 @@ sub_cipherlists() {
sslv2_cipherlist="$(strip_spaces "${6//,/}")" sslv2_cipherlist="$(strip_spaces "${6//,/}")"
len=${#sslv2_cipherlist} len=${#sslv2_cipherlist}
detected_ssl2_ciphers="$(grep "Supported cipher: " "$TEMPDIR/$NODEIP.parse_sslv2_serverhello.txt")" detected_ssl2_ciphers="$(grep "Supported cipher: " "$TEMPDIR/$NODEIP.parse_sslv2_serverhello.txt")"
for (( i=0; i<len; i=i+6 )); do for (( i=0; i<len; i+=6 )); do
[[ "$detected_ssl2_ciphers" =~ "x${sslv2_cipherlist:i:6}" ]] && sclient_success=0 && break [[ "$detected_ssl2_ciphers" =~ "x${sslv2_cipherlist:i:6}" ]] && sclient_success=0 && break
done done
fi fi
@ -6708,7 +6696,7 @@ cipher_pref_check() {
local using_sockets="$4" local using_sockets="$4"
local tested_cipher cipher order rfc_cipher rfc_order local tested_cipher cipher order rfc_cipher rfc_order
local overflow_probe_cipherlist="ALL:-ECDHE-RSA-AES256-GCM-SHA384:-AES128-SHA:-DES-CBC3-SHA" local overflow_probe_cipherlist="ALL:-ECDHE-RSA-AES256-GCM-SHA384:-AES128-SHA:-DES-CBC3-SHA"
local -i i nr_ciphers nr_nonossl_ciphers num_bundles mod_check bundle_size bundle end_of_bundle success local -i i nr_ciphers nr_nonossl_ciphers num_bundles bundle_size bundle end_of_bundle success
local hexc ciphers_to_test local hexc ciphers_to_test
local -a rfc_ciph hexcode ciphers_found ciphers_found2 local -a rfc_ciph hexcode ciphers_found ciphers_found2
local -a -i index local -a -i index
@ -6789,16 +6777,14 @@ cipher_pref_check() {
bundle_size=$nr_nonossl_ciphers bundle_size=$nr_nonossl_ciphers
else else
num_bundles=$nr_nonossl_ciphers/128 num_bundles=$nr_nonossl_ciphers/128
mod_check=$nr_nonossl_ciphers%128 [[ $((nr_nonossl_ciphers%128)) -ne 0 ]] && num_bundles+=1
[[ $mod_check -ne 0 ]] && num_bundles=$num_bundles+1
bundle_size=$nr_nonossl_ciphers/$num_bundles bundle_size=$nr_nonossl_ciphers/$num_bundles
mod_check=$nr_nonossl_ciphers%$num_bundles [[ $((nr_nonossl_ciphers%num_bundles)) -ne 0 ]] && bundle_size+=1
[[ $mod_check -ne 0 ]] && bundle_size+=1
fi fi
for (( bundle=0; bundle < num_bundles; bundle++ )); do for (( bundle=0; bundle < num_bundles; bundle++ )); do
end_of_bundle=$bundle*$bundle_size+$bundle_size end_of_bundle=$(( (bundle+1)*bundle_size ))
[[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers [[ $end_of_bundle -gt $nr_nonossl_ciphers ]] && end_of_bundle=$nr_nonossl_ciphers
while true; do while true; do
ciphers_to_test="" ciphers_to_test=""
@ -7705,7 +7691,7 @@ compare_server_name_to_cert() {
fi fi
if [[ $len -ne 0 ]] && [[ $len -lt ${#dercert} ]]; then if [[ $len -ne 0 ]] && [[ $len -lt ${#dercert} ]]; then
# loop through all the names and extract the SRV-ID and XmppAddr identifiers # loop through all the names and extract the SRV-ID and XmppAddr identifiers
for (( i=0; i < len; i=i+len_name )); do for (( i=0; i < len; i+=len_name )); do
tag="${dercert:i:2}" tag="${dercert:i:2}"
i+=2 i+=2
if [[ "${dercert:i:1}" == "8" ]]; then if [[ "${dercert:i:1}" == "8" ]]; then
@ -7861,7 +7847,7 @@ etsi_etls_visibility_info() {
fi fi
if [[ $len -ne 0 ]] && [[ $len -lt ${#dercert} ]]; then if [[ $len -ne 0 ]] && [[ $len -lt ${#dercert} ]]; then
# loop through all the names and extract the visibility information # loop through all the names and extract the visibility information
for (( i=0; i < len; i=i+len_name )); do for (( i=0; i < len; i+=len_name )); do
tag="${dercert:i:2}" tag="${dercert:i:2}"
i+=2 i+=2
if [[ "${dercert:i:1}" == 8 ]]; then if [[ "${dercert:i:1}" == 8 ]]; then
@ -10601,7 +10587,7 @@ get_dh_ephemeralkey() {
fi fi
# Subtract any leading 0 bytes # Subtract any leading 0 bytes
for (( i=4; i < offset; i=i+2 )); do for (( i=4; i < offset; i+=2 )); do
[[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break [[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break
dh_p_len=$dh_p_len-2 dh_p_len=$dh_p_len-2
done done
@ -10619,7 +10605,7 @@ get_dh_ephemeralkey() {
return 1 return 1
fi fi
# Subtract any leading 0 bytes # Subtract any leading 0 bytes
for (( 1; i < offset; i=i+2 )); do for (( 1; i < offset; i+=2 )); do
[[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break [[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break
dh_g_len=$dh_g_len-2 dh_g_len=$dh_g_len-2
done done
@ -10637,7 +10623,7 @@ get_dh_ephemeralkey() {
return 1 return 1
fi fi
# Subtract any leading 0 bytes # Subtract any leading 0 bytes
for (( 1; i < offset; i=i+2 )); do for (( 1; i < offset; i+=2 )); do
[[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break [[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break
dh_y_len=$dh_y_len-2 dh_y_len=$dh_y_len-2
done done
@ -10912,7 +10898,7 @@ hkdf-expand() {
local hash_fn="$1" local hash_fn="$1"
local prk="$2" info="$3" output="" local prk="$2" info="$3" output=""
local -i out_len="$4" local -i out_len="$4"
local -i i n mod_check hash_len ret local -i i n hash_len ret
local counter local counter
local ti tim1 # T(i) and T(i-1) local ti tim1 # T(i) and T(i-1)
@ -10923,8 +10909,7 @@ hkdf-expand() {
esac esac
n=$out_len/$hash_len n=$out_len/$hash_len
mod_check=$out_len%$hash_len [[ $((out_len%hash_len)) -ne 0 ]] && n+=1
[[ $mod_check -ne 0 ]] && n+=1
tim1="" tim1=""
for (( i=1; i <= n; i++ )); do for (( i=1; i <= n; i++ )); do
@ -11464,7 +11449,7 @@ chacha20() {
if [[ $mod_check -ne 0 ]]; then if [[ $mod_check -ne 0 ]]; then
keystream="$(chacha20_block "$key" "$(printf "%08X" $counter)" "$nonce")" keystream="$(chacha20_block "$key" "$(printf "%08X" $counter)" "$nonce")"
i1=$((128*num_blocks)) i1=$((128*num_blocks))
for (( i=0; i < mod_check; i=i+2 )); do for (( i=0; i < mod_check; i+=2 )); do
plaintext+="$(printf "%02X" "$((0x${ciphertext:i1:2} ^ 0x${keystream:i:2}))")" plaintext+="$(printf "%02X" "$((0x${ciphertext:i1:2} ^ 0x${keystream:i:2}))")"
i1+=2 i1+=2
done done
@ -11688,7 +11673,7 @@ generate-ccm-counter-blocks() {
ctr_msb="${ctr:0:24}" ctr_msb="${ctr:0:24}"
ctr_lsb=0x${ctr:24:8} ctr_lsb=0x${ctr:24:8}
for (( i=0; i <= n; i=i+1 )); do for (( i=0; i <= n; i+=1 )); do
ctr_lsb1="$(printf "%08X" "$ctr_lsb")" ctr_lsb1="$(printf "%08X" "$ctr_lsb")"
printf "\x${ctr_msb:0:2}\x${ctr_msb:2:2}\x${ctr_msb:4:2}\x${ctr_msb:6:2}\x${ctr_msb:8:2}\x${ctr_msb:10:2}\x${ctr_msb:12:2}\x${ctr_msb:14:2}\x${ctr_msb:16:2}\x${ctr_msb:18:2}\x${ctr_msb:20:2}\x${ctr_msb:22:2}\x${ctr_lsb1:0:2}\x${ctr_lsb1:2:2}\x${ctr_lsb1:4:2}\x${ctr_lsb1:6:2}" printf "\x${ctr_msb:0:2}\x${ctr_msb:2:2}\x${ctr_msb:4:2}\x${ctr_msb:6:2}\x${ctr_msb:8:2}\x${ctr_msb:10:2}\x${ctr_msb:12:2}\x${ctr_msb:14:2}\x${ctr_msb:16:2}\x${ctr_msb:18:2}\x${ctr_msb:20:2}\x${ctr_msb:22:2}\x${ctr_lsb1:0:2}\x${ctr_lsb1:2:2}\x${ctr_lsb1:4:2}\x${ctr_lsb1:6:2}"
ctr_lsb+=1 ctr_lsb+=1
@ -11826,7 +11811,7 @@ ccm-decrypt() {
# If the length of the ciphertext is not an even multiple of 16 bytes, then handle the final incomplete block. # If the length of the ciphertext is not an even multiple of 16 bytes, then handle the final incomplete block.
if [[ $mod_check -ne 0 ]]; then if [[ $mod_check -ne 0 ]]; then
i1=$((32*n)) i1=$((32*n))
for (( i=0; i < mod_check; i=i+2 )); do for (( i=0; i < mod_check; i+=2 )); do
plaintext+="$(printf "%02X" "$((0x${ciphertext:i1:2} ^ 0x${s:i1:2}))")" plaintext+="$(printf "%02X" "$((0x${ciphertext:i1:2} ^ 0x${s:i1:2}))")"
i1+=2 i1+=2
done done
@ -11912,7 +11897,7 @@ ccm-encrypt() {
# If the length of the plaintext is not an even multiple of 16 bytes, then handle the final incomplete block. # If the length of the plaintext is not an even multiple of 16 bytes, then handle the final incomplete block.
if [[ $mod_check -ne 0 ]]; then if [[ $mod_check -ne 0 ]]; then
i1=$((32*n)) i1=$((32*n))
for (( i=0; i < mod_check; i=i+2 )); do for (( i=0; i < mod_check; i+=2 )); do
ciphertext+="$(printf "%02X" "$((0x${plaintext:i1:2} ^ 0x${s:i1:2}))")" ciphertext+="$(printf "%02X" "$((0x${plaintext:i1:2} ^ 0x${s:i1:2}))")"
i1+=2 i1+=2
done done
@ -12319,7 +12304,7 @@ check_tls_serverhellodone() {
fi fi
tls_hello_ascii_len=${#tls_hello_ascii} tls_hello_ascii_len=${#tls_hello_ascii}
for (( i=0; i<tls_hello_ascii_len; i=i+msg_len )); do for (( i=0; i<tls_hello_ascii_len; i+=msg_len )); do
remaining=$tls_hello_ascii_len-$i remaining=$tls_hello_ascii_len-$i
[[ $remaining -lt 10 ]] && return 1 [[ $remaining -lt 10 ]] && return 1
@ -12328,14 +12313,14 @@ check_tls_serverhellodone() {
14|15|16|17) ;; 14|15|16|17) ;;
*) return 2 ;; *) return 2 ;;
esac esac
i=$i+2 i+=2
tls_protocol="${tls_hello_ascii:i:4}" tls_protocol="${tls_hello_ascii:i:4}"
[[ -z "$DETECTED_TLS_VERSION" ]] && DETECTED_TLS_VERSION="$tls_protocol" [[ -z "$DETECTED_TLS_VERSION" ]] && DETECTED_TLS_VERSION="$tls_protocol"
[[ "${tls_protocol:0:2}" != 03 ]] && return 2 [[ "${tls_protocol:0:2}" != 03 ]] && return 2
i=$i+4 i+=4
additional_data="$tls_content_type$tls_protocol${tls_hello_ascii:i:4}" additional_data="$tls_content_type$tls_protocol${tls_hello_ascii:i:4}"
msg_len=2*$(hex2dec "${tls_hello_ascii:i:4}") msg_len=2*$(hex2dec "${tls_hello_ascii:i:4}")
i=$i+4 i+=4
remaining=$tls_hello_ascii_len-$i remaining=$tls_hello_ascii_len-$i
[[ $msg_len -gt $remaining ]] && return 1 [[ $msg_len -gt $remaining ]] && return 1
@ -12360,7 +12345,7 @@ check_tls_serverhellodone() {
offset=84+$sid_len offset=84+$sid_len
tls_extensions_len=2*$(hex2dec "${tls_handshake_ascii:offset:4}") tls_extensions_len=2*$(hex2dec "${tls_handshake_ascii:offset:4}")
[[ $tls_extensions_len -ne $tls_serverhello_ascii_len-$sid_len-80 ]] && return 2 [[ $tls_extensions_len -ne $tls_serverhello_ascii_len-$sid_len-80 ]] && return 2
for (( j=0; j<tls_extensions_len; j=j+8+extension_len )); do for (( j=0; j<tls_extensions_len; j+=8+extension_len )); do
[[ $tls_extensions_len-$j -lt 8 ]] && return 2 [[ $tls_extensions_len-$j -lt 8 ]] && return 2
offset=88+$sid_len+$j offset=88+$sid_len+$j
extension_type="${tls_handshake_ascii:offset:4}" extension_type="${tls_handshake_ascii:offset:4}"
@ -12417,7 +12402,7 @@ check_tls_serverhellodone() {
# If there is a fatal alert, then we are done. # If there is a fatal alert, then we are done.
tls_alert_ascii_len=${#tls_alert_ascii} tls_alert_ascii_len=${#tls_alert_ascii}
for (( i=0; i<tls_alert_ascii_len; i=i+4 )); do for (( i=0; i<tls_alert_ascii_len; i+=4 )); do
remaining=$tls_alert_ascii_len-$i remaining=$tls_alert_ascii_len-$i
[[ $remaining -lt 4 ]] && return 1 [[ $remaining -lt 4 ]] && return 1
tls_err_level=${tls_alert_ascii:i:2} # 1: warning, 2: fatal tls_err_level=${tls_alert_ascii:i:2} # 1: warning, 2: fatal
@ -12426,13 +12411,13 @@ check_tls_serverhellodone() {
# If there is a serverHelloDone or Finished, then we are done. # If there is a serverHelloDone or Finished, then we are done.
tls_handshake_ascii_len=${#tls_handshake_ascii} tls_handshake_ascii_len=${#tls_handshake_ascii}
for (( i=0; i<tls_handshake_ascii_len; i=i+msg_len )); do for (( i=0; i<tls_handshake_ascii_len; i+=msg_len )); do
remaining=$tls_handshake_ascii_len-$i remaining=$tls_handshake_ascii_len-$i
[[ $remaining -lt 8 ]] && return 1 [[ $remaining -lt 8 ]] && return 1
tls_msg_type="${tls_handshake_ascii:i:2}" tls_msg_type="${tls_handshake_ascii:i:2}"
i=$i+2 i+=2
msg_len=2*$(hex2dec "${tls_handshake_ascii:i:6}") msg_len=2*$(hex2dec "${tls_handshake_ascii:i:6}")
i=$i+6 i+=6
remaining=$tls_handshake_ascii_len-$i remaining=$tls_handshake_ascii_len-$i
[[ $msg_len -gt $remaining ]] && return 1 [[ $msg_len -gt $remaining ]] && return 1
@ -12567,7 +12552,7 @@ parse_tls_serverhello() {
if [[ $DEBUG -ge 3 ]] && [[ $tls_hello_ascii_len -gt 0 ]]; then if [[ $DEBUG -ge 3 ]] && [[ $tls_hello_ascii_len -gt 0 ]]; then
echo "TLS message fragments:" echo "TLS message fragments:"
fi fi
for (( i=0; i<tls_hello_ascii_len; i=i+msg_len )); do for (( i=0; i<tls_hello_ascii_len; i+=msg_len )); do
if [[ $tls_hello_ascii_len-$i -lt 10 ]]; then if [[ $tls_hello_ascii_len-$i -lt 10 ]]; then
if [[ "$process_full" =~ all ]]; then if [[ "$process_full" =~ all ]]; then
# The entire server response should have been retrieved. # The entire server response should have been retrieved.
@ -12581,11 +12566,11 @@ parse_tls_serverhello() {
fi fi
fi fi
tls_content_type="${tls_hello_ascii:i:2}" tls_content_type="${tls_hello_ascii:i:2}"
i=$i+2 i+=2
tls_protocol="${tls_hello_ascii:i:4}" tls_protocol="${tls_hello_ascii:i:4}"
i=$i+4 i+=4
msg_len=2*$(hex2dec "${tls_hello_ascii:i:4}") msg_len=2*$(hex2dec "${tls_hello_ascii:i:4}")
i=$i+4 i+=4
if [[ $DEBUG -ge 3 ]]; then if [[ $DEBUG -ge 3 ]]; then
echo " protocol (rec. layer): 0x$tls_protocol" echo " protocol (rec. layer): 0x$tls_protocol"
@ -12652,7 +12637,7 @@ parse_tls_serverhello() {
if [[ $tls_alert_ascii_len -gt 0 ]]; then if [[ $tls_alert_ascii_len -gt 0 ]]; then
debugme echo "TLS alert messages:" debugme echo "TLS alert messages:"
for (( i=0; i+3 < tls_alert_ascii_len; i=i+4 )); do for (( i=0; i+3 < tls_alert_ascii_len; i+=4 )); do
tls_err_level=${tls_alert_ascii:i:2} # 1: warning, 2: fatal tls_err_level=${tls_alert_ascii:i:2} # 1: warning, 2: fatal
j=$i+2 j=$i+2
tls_err_descr_no=${tls_alert_ascii:j:2} tls_err_descr_no=${tls_alert_ascii:j:2}
@ -12691,7 +12676,7 @@ parse_tls_serverhello() {
if [[ $DEBUG -ge 3 ]] && [[ $tls_handshake_ascii_len -gt 0 ]]; then if [[ $DEBUG -ge 3 ]] && [[ $tls_handshake_ascii_len -gt 0 ]]; then
echo "TLS handshake messages:" echo "TLS handshake messages:"
fi fi
for (( i=0; i<tls_handshake_ascii_len; i=i+msg_len )); do for (( i=0; i<tls_handshake_ascii_len; i+=msg_len )); do
if [[ $tls_handshake_ascii_len-$i -lt 8 ]]; then if [[ $tls_handshake_ascii_len-$i -lt 8 ]]; then
if [[ "$process_full" =~ all ]]; then if [[ "$process_full" =~ all ]]; then
# The entire server response should have been retrieved. # The entire server response should have been retrieved.
@ -12705,9 +12690,9 @@ parse_tls_serverhello() {
fi fi
fi fi
tls_msg_type="${tls_handshake_ascii:i:2}" tls_msg_type="${tls_handshake_ascii:i:2}"
i=$i+2 i+=2
msg_len=2*$(hex2dec "${tls_handshake_ascii:i:6}") msg_len=2*$(hex2dec "${tls_handshake_ascii:i:6}")
i=$i+6 i+=6
if [[ $DEBUG -ge 3 ]]; then if [[ $DEBUG -ge 3 ]]; then
tm_out " handshake type: 0x${tls_msg_type}" tm_out " handshake type: 0x${tls_msg_type}"
case $tls_msg_type in case $tls_msg_type in
@ -12902,7 +12887,7 @@ parse_tls_serverhello() {
[[ $DEBUG -ge 1 ]] && tmpfile_handle ${FUNCNAME[0]}.txt [[ $DEBUG -ge 1 ]] && tmpfile_handle ${FUNCNAME[0]}.txt
return 1 return 1
fi fi
for (( i=0; i<tls_extensions_len; i=i+8+extension_len )); do for (( i=0; i<tls_extensions_len; i+=8+extension_len )); do
if [[ $tls_extensions_len-$i -lt 8 ]]; then if [[ $tls_extensions_len-$i -lt 8 ]]; then
debugme echo "Malformed response" debugme echo "Malformed response"
[[ $DEBUG -ge 1 ]] && tmpfile_handle ${FUNCNAME[0]}.txt [[ $DEBUG -ge 1 ]] && tmpfile_handle ${FUNCNAME[0]}.txt
@ -12952,7 +12937,7 @@ parse_tls_serverhello() {
return 1 return 1
fi fi
offset=$((offset+4)) offset=$((offset+4))
for (( j=0; j < len1; j=j+4 )); do for (( j=0; j < len1; j+=4 )); do
[[ $j -ne 0 ]] && echo -n ", " >> $TMPFILE [[ $j -ne 0 ]] && echo -n ", " >> $TMPFILE
case "${tls_serverhello_ascii:offset:4}" in case "${tls_serverhello_ascii:offset:4}" in
"0017") echo -n "secp256r1" >> $TMPFILE ;; "0017") echo -n "secp256r1" >> $TMPFILE ;;
@ -13130,7 +13115,7 @@ parse_tls_serverhello() {
local -i protocol_len local -i protocol_len
echo -n "Protocols advertised by server: " >> $TMPFILE echo -n "Protocols advertised by server: " >> $TMPFILE
offset=$((extns_offset+12+i)) offset=$((extns_offset+12+i))
for (( j=0; j<extension_len; j=j+protocol_len+2 )); do for (( j=0; j<extension_len; j+=protocol_len+2 )); do
if [[ $extension_len -lt $j+2 ]]; then if [[ $extension_len -lt $j+2 ]]; then
debugme echo "Malformed next protocol extension." debugme echo "Malformed next protocol extension."
[[ $DEBUG -ge 1 ]] && tmpfile_handle ${FUNCNAME[0]}.txt [[ $DEBUG -ge 1 ]] && tmpfile_handle ${FUNCNAME[0]}.txt
@ -13193,7 +13178,7 @@ parse_tls_serverhello() {
tmpfile_handle ${FUNCNAME[0]}.txt tmpfile_handle ${FUNCNAME[0]}.txt
return 1 return 1
fi fi
for (( j=8; j < tls_certificate_ascii_len; j=j+extn_len )); do for (( j=8; j < tls_certificate_ascii_len; j+=extn_len )); do
if [[ $tls_certificate_ascii_len-$j -lt 6 ]]; then if [[ $tls_certificate_ascii_len-$j -lt 6 ]]; then
debugme tmln_warning "Malformed Certificate Handshake message in ServerHello." debugme tmln_warning "Malformed Certificate Handshake message in ServerHello."
tmpfile_handle ${FUNCNAME[0]}.txt tmpfile_handle ${FUNCNAME[0]}.txt
@ -13329,7 +13314,7 @@ parse_tls_serverhello() {
tls_cipher_suite="$(tolower "$tls_cipher_suite")" tls_cipher_suite="$(tolower "$tls_cipher_suite")"
tls_cipher_suite="${tls_cipher_suite:0:2}\\x${tls_cipher_suite:2:2}" tls_cipher_suite="${tls_cipher_suite:0:2}\\x${tls_cipher_suite:2:2}"
cipherlist_len=${#cipherlist} cipherlist_len=${#cipherlist}
for (( i=0; i < cipherlist_len; i=i+8 )); do for (( i=0; i < cipherlist_len; i+=8 )); do
# At the right hand side we need the quotes here! # At the right hand side we need the quotes here!
[[ "${cipherlist:i:6}" == "$tls_cipher_suite" ]] && break [[ "${cipherlist:i:6}" == "$tls_cipher_suite" ]] && break
done done
@ -13351,14 +13336,14 @@ parse_tls_serverhello() {
# get position of extensions # get position of extensions
extns_offset=$offset+6+2*$(hex2dec "${TLS_CLIENT_HELLO:offset:2}") extns_offset=$offset+6+2*$(hex2dec "${TLS_CLIENT_HELLO:offset:2}")
len1=${#TLS_CLIENT_HELLO} len1=${#TLS_CLIENT_HELLO}
for (( i=extns_offset; i < len1; i=i+8+extension_len )); do for (( i=extns_offset; i < len1; i+=8+extension_len )); do
extension_type="${TLS_CLIENT_HELLO:i:4}" extension_type="${TLS_CLIENT_HELLO:i:4}"
offset=4+$i offset=4+$i
extension_len=2*$(hex2dec "${TLS_CLIENT_HELLO:offset:4}") extension_len=2*$(hex2dec "${TLS_CLIENT_HELLO:offset:4}")
if [[ "$extension_type" == 002b ]]; then if [[ "$extension_type" == 002b ]]; then
offset+=6 offset+=6
tls_protocol2="$(tolower "$tls_protocol2")" tls_protocol2="$(tolower "$tls_protocol2")"
for (( j=0; j < extension_len-2; j=j+4 )); do for (( j=0; j < extension_len-2; j+=4 )); do
[[ "${TLS_CLIENT_HELLO:offset:4}" == $tls_protocol2 ]] && break [[ "${TLS_CLIENT_HELLO:offset:4}" == $tls_protocol2 ]] && break
offset+=4 offset+=4
done done
@ -13421,7 +13406,7 @@ parse_tls_serverhello() {
# Place any additional certificates in $TEMPDIR/intermediatecerts.pem # Place any additional certificates in $TEMPDIR/intermediatecerts.pem
CERTIFICATE_LIST_ORDERING_PROBLEM=false CERTIFICATE_LIST_ORDERING_PROBLEM=false
CAissuerDN="$issuerDN" CAissuerDN="$issuerDN"
for (( i=12+certificate_len; i<tls_certificate_ascii_len; i=i+certificate_len )); do for (( i=12+certificate_len; i<tls_certificate_ascii_len; i+=certificate_len )); do
if [[ $tls_certificate_ascii_len-$i -lt 6 ]]; then if [[ $tls_certificate_ascii_len-$i -lt 6 ]]; then
debugme echo "Malformed Certificate Handshake message in ServerHello." debugme echo "Malformed Certificate Handshake message in ServerHello."
tmpfile_handle ${FUNCNAME[0]}.txt tmpfile_handle ${FUNCNAME[0]}.txt
@ -13587,7 +13572,7 @@ parse_tls_serverhello() {
fi fi
# Subtract any leading 0 bytes # Subtract any leading 0 bytes
for (( i=4; i < offset; i=i+2 )); do for (( i=4; i < offset; i+=2 )); do
[[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break [[ "${tls_serverkeyexchange_ascii:i:2}" != "00" ]] && break
dh_p_len=$dh_p_len-2 dh_p_len=$dh_p_len-2
done done
@ -13801,7 +13786,7 @@ generate_key_share_extension() {
len=2*$(hex2dec "${supported_groups:8:4}") len=2*$(hex2dec "${supported_groups:8:4}")
[[ $len+12 -ne $supported_groups_len ]] && return 1 [[ $len+12 -ne $supported_groups_len ]] && return 1
for (( i=12; i<supported_groups_len; i=i+4 )); do for (( i=12; i<supported_groups_len; i+=4 )); do
group=$(hex2dec "${supported_groups:i:4}") group=$(hex2dec "${supported_groups:i:4}")
# If the Supported groups extensions lists more than one group, # If the Supported groups extensions lists more than one group,
# then don't include the larger key shares in the extension. # then don't include the larger key shares in the extension.
@ -13905,7 +13890,7 @@ prepare_tls_clienthello() {
# Check to see if any ECC cipher suites are included in cipher_suites # Check to see if any ECC cipher suites are included in cipher_suites
# (not needed for TLSv1.3) # (not needed for TLSv1.3)
if [[ "0x$tls_low_byte" -le "0x03" ]]; then if [[ "0x$tls_low_byte" -le "0x03" ]]; then
for (( i=0; i<len_ciph_suites_byte; i=i+8 )); do for (( i=0; i<len_ciph_suites_byte; i+=8 )); do
j=$i+4 j=$i+4
part1="0x${cipher_suites:$i:2}" part1="0x${cipher_suites:$i:2}"
part2="0x${cipher_suites:$j:2}" part2="0x${cipher_suites:$j:2}"
@ -14051,7 +14036,7 @@ prepare_tls_clienthello() {
extra_extensions="$(tolower "$4")" extra_extensions="$(tolower "$4")"
code2network "$extra_extensions" code2network "$extra_extensions"
len_all=${#NW_STR} len_all=${#NW_STR}
for (( i=0; i < len_all; i=i+16+4*0x$len_extension_hex )); do for (( i=0; i < len_all; i+=16+4*0x$len_extension_hex )); do
part2=$i+4 part2=$i+4
extn_type="${NW_STR:i:2}${NW_STR:part2:2}" extn_type="${NW_STR:i:2}${NW_STR:part2:2}"
extra_extensions_list+=" $extn_type " extra_extensions_list+=" $extn_type "
@ -14374,7 +14359,7 @@ resend_if_hello_retry_request() {
fi fi
# Parse HelloRetryRequest extensions # Parse HelloRetryRequest extensions
for (( i=extns_offset+4; i < tls_hello_ascii_len; i=i+8+len_extn )); do for (( i=extns_offset+4; i < tls_hello_ascii_len; i+=8+len_extn )); do
extn_type="${tls_hello_ascii:i:4}" extn_type="${tls_hello_ascii:i:4}"
j=$i+4 j=$i+4
len_extn=2*$(hex2dec "${tls_hello_ascii:j:4}") len_extn=2*$(hex2dec "${tls_hello_ascii:j:4}")
@ -14463,7 +14448,7 @@ resend_if_hello_retry_request() {
second_clienthello="$(modify_clienthello "$original_clienthello" "$new_key_share" "$cookie")" second_clienthello="$(modify_clienthello "$original_clienthello" "$new_key_share" "$cookie")"
TLS_CLIENT_HELLO="${second_clienthello:10}" TLS_CLIENT_HELLO="${second_clienthello:10}"
msg_len=${#second_clienthello} msg_len=${#second_clienthello}
for (( i=0; i < msg_len; i=i+2 )); do for (( i=0; i < msg_len; i+=2 )); do
data+=", ${second_clienthello:i:2}" data+=", ${second_clienthello:i:2}"
done done
debugme echo -n "sending client hello... " debugme echo -n "sending client hello... "
@ -14661,7 +14646,7 @@ tls_sockets() {
finished_msg="$aad$finished_msg" finished_msg="$aad$finished_msg"
len=${#finished_msg} len=${#finished_msg}
for (( i=0; i < len; i=i+2 )); do for (( i=0; i < len; i+=2 )); do
data+=", ${finished_msg:i:2}" data+=", ${finished_msg:i:2}"
done done
debugme echo -e "\nsending finished..." debugme echo -e "\nsending finished..."
@ -14741,7 +14726,7 @@ send_app_data() {
res="$aad$res" res="$aad$res"
len=${#res} len=${#res}
data="" data=""
for (( i=0; i < len; i=i+2 )); do for (( i=0; i < len; i+=2 )); do
data+=",x${res:i:2}" data+=",x${res:i:2}"
done done
socksend "$data" $USLEEP_SND socksend "$data" $USLEEP_SND
@ -16172,7 +16157,7 @@ run_freak() {
exportrsa_ssl2_cipher_list_hex="$(strip_spaces "${exportrsa_ssl2_cipher_list_hex//,/}")" exportrsa_ssl2_cipher_list_hex="$(strip_spaces "${exportrsa_ssl2_cipher_list_hex//,/}")"
len=${#exportrsa_ssl2_cipher_list_hex} len=${#exportrsa_ssl2_cipher_list_hex}
detected_ssl2_ciphers="$(grep "Supported cipher: " "$TEMPDIR/$NODEIP.parse_sslv2_serverhello.txt")" detected_ssl2_ciphers="$(grep "Supported cipher: " "$TEMPDIR/$NODEIP.parse_sslv2_serverhello.txt")"
for (( i=0; i<len; i=i+6 )); do for (( i=0; i<len; i+=6 )); do
[[ "$detected_ssl2_ciphers" =~ x${exportrsa_ssl2_cipher_list_hex:i:6} ]] && sclient_success=0 && break [[ "$detected_ssl2_ciphers" =~ x${exportrsa_ssl2_cipher_list_hex:i:6} ]] && sclient_success=0 && break
done done
fi fi
@ -17335,7 +17320,7 @@ run_grease() {
fi fi
extn_len_hex=$(printf "%04x" $extn_len) extn_len_hex=$(printf "%04x" $extn_len)
extn+=",${extn_len_hex:0:2},${extn_len_hex:2:2}" extn+=",${extn_len_hex:0:2},${extn_len_hex:2:2}"
for (( j=0; j <= extn_len-2; j=j+2 )); do for (( j=0; j <= extn_len-2; j+=2 )); do
rnd_bytes="$(printf "%04x" $RANDOM)" rnd_bytes="$(printf "%04x" $RANDOM)"
extn+=",${rnd_bytes:0:2},${rnd_bytes:2:2}" extn+=",${rnd_bytes:0:2},${rnd_bytes:2:2}"
done done
@ -17683,7 +17668,7 @@ run_robot() {
pubkeybytes=$pubkeybits/8 pubkeybytes=$pubkeybits/8
[[ $((pubkeybits%8)) -ne 0 ]] && pubkeybytes+=1 [[ $((pubkeybits%8)) -ne 0 ]] && pubkeybytes+=1
rnd_pad="" rnd_pad=""
for (( len=0; len < pubkeybytes-52; len=len+2 )); do for (( len=0; len < pubkeybytes-52; len+=2 )); do
rnd_pad+="abcd" rnd_pad+="abcd"
done done
[[ $len -eq $pubkeybytes-52 ]] && rnd_pad+="ab" [[ $len -eq $pubkeybytes-52 ]] && rnd_pad+="ab"
@ -17723,7 +17708,7 @@ run_robot() {
encrypted_pms="$cke_prefix$encrypted_pms" encrypted_pms="$cke_prefix$encrypted_pms"
len=${#encrypted_pms} len=${#encrypted_pms}
client_key_exchange="" client_key_exchange=""
for (( i=0; i<len; i=i+2 )); do for (( i=0; i<len; i+=2 )); do
client_key_exchange+=", x${encrypted_pms:i:2}" client_key_exchange+=", x${encrypted_pms:i:2}"
done done