mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-02-02 11:04:00 +01:00
tunnel encryption/decryption
This commit is contained in:
parent
6557ebb51b
commit
6d1d816153
15
aes.cpp
15
aes.cpp
|
@ -1,4 +1,5 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include "TunnelBase.h"
|
||||||
#include "aes.h"
|
#include "aes.h"
|
||||||
|
|
||||||
namespace i2p
|
namespace i2p
|
||||||
|
@ -287,6 +288,20 @@ namespace crypto
|
||||||
Decrypt (1, (const ChipherBlock *)in, (ChipherBlock *)out);
|
Decrypt (1, (const ChipherBlock *)in, (ChipherBlock *)out);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TunnelEncryption::Encrypt (uint8_t * payload)
|
||||||
|
{
|
||||||
|
m_IVEncryption.Encrypt ((ChipherBlock *)payload, (ChipherBlock *)payload); // iv
|
||||||
|
m_LayerEncryption.Encrypt (payload + 16, i2p::tunnel::TUNNEL_DATA_ENCRYPTED_SIZE, payload + 16); // data
|
||||||
|
m_IVEncryption.Encrypt ((ChipherBlock *)payload, (ChipherBlock *)payload); // double iv
|
||||||
|
}
|
||||||
|
|
||||||
|
void TunnelDecryption::Decrypt (uint8_t * payload)
|
||||||
|
{
|
||||||
|
m_IVDecryption.Decrypt ((ChipherBlock *)payload, (ChipherBlock *)payload); // iv
|
||||||
|
m_LayerDecryption.Decrypt (payload + 16, i2p::tunnel::TUNNEL_DATA_ENCRYPTED_SIZE, payload + 16); // data
|
||||||
|
m_IVDecryption.Decrypt ((ChipherBlock *)payload, (ChipherBlock *)payload); // double iv
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
36
aes.h
36
aes.h
|
@ -138,6 +138,42 @@ namespace crypto
|
||||||
ChipherBlock m_IV;
|
ChipherBlock m_IV;
|
||||||
ECBDecryption m_ECBDecryption;
|
ECBDecryption m_ECBDecryption;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class TunnelEncryption // with double IV encryption
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
void SetKeys (uint8_t * layerKey, uint8_t * ivKey)
|
||||||
|
{
|
||||||
|
m_LayerEncryption.SetKey (layerKey);
|
||||||
|
m_IVEncryption.SetKey (ivKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Encrypt (uint8_t * payload); // 1024 bytes (16 IV + 1008 data)
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
ECBEncryption m_IVEncryption;
|
||||||
|
CBCEncryption m_LayerEncryption;
|
||||||
|
};
|
||||||
|
|
||||||
|
class TunnelDecryption // with double IV encryption
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
void SetKeys (uint8_t * layerKey, uint8_t * ivKey)
|
||||||
|
{
|
||||||
|
m_LayerDecryption.SetKey (layerKey);
|
||||||
|
m_IVDecryption.SetKey (ivKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Decrypt (uint8_t * payload); // 1024 bytes (16 IV + 1008 data)
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
ECBDecryption m_IVDecryption;
|
||||||
|
CBCDecryption m_LayerDecryption;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue