mirror of
https://github.com/mtrojnar/osslsigncode.git
synced 2025-04-04 08:50:12 -05:00
52 lines
1.5 KiB
Bash
52 lines
1.5 KiB
Bash
#!/bin/sh
|
|
# Compare the leaf certificate hash against specified SHA256 message digest for the file
|
|
|
|
. $(dirname $0)/../test_library
|
|
script_path=$(pwd)
|
|
test_nr=40
|
|
|
|
for file in ${script_path}/../logs/notsigned/*.*
|
|
do
|
|
name="${file##*/}"
|
|
ext="${file##*.}"
|
|
desc=""
|
|
case $ext in
|
|
"cat") filetype=CAT; format_nr=1 ;;
|
|
"msi") filetype=MSI; format_nr=2 ;;
|
|
"ex_") filetype=CAB; format_nr=3 ;;
|
|
"exe") filetype=PE; format_nr=4 ;;
|
|
"ps1")
|
|
filetype=TXT
|
|
if xxd -p -l 2 "notsigned/$name" | grep -q "fffe"; then
|
|
format_nr=5
|
|
desc=" UTF-16LE(BOM)"
|
|
elif xxd -p -l 3 "notsigned/$name" | grep -q "efbbbf"; then
|
|
format_nr=6
|
|
desc=" UTF-8(BOM)"
|
|
else
|
|
format_nr=7
|
|
desc=" UTF-8"
|
|
fi ;;
|
|
esac
|
|
|
|
number="$test_nr$format_nr"
|
|
test_name="Compare the leaf hash against SHA256 message digest for the $filetype$desc file"
|
|
printf "\n%03d. %s\n" "$number" "$test_name"
|
|
|
|
../../osslsigncode sign -h sha256 \
|
|
-st "1556668800" \
|
|
-certs "${script_path}/../certs/cert.pem" -key "${script_path}/../certs/key.der" \
|
|
-in "notsigned/$name" -out "test_$number.$ext"
|
|
result=$?
|
|
|
|
if test "$filetype" = "TXT" && ! cmp -l -n 3 "notsigned/$name" "test_$number.$ext"; then
|
|
printf "%s\n" "Compare file prefix failed"
|
|
test_result "1" "$number" "$test_name"
|
|
else
|
|
verify_leaf_hash "$result" "$number" "$ext" "@2019-05-01 00:00:00"
|
|
test_result "$?" "$number" "$test_name"
|
|
fi
|
|
done
|
|
|
|
exit 0
|