GOST R 34.10 added

This commit is contained in:
orignal 2017-02-20 16:08:17 -05:00
parent 46232a102d
commit 20e8513daf
3 changed files with 12 additions and 2 deletions

View file

@ -27,6 +27,8 @@ std::string SigTypeToName(uint16_t keytype)
return "RSA-4096-SHA512";
case i2p::data::SIGNING_KEY_TYPE_EDDSA_SHA512_ED25519:
return "ED25519-SHA512";
case i2p::data::SIGNING_KEY_TYPE_GOSTR3410_A_GOSTR3411:
return "GOSTR3410-A-GOSTR3411";
default:
std::stringstream ss;
ss << "unknown: " << keytype;
@ -63,6 +65,8 @@ uint16_t NameToSigType(const std::string & keyname)
if(name.find("ED25519") != npos) return i2p::data::SIGNING_KEY_TYPE_EDDSA_SHA512_ED25519;
if(name.find("GOSTR3410") != npos) return i2p::data::SIGNING_KEY_TYPE_GOSTR3410_A_GOSTR3411;
return -1;
}

2
i2pd

@ -1 +1 @@
Subproject commit b3ab85f3b538d0fab9194e5a33632e0e694e7705
Subproject commit 6fc80e9b67c8ee0a4c2c82c9173d2c1fb56b0efb

View file

@ -18,6 +18,8 @@ int main (int argc, char * argv[])
std::string str(argv[2]);
type = NameToSigType(str);
}
if (type == i2p::data::SIGNING_KEY_TYPE_GOSTR3410_A_GOSTR3411)
i2p::crypto::InitGost ();
auto keys = i2p::data::PrivateKeys::CreateRandomKeys (type);
std::ofstream f (argv[1], std::ofstream::binary | std::ofstream::out);
if (f)
@ -32,6 +34,10 @@ int main (int argc, char * argv[])
else
std::cout << "Can't create file " << argv[1] << std::endl;
if (type == i2p::data::SIGNING_KEY_TYPE_GOSTR3410_A_GOSTR3411)
i2p::crypto::TerminateGost ();
i2p::crypto::TerminateCrypto ();
return 0;
}