Fix problem when nmap file has .txt extension (3.0)

This addresses a bug filed in #1935 in 3.1dev when the supplied file
has a .txt extension. In this scenario the input file was nulled
as from the input file in nmap format an internal input file was
generated which has a .txt extension, in the same directory.
The idea was to persist the file for the user.

Now, this internal input file is ephemeral and only written to $TEMPDIR.
This commit is contained in:
Dirk 2021-07-25 16:40:16 +02:00
parent ca558a9c08
commit 3544014fe3

View File

@ -19003,17 +19003,12 @@ nmap_to_plain_file() {
else else
fatal "Nmap file $FNAME is not in grep(p)able format (-oG filename.g(n)map)" $ERR_FNAMEPARSE fatal "Nmap file $FNAME is not in grep(p)able format (-oG filename.g(n)map)" $ERR_FNAMEPARSE
fi fi
# strip extension and create output file *.txt in same folder # create ${FNAME%.*}.txt in $TEMPDIR
target_fname="${FNAME%.*}.txt" target_fname="${FNAME%.*}.txt"
> "${target_fname}" target_fname="${target_fname##*\/}" # strip path (Unix)
if [[ $? -ne 0 ]]; then target_fname="${target_fname##*\\}" # strip path (Dos)
# try to just create ${FNAME%.*}.txt in the same dir as the gnmap file failed. target_fname="$TEMPDIR/$target_fname"
# backup is using one in $TEMPDIR > "${target_fname}" || fatal "Cannot create \"${target_fname}\"" $ERR_FCREATE
target_fname="${target_fname##*\/}" # strip path (Unix)
target_fname="${target_fname##*\\}" # strip path (Dos)
target_fname="$TEMPDIR/$target_fname"
> "${target_fname}" || fatal "Cannot create \"${target_fname}\"" $ERR_FCREATE
fi
# Line x: "Host: AAA.BBB.CCC.DDD (<FQDN>) Status: Up" # Line x: "Host: AAA.BBB.CCC.DDD (<FQDN>) Status: Up"
# Line x+1: "Host: AAA.BBB.CCC.DDD (<FQDN>) Ports: 443/open/tcp//https///" # Line x+1: "Host: AAA.BBB.CCC.DDD (<FQDN>) Ports: 443/open/tcp//https///"