1
0
mirror of https://github.com/PurpleI2P/i2pd-tools synced 2025-01-15 17:20:08 +00:00
i2pd-tools/keygen.cpp

43 lines
1.2 KiB
C++
Raw Normal View History

2016-09-16 11:28:01 -04:00
#include <iostream>
#include <fstream>
#include <stdlib.h>
#include "Crypto.h"
#include "Identity.h"
2016-10-10 07:59:54 -04:00
#include "common/key.hpp"
2016-09-16 11:28:01 -04:00
int main (int argc, char * argv[])
{
2016-10-10 07:18:33 -04:00
if (argc < 2)
2016-09-16 11:28:01 -04:00
{
2016-10-10 07:59:54 -04:00
std::cout << "Usage: keygen filename <signature type>" << std::endl;
2016-09-16 11:28:01 -04:00
return -1;
}
2024-05-07 18:13:03 -04:00
i2p::crypto::InitCrypto (false, true, false);
2021-02-02 15:02:35 +03:00
i2p::data::SigningKeyType type = i2p::data::SIGNING_KEY_TYPE_EDDSA_SHA512_ED25519;
2016-10-10 07:59:54 -04:00
if (argc > 2) {
std::string str(argv[2]);
type = NameToSigType(str);
2021-06-03 00:56:35 -04:00
if (SigTypeToName(type).find("unknown") != std::string::npos) { std::cerr << "Incorrect signature type" << std::endl; return -2; }
2016-10-10 07:59:54 -04:00
}
2016-09-16 11:28:01 -04:00
auto keys = i2p::data::PrivateKeys::CreateRandomKeys (type);
std::ofstream f (argv[1], std::ofstream::binary | std::ofstream::out);
if (f)
{
size_t len = keys.GetFullLen ();
uint8_t * buf = new uint8_t[len];
len = keys.ToBuffer (buf, len);
f.write ((char *)buf, len);
delete[] buf;
std::cout << "Destination " << keys.GetPublic ()->GetIdentHash ().ToBase32 () << " created" << std::endl;
2021-06-03 00:56:35 -04:00
std::cout << "Signature type: " << SigTypeToName(type) << " (" << type << ")" << std::endl;
2016-09-16 11:28:01 -04:00
}
else
std::cout << "Can't create file " << argv[1] << std::endl;
2016-09-16 11:28:01 -04:00
2017-02-20 16:08:17 -05:00
i2p::crypto::TerminateCrypto ();
2016-09-16 11:28:01 -04:00
return 0;
}