/* */ #ifndef D_DHT_BUCKET_TREE_H #define D_DHT_BUCKET_TREE_H #include "common.h" #include #include "SharedHandle.h" #include "DHTConstants.h" namespace aria2 { class DHTBucket; class DHTNode; // This class represents Kademlia DHT routing tree. The leaf nodes // have bucket which contains DHT node. The tree is binary tree but // highly unbalanced. class DHTBucketTreeNode { public: // Ctor for internal node DHTBucketTreeNode(DHTBucketTreeNode* left, DHTBucketTreeNode* right); // Ctor for leaf node DHTBucketTreeNode(const SharedHandle& bucket); ~DHTBucketTreeNode(); // Returns child node, left or right, which contains key. If dig is // called against leaf node, then returns 0. DHTBucketTreeNode* dig(const unsigned char* key); bool isInRange(const unsigned char* key) const; // Returns true iff this is a leaf node. bool leaf() const { return bucket_; } const unsigned char* getMaxId() const { return maxId_; } const unsigned char* getMinId() const { return minId_; } DHTBucketTreeNode* getParent() const { return parent_; } DHTBucketTreeNode* getLeft() const { return left_; } DHTBucketTreeNode* getRight() const { return right_; } const SharedHandle& getBucket() const { return bucket_; } // Splits this object's bucket using DHTBucket::split() and create // left and right child node to hold buckets. The bucket of current // node is reseted so this node becomes internal node after this // call. void split(); private: // Do not allow copying DHTBucketTreeNode(const DHTBucketTreeNode&); DHTBucketTreeNode& operator=(const DHTBucketTreeNode&); // Reset relation of children and minId_ and maxId_. void resetRelation(); void setParent(DHTBucketTreeNode* parent) { parent_ = parent; } DHTBucketTreeNode* parent_; DHTBucketTreeNode* left_; DHTBucketTreeNode* right_; SharedHandle bucket_; unsigned char minId_[DHT_ID_LENGTH]; unsigned char maxId_[DHT_ID_LENGTH]; }; namespace dht { // Returns leaf node where key fits between node's min and max ID // range. DHTBucketTreeNode* findTreeNodeFor (DHTBucketTreeNode* root, const unsigned char* key); // Returns bucket where key fits between bucket's min and max ID // range. This function first use findTreeNodeFor and returns its // bucket_. SharedHandle findBucketFor (DHTBucketTreeNode* root, const unsigned char* key); // Stores most closest K nodes against key in nodes. K is // DHTBucket::K. This function may returns less than K nodes because // the routing tree contains less than K nodes. The order of nodes is // arbitrary. Caller must pass empty nodes. void findClosestKNodes (std::vector >& nodes, DHTBucketTreeNode* root, const unsigned char* key); // Stores all buckets in buckets. void enumerateBucket (std::vector >& buckets, DHTBucketTreeNode* root); } // namespace dht } // namespace aria2 #endif // D_DHT_BUCKET_TREE_H