From aeec28d09c0d3d6dd79b41f322866f33e8e501ab Mon Sep 17 00:00:00 2001 From: Dmitri Bogomolov <4glitch@gmail.com> Date: Mon, 25 Jan 2021 19:07:48 +0200 Subject: [PATCH] Move start of network threads to network package, reduce exported symbols and imports. --- src/bitmessagemain.py | 90 ++++++++++++++--------------------------- src/network/__init__.py | 47 ++++++++++++++++----- 2 files changed, 68 insertions(+), 69 deletions(-) diff --git a/src/bitmessagemain.py b/src/bitmessagemain.py index 6f18da69..370b1e1d 100755 --- a/src/bitmessagemain.py +++ b/src/bitmessagemain.py @@ -42,11 +42,7 @@ from helper_startup import ( adjustHalfOpenConnectionsLimit, start_proxyconfig) from inventory import Inventory # Network objects and threads -from network import ( - BMConnectionPool, Dandelion, AddrThread, AnnounceThread, BMNetworkThread, - InvThread, ReceiveQueueThread, DownloadThread, UploadThread -) -from network.knownnodes import readKnownNodes +import network from singleinstance import singleinstance # Synchronous threads from threads import ( @@ -238,8 +234,18 @@ class Main(object): defaults.networkDefaultPayloadLengthExtraBytes = int( defaults.networkDefaultPayloadLengthExtraBytes / 100) - # Not needed if objproc is disabled - if state.enableObjProc: + # Start the SQL thread + sqlLookup = sqlThread() + # DON'T close the main program even if there are threads left. + # The closeEvent should command this thread to exit gracefully. + sqlLookup.daemon = False + sqlLookup.start() + + Inventory() # init + + if state.enableObjProc: # Not needed if objproc is disabled + shared.reloadMyAddressHashes() + shared.reloadBroadcastSendersForWhichImWatching() # Start the address generation thread addressGeneratorThread = addressGenerator() @@ -253,19 +259,13 @@ class Main(object): singleWorkerThread.daemon = True singleWorkerThread.start() - # Start the SQL thread - sqlLookup = sqlThread() - # DON'T close the main program even if there are threads left. - # The closeEvent should command this thread to exit gracefully. - sqlLookup.daemon = False - sqlLookup.start() - - Inventory() # init - # init, needs to be early because other thread may access it early - Dandelion() - - # Enable object processor and SMTP only if objproc enabled - if state.enableObjProc: + # Start the thread that calculates POWs + objectProcessorThread = objectProcessor() + # DON'T close the main program even the thread remains. + # This thread checks the shutdown variable after processing + # each object. + objectProcessorThread.daemon = False + objectProcessorThread.start() # SMTP delivery thread if daemon and config.safeGet( @@ -281,25 +281,6 @@ class Main(object): smtpServerThread = smtpServer() smtpServerThread.start() - # Start the thread that calculates POWs - objectProcessorThread = objectProcessor() - # DON'T close the main program even the thread remains. - # This thread checks the shutdown variable after processing - # each object. - objectProcessorThread.daemon = False - objectProcessorThread.start() - - # Start the cleanerThread - singleCleanerThread = singleCleaner() - # close the main program even if there are threads left - singleCleanerThread.daemon = True - singleCleanerThread.start() - - # Not needed if objproc disabled - if state.enableObjProc: - shared.reloadMyAddressHashes() - shared.reloadBroadcastSendersForWhichImWatching() - # API is also objproc dependent if config.safeGetBoolean('bitmessagesettings', 'apienabled'): import api # pylint: disable=relative-import @@ -308,35 +289,26 @@ class Main(object): singleAPIThread.daemon = True singleAPIThread.start() + # Start the cleanerThread + singleCleanerThread = singleCleaner() + # close the main program even if there are threads left + singleCleanerThread.daemon = True + singleCleanerThread.start() + # start network components if networking is enabled if state.enableNetwork: - readKnownNodes() start_proxyconfig() - BMConnectionPool().connectToStream(1) - asyncoreThread = BMNetworkThread() - asyncoreThread.daemon = True - asyncoreThread.start() + network.start() + + # Optional components for i in range(config.getint('threads', 'receive')): - receiveQueueThread = ReceiveQueueThread(i) + receiveQueueThread = network.ReceiveQueueThread(i) receiveQueueThread.daemon = True receiveQueueThread.start() if config.safeGetBoolean('bitmessagesettings', 'udp'): - state.announceThread = AnnounceThread() + state.announceThread = network.AnnounceThread() state.announceThread.daemon = True state.announceThread.start() - state.invThread = InvThread() - state.invThread.daemon = True - state.invThread.start() - state.addrThread = AddrThread() - state.addrThread.daemon = True - state.addrThread.start() - state.downloadThread = DownloadThread() - state.downloadThread.daemon = True - state.downloadThread.start() - state.uploadThread = UploadThread() - state.uploadThread.daemon = True - state.uploadThread.start() - if config.safeGetBoolean('bitmessagesettings', 'upnp'): import upnp upnpThread = upnp.uPnPThread() diff --git a/src/network/__init__.py b/src/network/__init__.py index 70613539..ab1e3170 100644 --- a/src/network/__init__.py +++ b/src/network/__init__.py @@ -1,20 +1,47 @@ """ -Network subsystem packages +Network subsystem package """ -from addrthread import AddrThread + from announcethread import AnnounceThread from connectionpool import BMConnectionPool -from dandelion import Dandelion -from downloadthread import DownloadThread -from invthread import InvThread -from networkthread import BMNetworkThread from receivequeuethread import ReceiveQueueThread from threads import StoppableThread -from uploadthread import UploadThread __all__ = [ - "BMConnectionPool", "Dandelion", - "AddrThread", "AnnounceThread", "BMNetworkThread", "DownloadThread", - "InvThread", "ReceiveQueueThread", "UploadThread", "StoppableThread" + "AnnounceThread", "BMConnectionPool", + "ReceiveQueueThread", "StoppableThread" + # "AddrThread", "AnnounceThread", "BMNetworkThread", "Dandelion", + # "DownloadThread", "InvThread", "UploadThread", ] + + +def start(): + """Start network threads""" + from addrthread import AddrThread + from dandelion import Dandelion + from downloadthread import DownloadThread + from invthread import InvThread + from networkthread import BMNetworkThread + from knownnodes import readKnownNodes + from uploadthread import UploadThread + + readKnownNodes() + # init, needs to be early because other thread may access it early + Dandelion() + BMConnectionPool().connectToStream(1) + asyncoreThread = BMNetworkThread() + asyncoreThread.daemon = True + asyncoreThread.start() + invThread = InvThread() + invThread.daemon = True + invThread.start() + addrThread = AddrThread() + addrThread.daemon = True + addrThread.start() + downloadThread = DownloadThread() + downloadThread.daemon = True + downloadThread.start() + uploadThread = UploadThread() + uploadThread.daemon = True + uploadThread.start()