mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-22 08:29:31 +01:00
New socksend(), json flat: scan time
There's a new socksend() function which gives up to 8% performance benefit (LAN) as is saves 3 sed and 1 tr command in every socksend call. It has not been put in production yet as it shows a problem in ticketbleed check and it is late and I call it a day ;-) and resolve that later (see #902). For performance tests it's quite handy to also have in the flat json format a footer with time consumed for each run. fileout_json_footer() was patched accordingly.
This commit is contained in:
parent
9949be750d
commit
cce48a34d0
30
testssl.sh
30
testssl.sh
@ -639,14 +639,13 @@ strip_quote() {
|
|||||||
|
|
||||||
#################### JSON FILE FORMATING ####################
|
#################### JSON FILE FORMATING ####################
|
||||||
|
|
||||||
fileout_pretty_json_footer() {
|
|
||||||
echo -e " ],
|
|
||||||
\"scanTime\" : \"$SCAN_TIME\"\n}"
|
|
||||||
}
|
|
||||||
|
|
||||||
fileout_json_footer() {
|
fileout_json_footer() {
|
||||||
"$do_json" && printf "]\n" >> "$JSONFILE"
|
if "$do_json"; then
|
||||||
"$do_pretty_json" && (printf "$(fileout_pretty_json_footer)") >> "$JSONFILE"
|
fileout_json_finding "scanTime" "INFO" "$SCAN_TIME" "" "" ""
|
||||||
|
printf "]\n" >> "$JSONFILE"
|
||||||
|
fi
|
||||||
|
"$do_pretty_json" && echo -e " ],
|
||||||
|
\"scanTime\" : \"$SCAN_TIME\"\n}" >> "$JSONFILE"
|
||||||
}
|
}
|
||||||
|
|
||||||
fileout_json_section() {
|
fileout_json_section() {
|
||||||
@ -695,6 +694,7 @@ fileout_json_print_parameter() {
|
|||||||
|
|
||||||
fileout_json_finding() {
|
fileout_json_finding() {
|
||||||
local target
|
local target
|
||||||
|
local finding="$3" # FIXME: dealing with locals and globals in fileout()
|
||||||
|
|
||||||
if "$do_json"; then
|
if "$do_json"; then
|
||||||
"$FIRST_FINDING" || echo -n "," >> "$JSONFILE"
|
"$FIRST_FINDING" || echo -n "," >> "$JSONFILE"
|
||||||
@ -2598,6 +2598,8 @@ std_cipherlists() {
|
|||||||
# ARG1: hexbyte with a leading comma (!!), separated by commas
|
# ARG1: hexbyte with a leading comma (!!), separated by commas
|
||||||
# ARG2: sleep
|
# ARG2: sleep
|
||||||
socksend() {
|
socksend() {
|
||||||
|
local data
|
||||||
|
|
||||||
# the following works under BSD and Linux, which is quite tricky. So don't mess with it unless you're really sure what you do
|
# the following works under BSD and Linux, which is quite tricky. So don't mess with it unless you're really sure what you do
|
||||||
if "$HAS_SED_E"; then
|
if "$HAS_SED_E"; then
|
||||||
data=$(sed -e 's/# .*$//g' -e 's/ //g' <<< "$1" | sed -E 's/^[[:space:]]+//; s/[[:space:]]+$//; /^$/d' | sed 's/,/\\/g' | tr -d '\n')
|
data=$(sed -e 's/# .*$//g' -e 's/ //g' <<< "$1" | sed -E 's/^[[:space:]]+//; s/[[:space:]]+$//; /^$/d' | sed 's/,/\\/g' | tr -d '\n')
|
||||||
@ -2609,6 +2611,20 @@ socksend() {
|
|||||||
sleep $2
|
sleep $2
|
||||||
}
|
}
|
||||||
|
|
||||||
|
socksend2() {
|
||||||
|
local data line
|
||||||
|
|
||||||
|
# read line per line and strip comments (bash internal func can't handle multiline statements
|
||||||
|
data="$(while read line; do
|
||||||
|
printf "${line%\#*}"
|
||||||
|
done <<< "$1" )"
|
||||||
|
data="${data// /}" # strip ' '
|
||||||
|
data="${data//,/\\}" # s&r , by \
|
||||||
|
[[ $DEBUG -ge 4 ]] && echo && echo "\"$data\""
|
||||||
|
printf -- "$data" >&5 2>/dev/null &
|
||||||
|
sleep $2
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
openssl2rfc() {
|
openssl2rfc() {
|
||||||
local rfcname=""
|
local rfcname=""
|
||||||
|
Loading…
Reference in New Issue
Block a user