work on lan
This commit is contained in:
parent
a5983d32a4
commit
a52465a54f
13 changed files with 151 additions and 33 deletions
|
@ -4,9 +4,15 @@ LAN transport client thread
|
|||
"""
|
||||
from typing import List
|
||||
|
||||
import watchdog
|
||||
from requests.exceptions import ConnectionError
|
||||
|
||||
from onionrcrypto.cryptoutils.randomshuffle import random_shuffle
|
||||
from utils.bettersleep import better_sleep
|
||||
from onionrutils.basicrequests import do_post_request, do_get_request
|
||||
from threading import Thread
|
||||
from onionrblocks import BlockList
|
||||
from onionrblocks.blockimporter import import_block_from_data
|
||||
"""
|
||||
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
|
||||
|
@ -29,17 +35,46 @@ class Client:
|
|||
self.lookup_time = {}
|
||||
self.poll_delay = 10
|
||||
|
||||
|
||||
def get_lookup_time(self, peer):
|
||||
try:
|
||||
return self.lookup_time[peer]
|
||||
except KeyError:
|
||||
return 0
|
||||
|
||||
def start(self):
|
||||
def peer_work(self, peer):
|
||||
port = 1024
|
||||
|
||||
self.peers.append(peer)
|
||||
for port in range(port, 65535):
|
||||
print(port)
|
||||
try:
|
||||
if do_get_request(f'http://{peer}:{port}/ping', proxyType='lan', ignoreAPI=True, connect_timeout=0.3) == 'onionr!':
|
||||
port = port
|
||||
print(f'{peer}:{port} found')
|
||||
break
|
||||
except (AttributeError, ConnectionError):
|
||||
pass
|
||||
else:
|
||||
self.peers.remove(peer)
|
||||
return
|
||||
self.peers.append(peer)
|
||||
|
||||
while True:
|
||||
self.peers = random_shuffle(self.peers)
|
||||
block_list = self._too_many.get(BlockList).get()
|
||||
last_time = self.get_lookup_time(peer)
|
||||
new_blocks = set('\n'.join(do_get_request(f'http://{peer}:{port}/blist/{last_time}', proxyType='lan', ignoreAPI=True))) ^ set(block_list)
|
||||
|
||||
for bl in new_blocks:
|
||||
import_block_from_data(
|
||||
do_get_request(
|
||||
f'http://{peer}:{port}/get/{bl}', proxyType='lan', ignoreAPI=True))
|
||||
better_sleep(10)
|
||||
self.peers.remove(peer)
|
||||
|
||||
|
||||
better_sleep(self.poll_delay)
|
||||
def connect_peer(self, peer):
|
||||
if peer in self.peers:
|
||||
return
|
||||
print(f'connecting to {peer}')
|
||||
Thread(target=self.peer_work, args=[peer], daemon=True).start()
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue