aboutsummaryrefslogtreecommitdiff
path: root/Src/auth/OAuthKey.cpp
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/auth/OAuthKey.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/auth/OAuthKey.cpp')
-rw-r--r--Src/auth/OAuthKey.cpp31
1 files changed, 31 insertions, 0 deletions
diff --git a/Src/auth/OAuthKey.cpp b/Src/auth/OAuthKey.cpp
new file mode 100644
index 00000000..7fd3fdeb
--- /dev/null
+++ b/Src/auth/OAuthKey.cpp
@@ -0,0 +1,31 @@
+#include "OAuthKey.h"
+#include "b64.h"
+
+OAuthKey::OAuthKey(const void *key, size_t key_len)
+{
+ HMAC_SHA256_Init(&ctx);
+ HMAC_SHA256_UpdateKey(&ctx, (unsigned char *)key, (int)key_len);
+ HMAC_SHA256_EndKey(&ctx);
+ HMAC_SHA256_StartMessage(&ctx);
+}
+
+OAuthKey::~OAuthKey()
+{
+ HMAC_SHA256_Done(&ctx);
+}
+
+void OAuthKey::FeedMessage(const void *data, size_t data_len)
+{
+ HMAC_SHA256_UpdateMessage(&ctx, (unsigned char *)data, (unsigned int)data_len);
+}
+
+void OAuthKey::EndMessage()
+{
+ HMAC_SHA256_EndMessage(buf, &ctx);
+}
+
+void OAuthKey::GetBase64(char *output, size_t cch)
+{
+ size_t len = b64::b64_encode(buf, HMAC_SHA256_DIGEST_LENGTH, output, cch);
+ output[len] = '\0';
+} \ No newline at end of file