/* */ #include "DHTFindNodeReplyMessage.h" #include #include "DHTNode.h" #include "DHTBucket.h" #include "DHTRoutingTable.h" #include "DHTMessageFactory.h" #include "DHTMessageDispatcher.h" #include "DHTMessageCallback.h" #include "bittorrent_helper.h" #include "Util.h" #include "bencode.h" namespace aria2 { const std::string DHTFindNodeReplyMessage::FIND_NODE("find_node"); const std::string DHTFindNodeReplyMessage::NODES("nodes"); DHTFindNodeReplyMessage::DHTFindNodeReplyMessage(const SharedHandle& localNode, const SharedHandle& remoteNode, const std::string& transactionID): DHTResponseMessage(localNode, remoteNode, transactionID) {} DHTFindNodeReplyMessage::~DHTFindNodeReplyMessage() {} void DHTFindNodeReplyMessage::doReceivedAction() { for(std::deque >::iterator i = _closestKNodes.begin(); i != _closestKNodes.end(); ++i) { if(memcmp((*i)->getID(), _localNode->getID(), DHT_ID_LENGTH) != 0) { _routingTable->addNode(*i); } } } BDE DHTFindNodeReplyMessage::getResponse() { BDE aDict = BDE::dict(); aDict[DHTMessage::ID] = BDE(_localNode->getID(), DHT_ID_LENGTH); size_t offset = 0; unsigned char buffer[DHTBucket::K*26]; // TODO if _closestKNodes.size() > DHTBucket::K ?? for(std::deque >::const_iterator i = _closestKNodes.begin(); i != _closestKNodes.end() && offset < DHTBucket::K*26; ++i) { SharedHandle node = *i; memcpy(buffer+offset, node->getID(), DHT_ID_LENGTH); if(bittorrent::createcompact(buffer+20+offset, node->getIPAddress(), node->getPort())) { offset += 26; } } aDict[NODES] = BDE(buffer, offset); return aDict; } std::string DHTFindNodeReplyMessage::getMessageType() const { return FIND_NODE; } void DHTFindNodeReplyMessage::validate() const {} void DHTFindNodeReplyMessage::setClosestKNodes(const std::deque >& closestKNodes) { _closestKNodes = closestKNodes; } std::string DHTFindNodeReplyMessage::toStringOptional() const { return "nodes="+util::uitos(_closestKNodes.size()); } } // namespace aria2