mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-01 06:19:44 +01:00
Fix Darwin / LibreSSL startup problem
This PR addresses a bug where a user encountered the question "The results might look ok but they could be nonsense. Really proceed". That happened under Darwin and probably some LibreSSL versions when checking some hosts. sclient_auth() returned 1 indicating no SSL/TLS handshake could be established. This PR modifies sclient_auth() so that in those cases 0 is returned by skipping the check for the session ID. As NO_SSL_SESSIONID needs to be set when there's no session ID, this is done separately.
This commit is contained in:
parent
a64094a804
commit
8b4ebc385a
28
testssl.sh
28
testssl.sh
@ -20898,8 +20898,10 @@ extract_calist() {
|
||||
return 0
|
||||
}
|
||||
|
||||
# this is only being called from determine_optimal_proto in order to check whether we have a server
|
||||
# with client authentication, a server with no SSL session ID switched off
|
||||
# This is only being called from determine_optimal_proto() in order to check whether we have a server with
|
||||
# client authentication, a server with no SSL session ID switched off -- and as the name indicates a protocol.
|
||||
# ARG1 is the return value von openssl s_client connect. (Darwin or LibreSSL may return 1 here)
|
||||
# ARG2 is the file name from server hello
|
||||
#
|
||||
sclient_auth() {
|
||||
local server_hello="$(cat -v "$2")"
|
||||
@ -20908,12 +20910,17 @@ sclient_auth() {
|
||||
local connect_success=false
|
||||
|
||||
[[ $1 -eq 0 ]] && connect_success=true
|
||||
|
||||
! "$connect_success" && [[ "$server_hello" =~ $re ]] && \
|
||||
[[ -n "${BASH_REMATCH[1]}" ]] && connect_success=true
|
||||
! "$connect_success" && \
|
||||
[[ "$server_hello" =~ (New|Reused)\,\ (SSLv[23]|TLSv1(\.[0-3])?(\/SSLv3)?)\,\ Cipher\ is\ ([A-Z0-9]+-[A-Za-z0-9\-]+|TLS_[A-Za-z0-9_]+) ]] && \
|
||||
connect_success=true
|
||||
|
||||
if "$connect_success"; then
|
||||
[[ ! "$server_hello" =~ Session-ID:\ [a-fA-F0-9]{2,64} ]] && NO_SSL_SESSIONID=true
|
||||
# we needed to set this for later
|
||||
|
||||
if [[ "$server_hello" =~ \<\<\<\ (SSL\ [23]|TLS\ 1)(\.[0-3])?[\,]?\ Handshake\ \[length\ [0-9a-fA-F]*\]\,\ CertificateRequest ]]; then
|
||||
# CertificateRequest message in -msg
|
||||
CLIENT_AUTH="required"
|
||||
@ -20922,17 +20929,14 @@ sclient_auth() {
|
||||
return 0
|
||||
fi
|
||||
[[ $1 -eq 0 ]] && return 0
|
||||
if [[ ! "$server_hello" =~ Session-ID:\ [a-fA-F0-9]{2,64} ]]; then # probably no SSL session
|
||||
# do another sanity check to be sure
|
||||
if [[ "$server_hello" =~ \-\-\-BEGIN\ CERTIFICATE\-\-\-.*\-\-\-END\ CERTIFICATE\-\-\- ]]; then
|
||||
CLIENT_AUTH="none"
|
||||
NO_SSL_SESSIONID=true # NO_SSL_SESSIONID is preset globally to false for all other cases
|
||||
return 0
|
||||
fi
|
||||
if [[ "$server_hello" =~ \-\-\-BEGIN\ CERTIFICATE\-\-\-.*\-\-\-END\ CERTIFICATE\-\-\- ]]; then
|
||||
# This should be already set but just to be sure
|
||||
CLIENT_AUTH="none"
|
||||
return 0
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
fi
|
||||
# what's left now is: no protocol and ciphersuite specified, handshake returned not successful, session ID empty --> not successful
|
||||
return 1
|
||||
}
|
||||
|
||||
# Determine the best parameters to use with tls_sockets():
|
||||
@ -21144,7 +21148,7 @@ determine_optimal_proto() {
|
||||
$OPENSSL s_client $(s_client_options "$proto $BUGS -connect "$NODEIP:$PORT" -msg $PROXY $SNI") </dev/null >$TMPFILE 2>>$ERRFILE
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
if sclient_auth $? $TMPFILE; then
|
||||
# we use the successful handshake at least to get one valid protocol supported -- it saves us time later
|
||||
if [[ -z "$proto" ]]; then
|
||||
|
Loading…
Reference in New Issue
Block a user