-
Notifications
You must be signed in to change notification settings - Fork 148
/
Copy pathget_hash_peers.py
50 lines (39 loc) · 1.49 KB
/
get_hash_peers.py
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
import logging
import time
import sys
from btdht import DHT
# Script that trying to find peers for magnet hash
# More configuration items in btdht/defines.py
current_magnet = "746385fe32b268d513d068f22c53c46d2eb34a5c".decode("hex")
# Enable logging at DEBUG level
loglevel = logging.DEBUG
formatter = logging.Formatter("[%(levelname)s@%(created)s] %(message)s")
stdout_handler = logging.StreamHandler()
stdout_handler.setFormatter(formatter)
logging.getLogger("btdht").setLevel(loglevel)
logging.getLogger("btdht").addHandler(stdout_handler)
logger = logging.getLogger(__name__)
logger.setLevel(loglevel)
logger.addHandler(stdout_handler)
if __name__ == "__main__":
# Start DHT Node on port 60000
dht = DHT(host='0.0.0.0', port=60000)
dht.start()
# Boostrap it
dht.bootstrap('router.bittorrent.com', 6881)
# Find me peers for that torrent hashes
dht.ht.add_hash(current_magnet)
res = []
for count in xrange(10):
logger.info("DHT Nodes found: %d" % (dht.rt.count()))
logger.info("Bad DHT nodes found: %d" % (dht.rt.bad_count()))
logger.info("Total peers found: %d" % (dht.ht.count_all_peers()))
# How many peers at this moment?
peers = dht.ht.get_hash_peers(current_magnet)
for peer in peers:
res.append((peer))
logger.info("Found peer: %s:%d" % (peer))
time.sleep(3)
logger.info("Found peers (total): %d" % (len(res)))
logger.info("Found peers (uniq): %d" % (len(set(res))))
dht.stop()