2008-02-18 13:41:58 +00:00
|
|
|
#include "MSEHandshake.h"
|
2008-11-03 06:49:02 +00:00
|
|
|
|
2009-06-28 10:37:15 +00:00
|
|
|
#include <cstring>
|
|
|
|
|
2008-11-03 06:49:02 +00:00
|
|
|
#include <cppunit/extensions/HelperMacros.h>
|
|
|
|
|
2008-02-18 13:41:58 +00:00
|
|
|
#include "Exception.h"
|
2009-10-22 15:35:33 +00:00
|
|
|
#include "util.h"
|
2008-02-18 13:41:58 +00:00
|
|
|
#include "prefs.h"
|
|
|
|
#include "Socket.h"
|
|
|
|
#include "Option.h"
|
2009-06-28 10:37:15 +00:00
|
|
|
#include "DownloadContext.h"
|
2008-02-18 13:41:58 +00:00
|
|
|
#include "FileEntry.h"
|
2009-06-28 10:37:15 +00:00
|
|
|
#include "array_fun.h"
|
|
|
|
#include "bittorrent_helper.h"
|
2008-02-18 13:41:58 +00:00
|
|
|
|
|
|
|
namespace aria2 {
|
|
|
|
|
|
|
|
class MSEHandshakeTest:public CppUnit::TestFixture {
|
|
|
|
|
|
|
|
CPPUNIT_TEST_SUITE(MSEHandshakeTest);
|
|
|
|
CPPUNIT_TEST(testHandshake);
|
|
|
|
CPPUNIT_TEST_SUITE_END();
|
|
|
|
private:
|
2009-06-28 10:37:15 +00:00
|
|
|
SharedHandle<DownloadContext> _dctx;
|
2008-02-18 13:41:58 +00:00
|
|
|
|
|
|
|
void doHandshake(const SharedHandle<MSEHandshake>& initiator,
|
2010-01-05 16:01:46 +00:00
|
|
|
const SharedHandle<MSEHandshake>& receiver);
|
2008-02-18 13:41:58 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
void setUp()
|
|
|
|
{
|
2009-06-28 10:37:15 +00:00
|
|
|
_dctx.reset(new DownloadContext());
|
2008-02-18 13:41:58 +00:00
|
|
|
unsigned char infoHash[20];
|
|
|
|
memset(infoHash, 0, sizeof(infoHash));
|
2009-06-28 10:37:15 +00:00
|
|
|
BDE torrentAttrs = BDE::dict();
|
|
|
|
torrentAttrs[bittorrent::INFO_HASH] =
|
2010-03-25 13:51:10 +00:00
|
|
|
std::string(vbegin(infoHash), vend(infoHash));
|
2009-06-28 10:37:15 +00:00
|
|
|
_dctx->setAttribute(bittorrent::BITTORRENT, torrentAttrs);
|
2008-02-18 13:41:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void testHandshake();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION(MSEHandshakeTest);
|
|
|
|
|
2008-04-20 00:50:22 +00:00
|
|
|
static std::pair<SharedHandle<SocketCore>,
|
2010-01-05 16:01:46 +00:00
|
|
|
SharedHandle<SocketCore> > createSocketPair()
|
2008-02-18 13:41:58 +00:00
|
|
|
{
|
2008-04-20 00:50:22 +00:00
|
|
|
SharedHandle<SocketCore> initiatorSock(new SocketCore());
|
2008-02-18 13:41:58 +00:00
|
|
|
|
|
|
|
SocketCore receiverServerSock;
|
|
|
|
receiverServerSock.bind(0);
|
|
|
|
receiverServerSock.beginListen();
|
|
|
|
|
2008-03-09 12:24:01 +00:00
|
|
|
std::pair<std::string, uint16_t> receiverAddrInfo;
|
2008-02-18 13:41:58 +00:00
|
|
|
receiverServerSock.getAddrInfo(receiverAddrInfo);
|
2009-02-12 13:11:51 +00:00
|
|
|
initiatorSock->establishConnection("localhost", receiverAddrInfo.second);
|
2008-02-18 13:41:58 +00:00
|
|
|
initiatorSock->setBlockingMode();
|
|
|
|
|
2008-04-20 00:50:22 +00:00
|
|
|
SharedHandle<SocketCore> receiverSock(receiverServerSock.acceptConnection());
|
2008-02-18 13:41:58 +00:00
|
|
|
receiverSock->setBlockingMode();
|
|
|
|
|
2008-04-20 00:50:22 +00:00
|
|
|
return std::pair<SharedHandle<SocketCore>,
|
|
|
|
SharedHandle<SocketCore> >(initiatorSock, receiverSock);
|
2008-02-18 13:41:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void MSEHandshakeTest::doHandshake(const SharedHandle<MSEHandshake>& initiator, const SharedHandle<MSEHandshake>& receiver)
|
|
|
|
{
|
|
|
|
initiator->sendPublicKey();
|
|
|
|
|
|
|
|
while(!receiver->receivePublicKey());
|
|
|
|
receiver->sendPublicKey();
|
|
|
|
|
|
|
|
while(!initiator->receivePublicKey());
|
2009-06-28 10:37:15 +00:00
|
|
|
initiator->initCipher(bittorrent::getInfoHash(_dctx));
|
2008-02-18 13:41:58 +00:00
|
|
|
initiator->sendInitiatorStep2();
|
|
|
|
|
|
|
|
while(!receiver->findReceiverHashMarker());
|
2010-02-28 12:30:11 +00:00
|
|
|
std::vector<SharedHandle<DownloadContext> > contexts;
|
2009-06-28 10:37:15 +00:00
|
|
|
contexts.push_back(_dctx);
|
|
|
|
while(!receiver->receiveReceiverHashAndPadCLength(contexts));
|
2008-02-18 13:41:58 +00:00
|
|
|
while(!receiver->receivePad());
|
|
|
|
while(!receiver->receiveReceiverIALength());
|
|
|
|
while(!receiver->receiveReceiverIA());
|
|
|
|
receiver->sendReceiverStep2();
|
|
|
|
|
|
|
|
while(!initiator->findInitiatorVCMarker());
|
|
|
|
while(!initiator->receiveInitiatorCryptoSelectAndPadDLength());
|
|
|
|
while(!initiator->receivePad());
|
|
|
|
}
|
|
|
|
|
2008-04-20 00:50:22 +00:00
|
|
|
static SharedHandle<MSEHandshake>
|
|
|
|
createMSEHandshake(SharedHandle<SocketCore> socket, bool initiator,
|
2010-01-05 16:01:46 +00:00
|
|
|
const Option* option)
|
2008-02-18 13:41:58 +00:00
|
|
|
{
|
2008-04-20 00:50:22 +00:00
|
|
|
SharedHandle<MSEHandshake> h(new MSEHandshake(1, socket, option));
|
2008-02-18 13:41:58 +00:00
|
|
|
h->initEncryptionFacility(initiator);
|
|
|
|
return h;
|
|
|
|
}
|
|
|
|
|
|
|
|
void MSEHandshakeTest::testHandshake()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Option op;
|
|
|
|
op.put(PREF_BT_MIN_CRYPTO_LEVEL, V_PLAIN);
|
|
|
|
|
2008-04-20 00:50:22 +00:00
|
|
|
std::pair<SharedHandle<SocketCore>, SharedHandle<SocketCore> > sockPair =
|
|
|
|
createSocketPair();
|
2008-02-18 13:41:58 +00:00
|
|
|
SharedHandle<MSEHandshake> initiator = createMSEHandshake(sockPair.first, true, &op);
|
|
|
|
SharedHandle<MSEHandshake> receiver = createMSEHandshake(sockPair.second, false, &op);
|
|
|
|
|
|
|
|
doHandshake(initiator, receiver);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(MSEHandshake::CRYPTO_PLAIN_TEXT, initiator->getNegotiatedCryptoType());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(MSEHandshake::CRYPTO_PLAIN_TEXT, receiver->getNegotiatedCryptoType());
|
|
|
|
}
|
|
|
|
{
|
|
|
|
Option op;
|
|
|
|
op.put(PREF_BT_MIN_CRYPTO_LEVEL, V_ARC4);
|
|
|
|
|
2008-04-20 00:50:22 +00:00
|
|
|
std::pair<SharedHandle<SocketCore>, SharedHandle<SocketCore> > sockPair =
|
|
|
|
createSocketPair();
|
2008-02-18 13:41:58 +00:00
|
|
|
SharedHandle<MSEHandshake> initiator = createMSEHandshake(sockPair.first, true, &op);
|
|
|
|
SharedHandle<MSEHandshake> receiver = createMSEHandshake(sockPair.second, false, &op);
|
|
|
|
|
|
|
|
doHandshake(initiator, receiver);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(MSEHandshake::CRYPTO_ARC4, initiator->getNegotiatedCryptoType());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(MSEHandshake::CRYPTO_ARC4, receiver->getNegotiatedCryptoType());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace aria2
|