/* */ #include "DHTFindNodeReplyMessage.h" #include "DHTNode.h" #include "DHTBucket.h" #include "Data.h" #include "Dictionary.h" #include "DHTRoutingTable.h" #include "DHTMessageFactory.h" #include "DHTMessageDispatcher.h" #include "DHTMessageCallback.h" #include "PeerMessageUtil.h" DHTFindNodeReplyMessage::DHTFindNodeReplyMessage(const DHTNodeHandle& localNode, const DHTNodeHandle& remoteNode, const string& transactionID): DHTResponseMessage(localNode, remoteNode, transactionID) {} DHTFindNodeReplyMessage::~DHTFindNodeReplyMessage() {} void DHTFindNodeReplyMessage::doReceivedAction() { for(DHTNodes::iterator i = _closestKNodes.begin(); i != _closestKNodes.end(); ++i) { if(memcmp((*i)->getID(), _localNode->getID(), DHT_ID_LENGTH) != 0) { _routingTable->addNode(*i); } } } Dictionary* DHTFindNodeReplyMessage::getResponse() { Dictionary* a = new Dictionary(); a->put("id", new Data(reinterpret_cast(_localNode->getID()), DHT_ID_LENGTH)); size_t offset = 0; char buffer[DHTBucket::K*26]; for(DHTNodes::const_iterator i = _closestKNodes.begin(); i != _closestKNodes.end(); ++i) { DHTNodeHandle node = *i; memcpy(buffer+offset, node->getID(), DHT_ID_LENGTH); if(PeerMessageUtil::createcompact(buffer+20+offset, node->getIPAddress(), node->getPort())) { offset += 26; } } a->put("nodes", new Data(buffer, offset)); return a; } string DHTFindNodeReplyMessage::getMessageType() const { return "find_node"; } void DHTFindNodeReplyMessage::validate() const {} const DHTNodes& DHTFindNodeReplyMessage::getClosestKNodes() const { return _closestKNodes; } void DHTFindNodeReplyMessage::setClosestKNodes(const DHTNodes& closestKNodes) { _closestKNodes = closestKNodes; }