File: KBucket.h

package info (click to toggle)
eiskaltdcpp 2.4.2-1.3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 25,676 kB
  • sloc: cpp: 97,597; ansic: 5,004; perl: 1,897; xml: 1,440; sh: 1,313; php: 661; javascript: 257; makefile: 39
file content (112 lines) | stat: -rw-r--r-- 3,224 bytes parent folder | download | duplicates (2)
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*
 * Copyright (C) 2009-2010 Big Muscle, http://strongdc.sourceforge.net/
 *
 * 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, see <https://www.gnu.org/licenses/>.
 */

#pragma once

#include "Constants.h"
#include "dcpp/CID.h"
#include "dcpp/Client.h"
#include "dcpp/MerkleTree.h"
#include "dcpp/Pointer.h"
#include "dcpp/SimpleXML.h"
#include "dcpp/TimerManager.h"
#include "dcpp/User.h"

namespace dht
{
    struct UDPKey
    {
        string  ip;
        CID     key;
    };

    struct Node :
        public OnlineUser
    {
        typedef dcpp::intrusive_ptr<Node> Ptr;
        typedef std::map<CID, Node::Ptr> Map;

        Node(const UserPtr& u);
        ~Node() throw() {}

        uint8_t getType() const { return type; }
        bool isIpVerified() const { return ipVerified; }

        bool isOnline() const { return online; }
        void setOnline(bool _online) { online = _online; }

        void setAlive();
        void setIpVerified(bool verified) { ipVerified = verified; }
        void setTimeout(uint64_t now = GET_TICK());

        CID getUdpKey() const;
        void setUdpKey(const CID& _key);
        const UDPKey& getUDPKey() const { return key; }

    private:

        friend class KBucket;

        UDPKey      key;

        uint64_t    created;
        uint64_t    expires;
        uint8_t     type;
        bool        ipVerified;
        bool        online; // getUser()->isOnline() returns true when node is online in any hub, we need info when he is online in DHT
    };

    class KBucket
    {
    public:
        KBucket(void);
        ~KBucket(void);

        typedef std::deque<Node::Ptr> NodeList;

        /** Creates new (or update existing) node which is NOT added to our routing table */
        Node::Ptr createNode(const UserPtr& u, const string& ip, const std::string &port, bool update, bool isUdpKeyValid);

        /** Adds node to routing table */
        bool insert(const Node::Ptr& node);

        /** Finds "max" closest nodes and stores them to the list */
        void getClosestNodes(const CID& cid, Node::Map& closest, unsigned int max, uint8_t maxType) const;

        /** Return list of all nodes in this bucket */
        const NodeList& getNodes() const { return nodes; }

        /** Removes dead nodes */
        bool checkExpiration(uint64_t currentTime);

        /** Loads existing nodes from disk */
        void loadNodes(SimpleXML& xml);

        /** Save bootstrap nodes to disk */
        void saveNodes(SimpleXML& xml);

    private:

        /** List of nodes in this bucket */
        NodeList nodes;

        /** List of known IPs in this bucket */
        StringSet ipMap;

    };

}