DHTBucket.h 4.18 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
/* <!-- copyright */
/*
 * aria2 - The high speed download utility
 *
 * Copyright (C) 2006 Tatsuhiro Tsujikawa
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 *
 * In addition, as a special exception, the copyright holders give
 * permission to link the code of portions of this program with the
 * OpenSSL library under certain conditions as described in each
 * individual source file, and distribute linked combinations
 * including the two.
 * You must obey the GNU General Public License in all respects
 * for all of the code used other than OpenSSL.  If you modify
 * file(s) with this exception, you may extend this exception to your
 * version of the file(s), but you are not obligated to do so.  If you
 * do not wish to do so, delete this exception statement from your
 * version.  If you delete this exception statement from all source
 * files in the program, then also delete it here.
 */
/* copyright --> */
#ifndef D_DHT_BUCKET_H
#define D_DHT_BUCKET_H

#include "common.h"

#include <string>
#include <deque>
#include <vector>
43
#include <memory>
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60

#include "DHTConstants.h"
#include "TimerA2.h"

namespace aria2 {

class DHTNode;

class DHTBucket {
private:
  size_t prefixLength_;

  // this bucket contains nodes of distance between [min_, max_](inclusive).
  unsigned char min_[DHT_ID_LENGTH];

  unsigned char max_[DHT_ID_LENGTH];

61
  std::shared_ptr<DHTNode> localNode_;
62 63

  // sorted in ascending order
64
  std::deque<std::shared_ptr<DHTNode>> nodes_;
65 66 67

  // a replacement cache. The maximum size is specified by CACHE_SIZE.
  // This is sorted by last time seen.
68
  std::deque<std::shared_ptr<DHTNode>> cachedNodes_;
69 70 71

  Timer lastUpdated_;

72 73 74
  bool isInRange(const unsigned char* nodeID, const unsigned char* max,
                 const unsigned char* min) const;

75
public:
76
  DHTBucket(const std::shared_ptr<DHTNode>& localNode);
77

78 79
  DHTBucket(size_t prefixLength, const unsigned char* max,
            const unsigned char* min,
80
            const std::shared_ptr<DHTNode>& localNode);
81 82 83 84 85 86 87 88 89

  ~DHTBucket();

  static const size_t K = 8;

  static const size_t CACHE_SIZE = 2;

  void getRandomNodeID(unsigned char* nodeID) const;

90
  std::unique_ptr<DHTBucket> split();
91

92
  bool isInRange(const std::shared_ptr<DHTNode>& node) const;
93 94 95

  bool isInRange(const unsigned char* nodeID) const;

96
  bool addNode(const std::shared_ptr<DHTNode>& node);
97

98
  void cacheNode(const std::shared_ptr<DHTNode>& node);
99 100

  bool splitAllowed() const;
101

102
  size_t getPrefixLength() const { return prefixLength_; }
103

104
  const unsigned char* getMaxID() const { return max_; }
105

106
  const unsigned char* getMinID() const { return min_; }
107

108
  size_t countNode() const { return nodes_.size(); }
109

110
  const std::deque<std::shared_ptr<DHTNode>>& getNodes() const
111 112 113 114
  {
    return nodes_;
  }

115
  void getGoodNodes(std::vector<std::shared_ptr<DHTNode>>& nodes) const;
116

117
  void dropNode(const std::shared_ptr<DHTNode>& node);
118

119
  void moveToHead(const std::shared_ptr<DHTNode>& node);
120

121
  void moveToTail(const std::shared_ptr<DHTNode>& node);
122

123
  bool contains(const std::shared_ptr<DHTNode>& node) const;
124

125 126 127
  std::shared_ptr<DHTNode> getNode(const unsigned char* nodeID,
                                   const std::string& ipaddr,
                                   uint16_t port) const;
128 129 130 131 132 133 134 135 136

  bool operator==(const DHTBucket& bucket) const;

  bool needsRefresh() const;

  void notifyUpdate();

  bool containsQuestionableNode() const;

137
  std::shared_ptr<DHTNode> getLRUQuestionableNode() const;
138

139
  const std::deque<std::shared_ptr<DHTNode>>& getCachedNodes() const
140 141 142 143 144 145 146 147
  {
    return cachedNodes_;
  }
};

} // namespace aria2

#endif // D_DHT_BUCKET_H