Work on gossip system and tor transport
This commit is contained in:
parent
2bcfbf0d79
commit
15875d26c6
@ -12,6 +12,7 @@ import onionrplugins
|
|||||||
|
|
||||||
from .client import gossip_client
|
from .client import gossip_client
|
||||||
from .server import gossip_server
|
from .server import gossip_server
|
||||||
|
from .commands import GossipCommands
|
||||||
"""
|
"""
|
||||||
Onionr uses a flavor of Dandelion++ epidemic routing
|
Onionr uses a flavor of Dandelion++ epidemic routing
|
||||||
|
|
||||||
|
8
static-data/default-plugins/tor/getsocks.py
Normal file
8
static-data/default-plugins/tor/getsocks.py
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
from stem.control import Controller
|
||||||
|
|
||||||
|
from .torfilepaths import control_socket
|
||||||
|
|
||||||
|
|
||||||
|
def get_socks():
|
||||||
|
with Controller.from_socket_file(control_socket) as controller:
|
||||||
|
return controller.get_listeners('SOCKS')
|
@ -6,6 +6,7 @@ This default plugin handles "flow" messages
|
|||||||
import sys
|
import sys
|
||||||
import os
|
import os
|
||||||
import locale
|
import locale
|
||||||
|
import traceback
|
||||||
from typing import Set, TYPE_CHECKING
|
from typing import Set, TYPE_CHECKING
|
||||||
import base64
|
import base64
|
||||||
|
|
||||||
@ -24,7 +25,9 @@ locale.setlocale(locale.LC_ALL, '')
|
|||||||
sys.path.insert(0, os.path.dirname(os.path.realpath(__file__)))
|
sys.path.insert(0, os.path.dirname(os.path.realpath(__file__)))
|
||||||
# import after path insert
|
# import after path insert
|
||||||
import starttor
|
import starttor
|
||||||
|
from torpeer import TorPeer
|
||||||
from torfilepaths import control_socket
|
from torfilepaths import control_socket
|
||||||
|
from getsocks import get_socks
|
||||||
|
|
||||||
"""
|
"""
|
||||||
This program is free software: you can redistribute it and/or modify
|
This program is free software: you can redistribute it and/or modify
|
||||||
@ -58,14 +61,38 @@ def on_init(api, data=None):
|
|||||||
f"Tor Transport Plugin v{PLUGIN_VERSION} enabled", terminal=True)
|
f"Tor Transport Plugin v{PLUGIN_VERSION} enabled", terminal=True)
|
||||||
|
|
||||||
|
|
||||||
def on_gossip_start(api, data: Set[Peer] = None):
|
def on_bootstrap(api, data: Set[Peer] = None):
|
||||||
# We don't do gossip logic
|
bootstrap_nodes: Set[str]
|
||||||
|
peers = data
|
||||||
|
|
||||||
|
socks_address, socks_port = get_socks()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
with open(bootstrap_file, 'r') as bootstrap_file_obj:
|
with open(bootstrap_file, 'r') as bootstrap_file_obj:
|
||||||
bootstrap_nodes = set(bootstrap_file_obj.read().split(','))
|
bootstrap_nodes = set(bootstrap_file_obj.read().split(','))
|
||||||
except FileNotFoundError:
|
except FileNotFoundError:
|
||||||
bootstrap_nodes = set()
|
bootstrap_nodes = set()
|
||||||
|
|
||||||
|
for transport_address in bootstrap_nodes:
|
||||||
|
if not transport_address.endswith('.onion'):
|
||||||
|
transport_address += '.onion'
|
||||||
|
tor_peer = TorPeer(socks_address, socks_port, transport_address)
|
||||||
|
try:
|
||||||
|
s = tor_peer.get_socket()
|
||||||
|
except Exception as e:
|
||||||
|
logger.warn(
|
||||||
|
f"Could not connnect to Tor peer {transport_address} " +
|
||||||
|
"see logs for more info",
|
||||||
|
terminal=True)
|
||||||
|
logger.warn(traceback.format_exc())
|
||||||
|
continue
|
||||||
|
peers.add(tor_peer)
|
||||||
|
|
||||||
|
|
||||||
|
def on_gossip_start(api, data: Set[Peer] = None):
|
||||||
|
# We don't do gossip logic
|
||||||
|
|
||||||
|
|
||||||
starttor.start_tor()
|
starttor.start_tor()
|
||||||
|
|
||||||
with Controller.from_socket_file(control_socket) as controller:
|
with Controller.from_socket_file(control_socket) as controller:
|
||||||
|
Loading…
Reference in New Issue
Block a user