mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-02-02 06:54:15 +00:00
correct ciphertext length
This commit is contained in:
parent
b7d3fd959e
commit
61752e2aab
@ -836,7 +836,7 @@ namespace garlic
|
|||||||
// KDF1
|
// KDF1
|
||||||
// TODO : use precalculated hashes
|
// TODO : use precalculated hashes
|
||||||
static const char protocolName[41] = "Noise_IKelg2+hs2_25519_ChaChaPoly_SHA256"; // 40 bytes
|
static const char protocolName[41] = "Noise_IKelg2+hs2_25519_ChaChaPoly_SHA256"; // 40 bytes
|
||||||
uint8_t h[64], ck[32];
|
uint8_t h[80], ck[32];
|
||||||
SHA256 ((const uint8_t *)protocolName, 40, h);
|
SHA256 ((const uint8_t *)protocolName, 40, h);
|
||||||
memcpy (ck, h, 32);
|
memcpy (ck, h, 32);
|
||||||
SHA256 (h, 32, h);
|
SHA256 (h, 32, h);
|
||||||
@ -855,7 +855,7 @@ namespace garlic
|
|||||||
SHA256 (h, 64, h); // h = SHA256(h || aepk)
|
SHA256 (h, 64, h); // h = SHA256(h || aepk)
|
||||||
|
|
||||||
uint8_t sharedSecret[32], keyData[64];
|
uint8_t sharedSecret[32], keyData[64];
|
||||||
Decrypt (aepk, sharedSecret, m_Ctx); // x25519
|
Decrypt (aepk, sharedSecret, m_Ctx); // x25519(bsk, aepk)
|
||||||
i2p::crypto::HKDF (ck, sharedSecret, 32, "", keyData); // keydata = HKDF(chainKey, sharedSecret, "", 64)
|
i2p::crypto::HKDF (ck, sharedSecret, 32, "", keyData); // keydata = HKDF(chainKey, sharedSecret, "", 64)
|
||||||
memcpy (ck, keyData, 32); // chainKey = keydata[0:31]
|
memcpy (ck, keyData, 32); // chainKey = keydata[0:31]
|
||||||
|
|
||||||
@ -867,8 +867,8 @@ namespace garlic
|
|||||||
LogPrint (eLogWarning, "Garlic: Flags/static section AEAD verification failed ");
|
LogPrint (eLogWarning, "Garlic: Flags/static section AEAD verification failed ");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
memcpy (h + 32, buf, 32);
|
memcpy (h + 32, buf, 48);
|
||||||
SHA256 (h, 64, h); // h = SHA256(h || ciphertext)
|
SHA256 (h, 80, h); // h = SHA256(h || ciphertext)
|
||||||
buf += 48; len -= 48; // 32 data + 16 poly
|
buf += 48; len -= 48; // 32 data + 16 poly
|
||||||
// decrypt payload
|
// decrypt payload
|
||||||
std::vector<uint8_t> payload (len + 32); uint8_t h1[32];
|
std::vector<uint8_t> payload (len + 32); uint8_t h1[32];
|
||||||
@ -877,7 +877,7 @@ namespace garlic
|
|||||||
if (isStatic)
|
if (isStatic)
|
||||||
{
|
{
|
||||||
// static key, fs is apk
|
// static key, fs is apk
|
||||||
Decrypt (fs, sharedSecret, m_Ctx); // DH(bsk, apk)
|
Decrypt (fs, sharedSecret, m_Ctx); // x25519(bsk, apk)
|
||||||
i2p::crypto::HKDF (ck, sharedSecret, 32, "", keyData); // keydata = HKDF(chainKey, sharedSecret, "", 64)
|
i2p::crypto::HKDF (ck, sharedSecret, 32, "", keyData); // keydata = HKDF(chainKey, sharedSecret, "", 64)
|
||||||
memcpy (ck, keyData, 32); // chainKey = keydata[0:31]
|
memcpy (ck, keyData, 32); // chainKey = keydata[0:31]
|
||||||
memcpy (payload.data (), h, 32);
|
memcpy (payload.data (), h, 32);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user