Skip to content

Commit

Permalink
Introduce new_faster_hash() and remove most use of cat
Browse files Browse the repository at this point in the history
The old Master-hash will cat the file-list in one instance of cat
and then pipe the output to SSL for single hash. This requires one
subshell.

The new Master-hash opens the entire file-list one instance of SSL
and hashes each file to a hash-list.  This hash-list hashed by piping
it to a second SSL.  This requires one subsell.

Open hash-files with read instead of cat. Requires one less subshell.

Re-instate master_verify_hash_block=1 to block excess use.

Signed-off-by: Richard T Bonhomme <tincantech@protonmail.com>
  • Loading branch information
TinCanTech committed Feb 24, 2022
1 parent 371b8ce commit 747094d
Showing 1 changed file with 109 additions and 55 deletions.
164 changes: 109 additions & 55 deletions easytls
Original file line number Diff line number Diff line change
Expand Up @@ -1732,6 +1732,13 @@ save_file_hash ()
unset -v hash_file valid_hash valid_target
} # => save_file_hash ()

# Read hash from file (without cat) and clear EOF error
read_hash_file ()
{
[ -f "${1}" ] || return 1
read -r <"${1}" saved_file_hash || :
} # => read_hash_file ()

# generate_and_match_valid_hash
generate_and_match_valid_hash ()
{
Expand All @@ -1743,6 +1750,7 @@ generate_and_match_valid_hash ()
target_file="${1}" # File to be hashed
hash_file="${2}" # File to read the hash from

# Input error
[ "${target_file}" = "${hash_file}" ] && {
error_msg "invalid files - generate_and_match_valid_hash"
unset -v target_file hash_file generated_valid_hash saved_file_hash
Expand All @@ -1756,8 +1764,12 @@ generate_and_match_valid_hash ()
return 1
}

# Load saved hash - If this fails then match_two_hashes will fail
read -r < "${hash_file}" saved_file_hash
# Read hash from file
read_hash_file "${hash_file}" || {
error_msg "generate_and_match_valid_hash - read_hash_file"
unset -v target_file hash_file generated_valid_hash saved_file_hash
return 1
}

# Validate and match $generated_valid_hash
match_two_hashes "${generated_valid_hash}" "${saved_file_hash}" || {
Expand Down Expand Up @@ -1894,10 +1906,32 @@ easytls_ssl_generate_empty_hash ()
unset -v unlock_ssl
return 1
}
empty_hash="${ssl_out}"
empty_hash="${ssl_out% *}"
unset -v unlock_ssl ssl_out
} # => easytls_ssl_generate_empty_hash ()

# Hash all files from master file-list
ssl_generate_new_master_files_hash ()
{
[ -n "${master_hash_only}" ] || return 1

[ -n "${request_fixed_hash}" ] && \
"${EASYTLS_PRINTF}" '%s\n' "${fixed_hash}" && return 0

"${EASYRSA_OPENSSL}" dgst -"${EASYTLS_HASH_ALGO}" -r "$@" || return 1
} # => openssl_generate_data_hash ()

# SSL data in via pipe hash output
ssl_generate_old_master_data_hash ()
{
[ -n "${master_hash_only}" ] || return 1

[ -n "${request_fixed_hash}" ] && \
"${EASYTLS_PRINTF}" '%s\n' "${fixed_hash}" && return 0

"${EASYRSA_OPENSSL}" dgst -"${EASYTLS_HASH_ALGO}" -r || return 1
} # => openssl_generate_data_hash ()

# SSL file via command hash output
ssl_generate_file_hash ()
{
Expand All @@ -1921,28 +1955,14 @@ easytls_ssl_generate_file_hash ()
unset -v unlock_ssl ssl_out
} # => easytls_ssl_encode_base64_data ()


# TEMPORARY FUNCTION for generate_master_hash()
# SSL data in via pipe hash output
openssl_generate_data_hash ()
{
#[ -n "${unlock_ssl}" ] || return 1
[ -n "${request_fixed_hash}" ] && \
"${EASYTLS_PRINTF}" '%s\n' "${fixed_hash}" && return 0

"${EASYRSA_OPENSSL}" dgst -"${EASYTLS_HASH_ALGO}" -r || return 1
} # => openssl_generate_data_hash ()
# TEMPORARY FUNCTION for generate_master_hash()


# SSL data in via pipe hash output
ssl_generate_data_hash ()
{
[ -n "${unlock_ssl}" ] || return 1
[ -n "${request_fixed_hash}" ] && \
"${EASYTLS_PRINTF}" '%s\n' "${fixed_hash}" && return 0

"${EASYRSA_OPENSSL}" dgst -"${EASYTLS_HASH_ALGO}" -r || return 1
"${EASYRSA_OPENSSL}" dgst -"${EASYTLS_HASH_ALGO}" -r || return 1
} # => ssl_generate_data_hash ()

