1
0
mirror of https://github.com/mfontanini/libtins synced 2026-01-27 20:24:26 +01:00

Allow retrieving keys on WPA2Decrypter.

This commit is contained in:
Matias Fontanini
2015-05-21 21:14:24 -07:00
parent 76c6511e0c
commit 0dee5618f2
4 changed files with 243 additions and 24 deletions

View File

@@ -127,6 +127,37 @@ TEST_F(WPA2DecryptTest, DecryptCCMPWithoutUsingBeacon) {
}
}
TEST_F(WPA2DecryptTest, DecryptCCMPUsingKey) {
Crypto::WPA2Decrypter::addr_pair addresses;
Crypto::WPA2::SessionKeys session_keys;
{
Crypto::WPA2Decrypter decrypter;
decrypter.add_ap_data("Induction", "Coherer", "00:0c:41:82:b2:55");
for(size_t i = 1; i < 5; ++i) {
RadioTap radio(ccmp_packets[i], ccmp_packets_size[i]);
ASSERT_FALSE(decrypter.decrypt(radio));
}
const Crypto::WPA2Decrypter::keys_map& keys = decrypter.get_keys();
ASSERT_EQ(1, keys.size());
addresses = keys.begin()->first;
session_keys = keys.begin()->second;
}
Crypto::WPA2Decrypter decrypter;
decrypter.add_decryption_keys(addresses, session_keys);
for(size_t i = 5; i < 7; ++i) {
RadioTap radio(ccmp_packets[i], ccmp_packets_size[i]);
ASSERT_TRUE(decrypter.decrypt(radio));
if(i == 5)
check_ccmp_packet5(radio);
else
check_ccmp_packet6(radio);
}
EXPECT_TRUE(session_keys.uses_ccmp());
}
TEST_F(WPA2DecryptTest, DecryptTKIPUsingBeacon) {
Crypto::WPA2Decrypter decrypter;
decrypter.add_ap_data("libtinstest", "NODO");
@@ -161,6 +192,37 @@ TEST_F(WPA2DecryptTest, DecryptTKIPWithoutUsingBeacon) {
}
}
TEST_F(WPA2DecryptTest, DecryptTKIPUsingKey) {
Crypto::WPA2Decrypter::addr_pair addresses;
Crypto::WPA2::SessionKeys session_keys;
{
Crypto::WPA2Decrypter decrypter;
decrypter.add_ap_data("libtinstest", "NODO", "00:1b:11:d2:1b:eb");
for(size_t i = 1; i < 5; ++i) {
RadioTap radio(tkip_packets[i], tkip_packets_size[i]);
ASSERT_FALSE(decrypter.decrypt(radio));
}
const Crypto::WPA2Decrypter::keys_map& keys = decrypter.get_keys();
ASSERT_EQ(1, keys.size());
addresses = keys.begin()->first;
session_keys = keys.begin()->second;
}
Crypto::WPA2Decrypter decrypter;
decrypter.add_decryption_keys(addresses, session_keys);
for(size_t i = 5; i < 7; ++i) {
RadioTap radio(tkip_packets[i], tkip_packets_size[i]);
ASSERT_TRUE(decrypter.decrypt(radio));
if(i == 5)
check_tkip_packet5(radio);
else
check_tkip_packet6(radio);
}
EXPECT_FALSE(session_keys.uses_ccmp());
}
TEST_F(WPA2DecryptTest, DecryptCCMPAndTKIPUsingBeacon) {
Crypto::WPA2Decrypter decrypter;
decrypter.add_ap_data("libtinstest", "NODO");