From b001840dee20d31423a7fb29e18ac9177b7f9a4c Mon Sep 17 00:00:00 2001 From: neilpang Date: Tue, 8 Nov 2016 21:27:39 +0800 Subject: [PATCH] minor: add _hmac function --- acme.sh | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/acme.sh b/acme.sh index e077d2e6..c52ce70c 100755 --- a/acme.sh +++ b/acme.sh @@ -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() {