aboutsummaryrefslogtreecommitdiff
path: root/mod/hmac.hxx
diff options
context:
space:
mode:
authorFrancois Kritzinger <francois@codesynthesis.com>2024-02-28 10:52:08 +0200
committerFrancois Kritzinger <francois@codesynthesis.com>2024-06-05 09:12:46 +0200
commitd923111f50e59196ec4b84d943ccfb652a9d77d8 (patch)
tree4c983495ef4c20ae299336de0e6e584dcfb55720 /mod/hmac.hxx
parent875d221c3561203575096cbf9cd93d784e923d3a (diff)
Verify webhook request HMACs
Diffstat (limited to 'mod/hmac.hxx')
-rw-r--r--mod/hmac.hxx29
1 files changed, 29 insertions, 0 deletions
diff --git a/mod/hmac.hxx b/mod/hmac.hxx
new file mode 100644
index 0000000..104b629
--- /dev/null
+++ b/mod/hmac.hxx
@@ -0,0 +1,29 @@
+#ifndef MOD_HMAC_HXX
+#define MOD_HMAC_HXX
+
+#include <libbrep/types.hxx>
+#include <libbrep/utility.hxx>
+
+#include <mod/module-options.hxx>
+
+namespace brep
+{
+ // Compute the HMAC-SHA256 message authentication code over a message using
+ // the given key.
+ //
+ // Return the HMAC or throw std::system_error in case of an error.
+ //
+ // Example output:
+ //
+ // 5e822587094c68e646db8b916da1db2056d92f1dea4252136a533b4147a30cb7
+ //
+ // Note that although any cryptographic hash function can be used to compute
+ // an HMAC, this implementation supports only SHA-256.
+ //
+ string
+ compute_hmac (const options::openssl_options&,
+ const vector<char>& message,
+ const char* key);
+}
+
+#endif