minor: add _hmac function

This commit is contained in:
neilpang 2016-11-08 21:27:39 +08:00
parent 20a6ab3d1a
commit b001840dee
1 changed files with 25 additions and 0 deletions

25
acme.sh
View File

@ -436,6 +436,31 @@ _digest() {
}
#Usage: hashalg secret [outputhex]
#Output Base64-encoded hmac
_hmac() {
alg="$1"
hmac_sec="$2"
outputhex="$3"
if [ -z "$hmac_sec" ] ; then
_usage "Usage: _hmac hashalg secret [outputhex]"
return 1
fi
if [ "$alg" = "sha256" ] || [ "$alg" = "sha1" ]; then
if [ "$outputhex" ] ; then
openssl dgst -$alg -hmac "$hmac_sec" | cut -d = -f 2 | tr -d ' '
else
openssl dgst -$alg -hmac "$hmac_sec" -binary | _base64
fi
else
_err "$alg is not supported yet"
return 1
fi
}
#Usage: keyfile hashalg
#Output: Base64-encoded signature value
_sign() {