diff options
author | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-07-12 15:13:30 +1000 |
---|---|---|
committer | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-07-12 15:13:30 +1000 |
commit | 81343bc06fc08d8a3ba441e6038c9be1ed093fdc (patch) | |
tree | f0e8452385604b7287d28a5e83d9f8a5d4e591d1 /source/core/StarCurve25519.cpp | |
parent | 70bfb54e5575476450a4f604507e9a8189ca144b (diff) |
Add Curve25519
Diffstat (limited to 'source/core/StarCurve25519.cpp')
-rw-r--r-- | source/core/StarCurve25519.cpp | 50 |
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 |