mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 21:37:17 +01:00
persist multi encryption keys
This commit is contained in:
parent
a2a0f62135
commit
f4798d05e7
|
@ -867,13 +867,18 @@ namespace client
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// if no param or valid crypto type use from identity
|
// if no param or valid crypto type use from identity
|
||||||
if (encryptionKeyTypes.empty ()) encryptionKeyTypes.insert (GetIdentity ()->GetCryptoKeyType ());
|
bool isSingleKey = false;
|
||||||
|
if (encryptionKeyTypes.empty ())
|
||||||
|
{
|
||||||
|
isSingleKey = true;
|
||||||
|
encryptionKeyTypes.insert (GetIdentity ()->GetCryptoKeyType ());
|
||||||
|
}
|
||||||
|
|
||||||
for (auto& it: encryptionKeyTypes)
|
for (auto& it: encryptionKeyTypes)
|
||||||
{
|
{
|
||||||
auto encryptionKey = new EncryptionKey (it);
|
auto encryptionKey = new EncryptionKey (it);
|
||||||
if (isPublic)
|
if (isPublic)
|
||||||
PersistTemporaryKeys (encryptionKey); // TODO:
|
PersistTemporaryKeys (encryptionKey, isSingleKey);
|
||||||
else
|
else
|
||||||
encryptionKey->GenerateKeys ();
|
encryptionKey->GenerateKeys ();
|
||||||
encryptionKey->CreateDecryptor ();
|
encryptionKey->CreateDecryptor ();
|
||||||
|
@ -1119,10 +1124,12 @@ namespace client
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClientDestination::PersistTemporaryKeys (EncryptionKey * keys)
|
void ClientDestination::PersistTemporaryKeys (EncryptionKey * keys, bool isSingleKey)
|
||||||
{
|
{
|
||||||
|
if (!keys) return;
|
||||||
std::string ident = GetIdentHash().ToBase32();
|
std::string ident = GetIdentHash().ToBase32();
|
||||||
std::string path = i2p::fs::DataDirPath("destinations", (ident + ".dat"));
|
std::string path = i2p::fs::DataDirPath("destinations",
|
||||||
|
isSingleKey ? (ident + ".dat") : (ident + "." + std::to_string (keys->keyType) + ".dat"));
|
||||||
std::ifstream f(path, std::ifstream::binary);
|
std::ifstream f(path, std::ifstream::binary);
|
||||||
|
|
||||||
if (f) {
|
if (f) {
|
||||||
|
|
|
@ -256,7 +256,7 @@ namespace client
|
||||||
std::shared_ptr<ClientDestination> GetSharedFromThis () {
|
std::shared_ptr<ClientDestination> GetSharedFromThis () {
|
||||||
return std::static_pointer_cast<ClientDestination>(shared_from_this ());
|
return std::static_pointer_cast<ClientDestination>(shared_from_this ());
|
||||||
}
|
}
|
||||||
void PersistTemporaryKeys (EncryptionKey * keys);
|
void PersistTemporaryKeys (EncryptionKey * keys, bool isSingleKey);
|
||||||
void ReadAuthKey (const std::string& group, const std::map<std::string, std::string> * params);
|
void ReadAuthKey (const std::string& group, const std::map<std::string, std::string> * params);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
Loading…
Reference in a new issue