Веб-сайт самохостера Lotigara

summaryrefslogtreecommitdiff
path: root/source/core/StarCurve25519.cpp
diff options
context:
space:
mode:
authorKae <80987908+Novaenia@users.noreply.github.com>2023-07-12 15:13:30 +1000
committerKae <80987908+Novaenia@users.noreply.github.com>2023-07-12 15:13:30 +1000
commit81343bc06fc08d8a3ba441e6038c9be1ed093fdc (patch)
treef0e8452385604b7287d28a5e83d9f8a5d4e591d1 /source/core/StarCurve25519.cpp
parent70bfb54e5575476450a4f604507e9a8189ca144b (diff)
Add Curve25519
Diffstat (limited to 'source/core/StarCurve25519.cpp')
-rw-r--r--source/core/StarCurve25519.cpp50
1 files changed, 50 insertions, 0 deletions
diff --git a/source/core/StarCurve25519.cpp b/source/core/StarCurve25519.cpp
new file mode 100644
index 0000000..f8f5451
--- /dev/null
+++ b/source/core/StarCurve25519.cpp
@@ -0,0 +1,50 @@
+#include "StarCurve25519.hpp"
+#include "StarRandom.hpp"
+#include "StarLogging.hpp"
+
+#include "curve25519/include/curve25519_dh.h"
+#include "curve25519/include/ed25519_signature.h"
+
+namespace Star::Curve25519 {
+
+struct KeySet {
+ PrivateKey privateKey;
+ PublicKey publicKey;
+
+ KeySet() {
+ SecretKey secret;
+ Random::randBytes(SecretKeySize).copyTo((char*)secret.data());
+
+ secret[0] &= 248;
+ secret[31] &= 127;
+ secret[31] |= 64;
+
+ ed25519_CreateKeyPair(privateKey.data(), publicKey.data(), nullptr, secret.data());
+
+ Logger::info("Generated Curve25519 key-pair");
+ }
+};
+
+static KeySet const& staticKeys() {
+ static KeySet keys;
+
+ return keys;
+}
+
+PrivateKey const& privateKey() { return staticKeys().privateKey; }
+
+
+
+Signature sign(void* data, size_t len) {
+ Signature signature;
+ ed25519_SignMessage(signature.data(), privateKey().data(), nullptr, (unsigned char*)data, len);
+ return signature;
+}
+
+bool verify(uint8_t const* signature, uint8_t const* publicKey, void* data, size_t len) {
+ return ed25519_VerifySignature(signature, publicKey, (unsigned char*)data, len);
+}
+
+PublicKey const& publicKey() { return staticKeys().publicKey; }
+
+} \ No newline at end of file