# easytls wrapper for ssl data hash
Expand Down Expand Up @@ -8994,6 +9014,7 @@ generate_master_hash ()
return 0
fi

# Make sure to get a hash
unset request_fixed_hash

# Initialise the list variables
Expand All @@ -9002,52 +9023,78 @@ generate_master_hash ()
# Generate the lists above
generate_master_list || die "generate_master_hash - generate_master_list"

# Generate a single hash of all the files
generated_faster_hash="$(
{
set --
unset file_list
old_IFS="$IFS"
IFS="${new_line}"
unlock_ssl=1
# Use ssl unlock
master_hash_only=1

# List inline files
for f in ${inline_file_list}; do
# This does not appear to be any faster than cat.
# Hashing a hash .. I don't think it matters here.
# Choose hash
new_faster_hash || die "new_faster_hash"
#old_faster_hash || die "old_faster_hash"

set -- "$@" "${f}"
unset inline_file_list tlskey_file_list util_file_list master_hash_only
generated_faster_hash="${generated_faster_hash%% *}"
} # => generate_master_hash ()

done
# new_faster_hash way
new_faster_hash ()
{
# Generate a single hash of all the files via ssl
old_IFS="$IFS"
IFS="${new_line}"
set --

# List tlskey files
for f in ${tlskey_file_list}; do
# List inline files
for f in ${inline_file_list}; do set -- "$@" "${f}"; done

set -- "$@" "${f}"
# List tlskey files
for f in ${tlskey_file_list}; do set -- "$@" "${f}"; done

done
# List utility files
for f in ${util_file_list}; do set -- "$@" "${f}"; done

# List utility files
for f in ${util_file_list}; do
# hash each file in the @ list to a single hash-list
# hash the list-hash and return a single hash
hash_list_hash="$(
ssl_generate_new_master_files_hash "$@" | \
ssl_generate_old_master_data_hash
)" || \
die "new_faster_hash - # hash the list"

set -- "$@" "${f}"
# Use hash
generated_faster_hash="${hash_list_hash}"

done
set --
IFS="${old_IFS}"
unset old_IFS hash_list_hash
} # => new_faster_hash ()

# Restore standard IFS
IFS="${old_IFS}"
# old_faster_hash way
old_faster_hash ()
{
# Generate a single hash of all the files via cat
generated_faster_hash="$(
{
set --
IFS="${new_line}"
# cat the list - Comment out to test
# This save 20s of 3m25s on local testing
# List inline files
for f in ${inline_file_list}; do set -- "$@" "${f}"; done
# List tlskey files
for f in ${tlskey_file_list}; do set -- "$@" "${f}"; done
# List utility files
for f in ${util_file_list}; do set -- "$@" "${f}"; done
# cat the list
"${EASYTLS_CAT}" "$@" || \
die "generate_master_hash - # cat the list"
set --
} | openssl_generate_data_hash
} | ssl_generate_old_master_data_hash
)" || die "generate_master_hash - generated_faster_hash"

unset inline_file_list tlskey_file_list util_file_list
generated_faster_hash="${generated_faster_hash%% *}"
} # => generate_master_hash ()
} # => old_faster_hash ()

# Save Master hash
save_master_hash ()
Expand All @@ -9068,18 +9115,25 @@ save_master_hash ()
# Verify Master hash
verify_master_hash ()
{
[ -f "${EASYTLS_FASTER_HASH}" ] || missing_file "EASYTLS_FASTER_HASH"
#[ "${master_verify_hash_block}" ] && \
# die "Master verify hash must only run once"
saved_faster_hash="$("${EASYTLS_CAT}" "${EASYTLS_FASTER_HASH}")"
generate_master_hash || die "verify_faster_hash/generate_master_hash"
#validate_hash "${generated_faster_hash}"
[ "${master_verify_hash_block}" ] && \
die "Master verify hash must only run once"
read_hash_file "${EASYTLS_FASTER_HASH}" || {
error_msg "verify_master_hash - read_hash_file"
unset -v target_file hash_file generated_valid_hash saved_file_hash
return 1
}
# Use hash
saved_faster_hash="${saved_file_hash}"

generate_master_hash || die "verify_master_hash - generate_master_hash"
if match_two_hashes "${generated_faster_hash}" "${saved_faster_hash}"
then
easytls_verbose "verify_master_hash OK"
#master_verify_hash_block=1
master_verify_hash_block=1
return 0
fi
print "EASYTLS_PKI: ${EASYTLS_PKI}"
print "EASYTLS_FASTER_HASH: ${EASYTLS_FASTER_HASH}"
print "gen'd:${generated_faster_hash} <==> saved:${saved_faster_hash}"
print "TIP: Use './easytls rehash' to correct this hash."
return 1
Expand Down

1 comment on commit 747094d

@TinCanTech
Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.