mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-22 08:29:31 +01:00
Re-add RFC 7919 primes into run_logjam()
.. after some discussion. As TLS 1.3 is not tested here any RFC 7919 primes using this protocol will not show up (they in in run_pfs() though). To avoid misunderstandings " DH key detected with <= TLS 1.2" is now being printed.
This commit is contained in:
parent
4e2bd0ef2f
commit
7d40041652
18
testssl.sh
18
testssl.sh
@ -8886,7 +8886,7 @@ run_pfs() {
|
|||||||
if [[ -z "$curves_offered" ]] && [[ -n "$curve_found" ]]; then
|
if [[ -z "$curves_offered" ]] && [[ -n "$curve_found" ]]; then
|
||||||
# The server is not using one of the groups from RFC 7919.
|
# The server is not using one of the groups from RFC 7919.
|
||||||
if [[ -z "$DH_GROUP_OFFERED" ]]; then
|
if [[ -z "$DH_GROUP_OFFERED" ]]; then
|
||||||
# this global will get athe name of the group eithe here or in run_logjam()
|
# this global will get the name of the group eithe here or in run_logjam()
|
||||||
key_bitstring="$(awk '/-----BEGIN PUBLIC KEY/,/-----END PUBLIC KEY/ { print $0 }' $TEMPDIR/$NODEIP.parse_tls_serverhello.txt)"
|
key_bitstring="$(awk '/-----BEGIN PUBLIC KEY/,/-----END PUBLIC KEY/ { print $0 }' $TEMPDIR/$NODEIP.parse_tls_serverhello.txt)"
|
||||||
get_common_prime "$jsonID" "$key_bitstring" ""
|
get_common_prime "$jsonID" "$key_bitstring" ""
|
||||||
[[ $? -eq 0 ]] && curves_offered="$DH_GROUP_OFFERED" && len_dh_p=$DH_GROUP_LEN_P
|
[[ $? -eq 0 ]] && curves_offered="$DH_GROUP_OFFERED" && len_dh_p=$DH_GROUP_LEN_P
|
||||||
@ -13974,9 +13974,11 @@ out_common_prime() {
|
|||||||
local cve="$2"
|
local cve="$2"
|
||||||
local cwe="$3"
|
local cwe="$3"
|
||||||
|
|
||||||
if [[ "$DH_GROUP_OFFERED" =~ ffdhe ]]; then
|
[[ "$DH_GROUP_OFFERED" == ffdhe* ]] && [[ ! "$DH_GROUP_OFFERED" =~ \ ]] && DH_GROUP_OFFERED="RFC7919/$DH_GROUP_OFFERED"
|
||||||
:
|
if [[ "$DH_GROUP_OFFERED" =~ ffdhe ]] && [[ "$DH_GROUP_OFFERED" =~ \ ]]; then
|
||||||
# now size matters -- i.e. the bit size. As this is about a known prime we label it more strict.
|
out "common primes detected: "; pr_italic "$DH_GROUP_OFFERED"
|
||||||
|
fileout "$jsonID2" "INFO" "$DH_GROUP_OFFERED" "$cve" "$cwe"
|
||||||
|
# Now (below) size matters -- i.e. the bit size. As this is about a known prime we label it more strict.
|
||||||
# This needs maybe needs a another thought as it could appear inconsitent with run_pfs and elsewhere.
|
# This needs maybe needs a another thought as it could appear inconsitent with run_pfs and elsewhere.
|
||||||
# for now we label the bit size similar in the screen, but distiguish the leading text for logjam before
|
# for now we label the bit size similar in the screen, but distiguish the leading text for logjam before
|
||||||
elif [[ $DH_GROUP_LEN_P -le 800 ]]; then
|
elif [[ $DH_GROUP_LEN_P -le 800 ]]; then
|
||||||
@ -14129,8 +14131,8 @@ run_logjam() {
|
|||||||
pr_svrty_high "VULNERABLE (NOT ok):"; out " uses DH EXPORT ciphers"
|
pr_svrty_high "VULNERABLE (NOT ok):"; out " uses DH EXPORT ciphers"
|
||||||
fileout "$jsonID" "HIGH" "VULNERABLE, uses DH EXPORT ciphers" "$cve" "$cwe" "$hint"
|
fileout "$jsonID" "HIGH" "VULNERABLE, uses DH EXPORT ciphers" "$cve" "$cwe" "$hint"
|
||||||
if [[ $subret -eq 3 ]]; then
|
if [[ $subret -eq 3 ]]; then
|
||||||
out ", no DH key detected"
|
out ", no DH key detected with <= TLS 1.2"
|
||||||
fileout "$jsonID2" "OK" "no DH key detected"
|
fileout "$jsonID2" "OK" "no DH key detected with <= TLS 1.2"
|
||||||
elif [[ $subret -eq 1 ]]; then
|
elif [[ $subret -eq 1 ]]; then
|
||||||
out "\n${spaces}"
|
out "\n${spaces}"
|
||||||
out_common_prime "$jsonID2" "$cve" "$cwe"
|
out_common_prime "$jsonID2" "$cve" "$cwe"
|
||||||
@ -14151,8 +14153,8 @@ run_logjam() {
|
|||||||
elif [[ $subret -eq 3 ]]; then
|
elif [[ $subret -eq 3 ]]; then
|
||||||
pr_svrty_good "not vulnerable (OK):"; out " no DH EXPORT ciphers${addtl_warning}"
|
pr_svrty_good "not vulnerable (OK):"; out " no DH EXPORT ciphers${addtl_warning}"
|
||||||
fileout "$jsonID" "OK" "not vulnerable, no DH EXPORT ciphers,$addtl_warning" "$cve" "$cwe"
|
fileout "$jsonID" "OK" "not vulnerable, no DH EXPORT ciphers,$addtl_warning" "$cve" "$cwe"
|
||||||
out ", no DH key detected"
|
out ", no DH key detected with <= TLS 1.2"
|
||||||
fileout "$jsonID2" "OK" "no DH key" "$cve" "$cwe"
|
fileout "$jsonID2" "OK" "no DH key13977 with <= TLS 1.2" "$cve" "$cwe"
|
||||||
elif [[ $subret -eq 0 ]]; then
|
elif [[ $subret -eq 0 ]]; then
|
||||||
pr_svrty_good "not vulnerable (OK):"; out " no DH EXPORT ciphers${addtl_warning}"
|
pr_svrty_good "not vulnerable (OK):"; out " no DH EXPORT ciphers${addtl_warning}"
|
||||||
fileout "$jsonID" "OK" "not vulnerable, no DH EXPORT ciphers,$addtl_warning" "$cve" "$cwe"
|
fileout "$jsonID" "OK" "not vulnerable, no DH EXPORT ciphers,$addtl_warning" "$cve" "$cwe"
|
||||||
|
Loading…
Reference in New Issue
Block a user