-
Notifications
You must be signed in to change notification settings - Fork 37
/
x25519.cpp
78 lines (61 loc) · 1.92 KB
/
x25519.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#include <openssl/evp.h>
#include <openssl/bn.h>
#include <iostream>
#include <string>
#include <iomanip>
#include "Base.h"
#define KEYSIZE 32
size_t len = KEYSIZE;
struct BoxKeys
{
uint8_t PublicKey[KEYSIZE];
uint8_t PrivateKey[KEYSIZE];
};
BoxKeys getKeyPair()
{
BoxKeys keys;
EVP_PKEY_CTX * Ctx;
EVP_PKEY * Pkey = nullptr;
Ctx = EVP_PKEY_CTX_new_id (NID_X25519, NULL);
EVP_PKEY_keygen_init (Ctx);
EVP_PKEY_keygen (Ctx, &Pkey);
EVP_PKEY_get_raw_public_key (Pkey, keys.PublicKey, &len);
EVP_PKEY_get_raw_private_key (Pkey, keys.PrivateKey, &len);
EVP_PKEY_CTX_free(Ctx);
EVP_PKEY_free(Pkey);
return keys;
}
int main(int argc, char * argv[])
{
if (argc > 1)
{
std::string arg (argv[1]);
if (arg == "--usage" || arg == "--help" || arg == "-h")
{
std::cout << "The x25519 keys are used for authentication with an encrypted LeaseSet.\n"
<< "Server side:\n"
<< " signaturetype = 11\n"
<< " i2cp.leaseSetType = 5\n"
<< " i2cp.leaseSetAuthType = 1\n"
<< " i2cp.leaseSetClient.dh.210 = clientName:PublicKey\n"
<< "Client side:\n"
<< " i2cp.leaseSetPrivKey = PrivateKey\n\n"
<< "https://i2pd.readthedocs.io/en/latest/user-guide/tunnels/" << std::endl;
return 0;
}
}
BoxKeys newKeys = getKeyPair();
const size_t len_out = 50;
char b64Public[len_out] = {0};
char b64Private[len_out] = {0};
i2p::data::ByteStreamToBase64 (newKeys.PublicKey, len, b64Public, len_out);
std::cout << "PublicKey: ";
for (int i = 0; b64Public[i] != 0; ++i)
std::cout << b64Public[i];
i2p::data::ByteStreamToBase64 (newKeys.PrivateKey, len, b64Private, len_out);
std::cout << "\nPrivateKey: ";
for (int i = 0; b64Private[i] != 0; ++i)
std::cout << b64Private[i];
std::cout << std::endl;
return 0;
}