mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-07 17:20:57 +01:00
Better parsing of HPKP
Previously testssl.sh ran into problems when both Public-Key-Pins and Public-Key-Pins-Report-Only were present in the header. Now if both are present only Public-Key-Pins is evalutated and a hint is given. If Public-Key-Pins-Report-Only is only present a hint is given and those are evaluated. If more than 1 from either Public-Key-Pins-Report-Only or Public-Key-Pins is detected only the first one will be processed and a warning will be displayed.
This commit is contained in:
parent
1011ef1399
commit
9618ed993d
44
testssl.sh
44
testssl.sh
@ -1828,7 +1828,6 @@ run_hpkp() {
|
|||||||
local spaces_indented=" "
|
local spaces_indented=" "
|
||||||
local certificate_found=false
|
local certificate_found=false
|
||||||
local i
|
local i
|
||||||
local hpkp_headers
|
|
||||||
local first_hpkp_header
|
local first_hpkp_header
|
||||||
local spki
|
local spki
|
||||||
local ca_hashes="$TESTSSL_INSTALL_DIR/etc/ca_hashes.txt"
|
local ca_hashes="$TESTSSL_INSTALL_DIR/etc/ca_hashes.txt"
|
||||||
@ -1837,29 +1836,36 @@ run_hpkp() {
|
|||||||
run_http_header "$1" || return 1
|
run_http_header "$1" || return 1
|
||||||
fi
|
fi
|
||||||
pr_bold " Public Key Pinning "
|
pr_bold " Public Key Pinning "
|
||||||
egrep -aiw '^Public-Key-Pins|Public-Key-Pins-Report-Only' $HEADERFILE >$TMPFILE
|
grep -aiw '^Public-Key-Pins' $HEADERFILE >$TMPFILE # TMPFILE includes report-only
|
||||||
if [[ $? -eq 0 ]]; then
|
if [[ $? -eq 0 ]]; then
|
||||||
if egrep -aciw '^Public-Key-Pins|Public-Key-Pins-Report-Only' $HEADERFILE | egrep -waq "1" ; then
|
if [[ $(grep -aciw '^Public-Key-Pins:' $TMPFILE) -gt 1 ]]; then
|
||||||
:
|
pr_svrty_medium "Misconfiguration, multiple Public-Key-Pins headers"
|
||||||
|
outln ", taking first line"
|
||||||
|
fileout "HPKP_error" "MEDIUM" "multiple Public-Key-Pins in header"
|
||||||
|
first_hpkp_header="$(grep -aiw '^Public-Key-Pins:' $TMPFILE | head -1)"
|
||||||
|
# we only evaluate the keys here, unless they a not present
|
||||||
|
out "$spaces "
|
||||||
|
elif [[ $(grep -aciw '^Public-Key-Pins-Report-Only:' $TMPFILE) -gt 1 ]]; then
|
||||||
|
outln "Multiple HPKP headers (Report-Only), taking first line"
|
||||||
|
fileout "HPKP_notice" "INFO" "multiple Public-Key-Pins-Report-Only in header"
|
||||||
|
first_hpkp_header="$(grep -aiw '^Public-Key-Pins-Report-Only:' $TMPFILE | head -1)"
|
||||||
|
out "$spaces "
|
||||||
|
elif [[ $(egrep -aciw '^Public-Key-Pins:|^Public-Key-Pins-Report-Only:' $TMPFILE) -eq 2 ]]; then
|
||||||
|
outln "Public-Key-Pins + Public-Key-Pins-Report-Only detected. Continue with first one"
|
||||||
|
first_hpkp_header="$(grep -aiw '^Public-Key-Pins:' $TMPFILE)"
|
||||||
|
out "$spaces "
|
||||||
|
elif [[ $(grep -aciw '^Public-Key-Pins:' $TMPFILE) -eq 1 ]]; then
|
||||||
|
first_hpkp_header="$(grep -aiw '^Public-Key-Pins:' $TMPFILE)"
|
||||||
else
|
else
|
||||||
hpkp_headers=""
|
outln "Public-Key-Pins-Only detected"
|
||||||
pr_svrty_medium "misconfiguration, multiple HPKP headers: "
|
first_hpkp_header="$(grep -aiw '^Public-Key-Pins-Report-Only:' $TMPFILE)"
|
||||||
# https://scotthelme.co.uk is a candidate
|
out "$spaces "
|
||||||
#FIXME: should display both Public-Key-Pins+Public-Key-Pins-Report-Only --> egrep -ai -w
|
fileout "HPKP_SPKIs" "INFO" "Only Public-Key-Pins-Report-Only"
|
||||||
for i in $(newline_to_spaces "$(egrep -ai '^Public-Key-Pins' $HEADERFILE | awk -F':' '/Public-Key-Pins/ { print $1 }')"); do
|
|
||||||
pr_italic $i
|
|
||||||
hpkp_headers="$hpkp_headers$i "
|
|
||||||
out " "
|
|
||||||
done
|
|
||||||
out "\n$spaces Examining first: "
|
|
||||||
first_hpkp_header=$(awk -F':' '/Public-Key-Pins/ { print $1 }' $HEADERFILE | head -1)
|
|
||||||
pr_italic "$first_hpkp_header, "
|
|
||||||
fileout "HPKP_multiple" "WARN" "Multiple HPKP headers $hpkp_headers. Using first header \'$first_hpkp_header\'"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# remove leading Public-Key-Pins* and convert it to mulitline arg
|
# remove leading Public-Key-Pins* and convert it to mulitline arg
|
||||||
sed -e 's/Public-Key-Pins://g' -e s'/Public-Key-Pins-Report-Only://' $TMPFILE | tr ';' '\n' | sed -e 's/\"//g' -e 's/^ //' >$TMPFILE.2
|
sed -e 's/Public-Key-Pins://g' -e s'/Public-Key-Pins-Report-Only://' <<< "$first_hpkp_header" | \
|
||||||
mv $TMPFILE.2 $TMPFILE
|
tr ';' '\n' | sed -e 's/\"//g' -e 's/^ //' >$TMPFILE
|
||||||
|
|
||||||
hpkp_nr_keys=$(grep -ac pin-sha $TMPFILE)
|
hpkp_nr_keys=$(grep -ac pin-sha $TMPFILE)
|
||||||
if [[ $hpkp_nr_keys -eq 1 ]]; then
|
if [[ $hpkp_nr_keys -eq 1 ]]; then
|
||||||
|
Loading…
Reference in New Issue
Block a user