parent
a02ef70607
commit
97c9b7eaf6
|
@ -1,2 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
autopep8 --in-place --recursive src
|
|
|
@ -328,7 +328,6 @@ class testmode(object): # pylint: disable=too-few-public-methods
|
||||||
|
|
||||||
class command(object): # pylint: disable=too-few-public-methods
|
class command(object): # pylint: disable=too-few-public-methods
|
||||||
"""Decorator for API command method"""
|
"""Decorator for API command method"""
|
||||||
|
|
||||||
def __init__(self, *aliases):
|
def __init__(self, *aliases):
|
||||||
self.aliases = aliases
|
self.aliases = aliases
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,6 @@ from pybitmessage.defaults import (
|
||||||
|
|
||||||
class AddressGenerator(object):
|
class AddressGenerator(object):
|
||||||
""""Base class for address generation and validation"""
|
""""Base class for address generation and validation"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
|
@ -9,27 +9,6 @@ The PyBitmessage startup script
|
||||||
|
|
||||||
# Right now, PyBitmessage only support connecting to stream 1. It doesn't
|
# Right now, PyBitmessage only support connecting to stream 1. It doesn't
|
||||||
# yet contain logic to expand into further streams.
|
# yet contain logic to expand into further streams.
|
||||||
from threads import (
|
|
||||||
set_thread_name, printLock,
|
|
||||||
addressGenerator, objectProcessor, singleCleaner, singleWorker, sqlThread)
|
|
||||||
from singleinstance import singleinstance
|
|
||||||
from inventory import Inventory
|
|
||||||
from helper_startup import (
|
|
||||||
adjustHalfOpenConnectionsLimit, fixSocket, start_proxyconfig)
|
|
||||||
from debug import logger # this should go before any threads
|
|
||||||
from bmconfigparser import config
|
|
||||||
from testmode_init import populate_api_test_data
|
|
||||||
import state
|
|
||||||
import shutdown
|
|
||||||
import network
|
|
||||||
import defaults
|
|
||||||
import traceback
|
|
||||||
import time
|
|
||||||
import threading
|
|
||||||
import signal
|
|
||||||
import multiprocessing
|
|
||||||
import getopt
|
|
||||||
import depends
|
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
@ -39,13 +18,34 @@ except ImportError:
|
||||||
from pybitmessage import pathmagic
|
from pybitmessage import pathmagic
|
||||||
app_dir = pathmagic.setup()
|
app_dir = pathmagic.setup()
|
||||||
|
|
||||||
|
import depends
|
||||||
depends.check_dependencies()
|
depends.check_dependencies()
|
||||||
|
|
||||||
|
import getopt
|
||||||
|
import multiprocessing
|
||||||
# Used to capture a Ctrl-C keypress so that Bitmessage can shutdown gracefully.
|
# Used to capture a Ctrl-C keypress so that Bitmessage can shutdown gracefully.
|
||||||
|
import signal
|
||||||
|
import threading
|
||||||
|
import time
|
||||||
|
import traceback
|
||||||
|
|
||||||
|
import defaults
|
||||||
# Network subsystem
|
# Network subsystem
|
||||||
|
import network
|
||||||
|
import shutdown
|
||||||
|
import state
|
||||||
|
|
||||||
|
from testmode_init import populate_api_test_data
|
||||||
|
from bmconfigparser import config
|
||||||
|
from debug import logger # this should go before any threads
|
||||||
|
from helper_startup import (
|
||||||
|
adjustHalfOpenConnectionsLimit, fixSocket, start_proxyconfig)
|
||||||
|
from inventory import Inventory
|
||||||
|
from singleinstance import singleinstance
|
||||||
# Synchronous threads
|
# Synchronous threads
|
||||||
|
from threads import (
|
||||||
|
set_thread_name, printLock,
|
||||||
|
addressGenerator, objectProcessor, singleCleaner, singleWorker, sqlThread)
|
||||||
|
|
||||||
|
|
||||||
def signal_handler(signum, frame):
|
def signal_handler(signum, frame):
|
||||||
|
@ -81,7 +81,6 @@ def signal_handler(signum, frame):
|
||||||
|
|
||||||
class Main(object):
|
class Main(object):
|
||||||
"""Main PyBitmessage class"""
|
"""Main PyBitmessage class"""
|
||||||
|
|
||||||
def start(self):
|
def start(self):
|
||||||
"""Start main application"""
|
"""Start main application"""
|
||||||
# pylint: disable=too-many-statements,too-many-branches,too-many-locals
|
# pylint: disable=too-many-statements,too-many-branches,too-many-locals
|
||||||
|
|
|
@ -128,7 +128,7 @@ class BMConfigParser(SafeConfigParser):
|
||||||
shutil.copyfile(fileName, fileNameBak)
|
shutil.copyfile(fileName, fileNameBak)
|
||||||
# The backup succeeded.
|
# The backup succeeded.
|
||||||
fileNameExisted = True
|
fileNameExisted = True
|
||||||
except (IOError, Exception):
|
except(IOError, Exception):
|
||||||
# The backup failed. This can happen if the file
|
# The backup failed. This can happen if the file
|
||||||
# didn't exist before.
|
# didn't exist before.
|
||||||
fileNameExisted = False
|
fileNameExisted = False
|
||||||
|
|
|
@ -43,7 +43,6 @@ class objectProcessor(threading.Thread):
|
||||||
The objectProcessor thread, of which there is only one, receives network
|
The objectProcessor thread, of which there is only one, receives network
|
||||||
objects (msg, broadcast, pubkey, getpubkey) from the receiveDataThreads.
|
objects (msg, broadcast, pubkey, getpubkey) from the receiveDataThreads.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
threading.Thread.__init__(self, name="objectProcessor")
|
threading.Thread.__init__(self, name="objectProcessor")
|
||||||
random.seed()
|
random.seed()
|
||||||
|
|
|
@ -35,7 +35,6 @@ class SmtpServerChannelException(Exception):
|
||||||
|
|
||||||
class smtpServerChannel(smtpd.SMTPChannel):
|
class smtpServerChannel(smtpd.SMTPChannel):
|
||||||
"""Asyncore channel for SMTP protocol (server)"""
|
"""Asyncore channel for SMTP protocol (server)"""
|
||||||
|
|
||||||
def smtp_EHLO(self, arg):
|
def smtp_EHLO(self, arg):
|
||||||
"""Process an EHLO"""
|
"""Process an EHLO"""
|
||||||
if not arg:
|
if not arg:
|
||||||
|
@ -74,7 +73,6 @@ class smtpServerChannel(smtpd.SMTPChannel):
|
||||||
|
|
||||||
class smtpServerPyBitmessage(smtpd.SMTPServer):
|
class smtpServerPyBitmessage(smtpd.SMTPServer):
|
||||||
"""Asyncore SMTP server class"""
|
"""Asyncore SMTP server class"""
|
||||||
|
|
||||||
def handle_accept(self):
|
def handle_accept(self):
|
||||||
"""Accept a connection"""
|
"""Accept a connection"""
|
||||||
pair = self.accept()
|
pair = self.accept()
|
||||||
|
@ -182,7 +180,6 @@ class smtpServerPyBitmessage(smtpd.SMTPServer):
|
||||||
|
|
||||||
class smtpServer(StoppableThread):
|
class smtpServer(StoppableThread):
|
||||||
"""SMTP server thread"""
|
"""SMTP server thread"""
|
||||||
|
|
||||||
def __init__(self, _=None):
|
def __init__(self, _=None):
|
||||||
super(smtpServer, self).__init__(name="smtpServerThread")
|
super(smtpServer, self).__init__(name="smtpServerThread")
|
||||||
self.server = smtpServerPyBitmessage(('127.0.0.1', LISTENPORT), None)
|
self.server = smtpServerPyBitmessage(('127.0.0.1', LISTENPORT), None)
|
||||||
|
|
|
@ -436,7 +436,7 @@ def check_dependencies(verbose=False, optional=False):
|
||||||
if sys.hexversion < 0x3000000:
|
if sys.hexversion < 0x3000000:
|
||||||
logger.error(
|
logger.error(
|
||||||
'PyBitmessage requires Python 3 or greater')
|
'PyBitmessage requires Python 3 or greater')
|
||||||
# has_all_dependencies = False
|
#has_all_dependencies = False
|
||||||
sys.exit()
|
sys.exit()
|
||||||
|
|
||||||
# FIXME: This needs to be uncommented when more of the code is python3 compatible
|
# FIXME: This needs to be uncommented when more of the code is python3 compatible
|
||||||
|
|
|
@ -37,14 +37,12 @@ class MsgDecodeException(Exception):
|
||||||
class DecompressionSizeException(MsgDecodeException):
|
class DecompressionSizeException(MsgDecodeException):
|
||||||
# pylint: disable=super-init-not-called
|
# pylint: disable=super-init-not-called
|
||||||
"""Decompression resulted in too much data (attack protection)"""
|
"""Decompression resulted in too much data (attack protection)"""
|
||||||
|
|
||||||
def __init__(self, size):
|
def __init__(self, size):
|
||||||
self.size = size
|
self.size = size
|
||||||
|
|
||||||
|
|
||||||
class MsgEncode(object):
|
class MsgEncode(object):
|
||||||
"""Message encoder class"""
|
"""Message encoder class"""
|
||||||
|
|
||||||
def __init__(self, message, encoding=BITMESSAGE_ENCODING_SIMPLE):
|
def __init__(self, message, encoding=BITMESSAGE_ENCODING_SIMPLE):
|
||||||
self.data = None
|
self.data = None
|
||||||
self.encoding = encoding
|
self.encoding = encoding
|
||||||
|
@ -88,7 +86,6 @@ class MsgEncode(object):
|
||||||
|
|
||||||
class MsgDecode(object):
|
class MsgDecode(object):
|
||||||
"""Message decoder class"""
|
"""Message decoder class"""
|
||||||
|
|
||||||
def __init__(self, encoding, data):
|
def __init__(self, encoding, data):
|
||||||
self.encoding = encoding
|
self.encoding = encoding
|
||||||
if self.encoding == BITMESSAGE_ENCODING_EXTENDED:
|
if self.encoding == BITMESSAGE_ENCODING_EXTENDED:
|
||||||
|
|
|
@ -21,7 +21,6 @@ class Inventory:
|
||||||
Inventory class which uses storage backends
|
Inventory class which uses storage backends
|
||||||
to manage the inventory.
|
to manage the inventory.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self._moduleName = config.safeGet("inventory", "storage")
|
self._moduleName = config.safeGet("inventory", "storage")
|
||||||
self._realInventory = create_inventory_instance(self._moduleName)
|
self._realInventory = create_inventory_instance(self._moduleName)
|
||||||
|
|
|
@ -5,7 +5,6 @@ logger = logging.getLogger('default')
|
||||||
|
|
||||||
class MsgBase(object): # pylint: disable=too-few-public-methods
|
class MsgBase(object): # pylint: disable=too-few-public-methods
|
||||||
"""Base class for message types"""
|
"""Base class for message types"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.data = {"": type(self).__name__.lower()}
|
self.data = {"": type(self).__name__.lower()}
|
||||||
|
|
||||||
|
|
|
@ -564,12 +564,12 @@ class dispatcher(object):
|
||||||
try:
|
try:
|
||||||
kqueue_poller.pollster.control([select.kevent(
|
kqueue_poller.pollster.control([select.kevent(
|
||||||
fd, select.KQ_FILTER_READ, select.KQ_EV_DELETE)], 0)
|
fd, select.KQ_FILTER_READ, select.KQ_EV_DELETE)], 0)
|
||||||
except (AttributeError, KeyError, TypeError, IOError, OSError):
|
except(AttributeError, KeyError, TypeError, IOError, OSError):
|
||||||
pass
|
pass
|
||||||
try:
|
try:
|
||||||
kqueue_poller.pollster.control([select.kevent(
|
kqueue_poller.pollster.control([select.kevent(
|
||||||
fd, select.KQ_FILTER_WRITE, select.KQ_EV_DELETE)], 0)
|
fd, select.KQ_FILTER_WRITE, select.KQ_EV_DELETE)], 0)
|
||||||
except (AttributeError, KeyError, TypeError, IOError, OSError):
|
except(AttributeError, KeyError, TypeError, IOError, OSError):
|
||||||
pass
|
pass
|
||||||
try:
|
try:
|
||||||
epoll_poller.pollster.unregister(fd)
|
epoll_poller.pollster.unregister(fd)
|
||||||
|
@ -726,7 +726,7 @@ class dispatcher(object):
|
||||||
# XXX unresolved
|
# XXX unresolved
|
||||||
# cheap inheritance, used to pass all other attribute
|
# cheap inheritance, used to pass all other attribute
|
||||||
# references to the underlying socket object.
|
# references to the underlying socket object.
|
||||||
# def __getattr__(self, attr):
|
#def __getattr__(self, attr):
|
||||||
# try:
|
# try:
|
||||||
# retattr = getattr(self.socket, attr)
|
# retattr = getattr(self.socket, attr)
|
||||||
# except AttributeError:
|
# except AttributeError:
|
||||||
|
|
|
@ -28,7 +28,6 @@ logger = logging.getLogger('default')
|
||||||
|
|
||||||
class Dandelion: # pylint: disable=old-style-class
|
class Dandelion: # pylint: disable=old-style-class
|
||||||
"""Dandelion class for tracking stem/fluff stages."""
|
"""Dandelion class for tracking stem/fluff stages."""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
# currently assignable child stems
|
# currently assignable child stems
|
||||||
self.stem = []
|
self.stem = []
|
||||||
|
|
|
@ -69,7 +69,6 @@ class HTTPRequestHandler(asyncore.dispatcher):
|
||||||
|
|
||||||
class HTTPSRequestHandler(HTTPRequestHandler, TLSHandshake):
|
class HTTPSRequestHandler(HTTPRequestHandler, TLSHandshake):
|
||||||
"""Handling HTTPS request"""
|
"""Handling HTTPS request"""
|
||||||
|
|
||||||
def __init__(self, sock):
|
def __init__(self, sock):
|
||||||
if not hasattr(self, '_map'):
|
if not hasattr(self, '_map'):
|
||||||
asyncore.dispatcher.__init__(self, sock) # pylint: disable=non-parent-init-called
|
asyncore.dispatcher.__init__(self, sock) # pylint: disable=non-parent-init-called
|
||||||
|
|
|
@ -102,7 +102,7 @@ class ObjectTracker(object):
|
||||||
|
|
||||||
def handleReceivedObject(self, streamNumber, hashid):
|
def handleReceivedObject(self, streamNumber, hashid):
|
||||||
"""Handling received object"""
|
"""Handling received object"""
|
||||||
hashid_bytes = bytes(hashid)
|
hashid_bytes = bytes(hashid);
|
||||||
for i in connectionpool.pool.connections():
|
for i in connectionpool.pool.connections():
|
||||||
if not i.fullyEstablished:
|
if not i.fullyEstablished:
|
||||||
continue
|
continue
|
||||||
|
|
|
@ -15,7 +15,6 @@ from .threads import StoppableThread
|
||||||
class ReceiveQueueThread(StoppableThread):
|
class ReceiveQueueThread(StoppableThread):
|
||||||
"""This thread processes data received from the network
|
"""This thread processes data received from the network
|
||||||
(which is done by the asyncore thread)"""
|
(which is done by the asyncore thread)"""
|
||||||
|
|
||||||
def __init__(self, num=0):
|
def __init__(self, num=0):
|
||||||
super(ReceiveQueueThread, self).__init__(name="ReceiveQueue_%i" % num)
|
super(ReceiveQueueThread, self).__init__(name="ReceiveQueue_%i" % num)
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,6 @@ class Socks4aError(ProxyError):
|
||||||
|
|
||||||
class Socks4a(Proxy):
|
class Socks4a(Proxy):
|
||||||
"""SOCKS4a proxy class"""
|
"""SOCKS4a proxy class"""
|
||||||
|
|
||||||
def __init__(self, address=None):
|
def __init__(self, address=None):
|
||||||
Proxy.__init__(self, address)
|
Proxy.__init__(self, address)
|
||||||
self.ipaddr = None
|
self.ipaddr = None
|
||||||
|
@ -74,7 +73,6 @@ class Socks4a(Proxy):
|
||||||
|
|
||||||
class Socks4aConnection(Socks4a):
|
class Socks4aConnection(Socks4a):
|
||||||
"""Child SOCKS4a class used for making outbound connections."""
|
"""Child SOCKS4a class used for making outbound connections."""
|
||||||
|
|
||||||
def __init__(self, address):
|
def __init__(self, address):
|
||||||
Socks4a.__init__(self, address=address)
|
Socks4a.__init__(self, address=address)
|
||||||
|
|
||||||
|
@ -121,7 +119,6 @@ class Socks4aConnection(Socks4a):
|
||||||
|
|
||||||
class Socks4aResolver(Socks4a):
|
class Socks4aResolver(Socks4a):
|
||||||
"""DNS resolver class using SOCKS4a"""
|
"""DNS resolver class using SOCKS4a"""
|
||||||
|
|
||||||
def __init__(self, host):
|
def __init__(self, host):
|
||||||
self.host = host
|
self.host = host
|
||||||
self.port = 8444
|
self.port = 8444
|
||||||
|
|
|
@ -42,7 +42,6 @@ class Socks5Error(ProxyError):
|
||||||
|
|
||||||
class Socks5(Proxy):
|
class Socks5(Proxy):
|
||||||
"""A socks5 proxy base class"""
|
"""A socks5 proxy base class"""
|
||||||
|
|
||||||
def __init__(self, address=None):
|
def __init__(self, address=None):
|
||||||
Proxy.__init__(self, address)
|
Proxy.__init__(self, address)
|
||||||
self.ipaddr = None
|
self.ipaddr = None
|
||||||
|
@ -164,7 +163,6 @@ class Socks5(Proxy):
|
||||||
|
|
||||||
class Socks5Connection(Socks5):
|
class Socks5Connection(Socks5):
|
||||||
"""Child socks5 class used for making outbound connections."""
|
"""Child socks5 class used for making outbound connections."""
|
||||||
|
|
||||||
def state_auth_done(self):
|
def state_auth_done(self):
|
||||||
"""Request connection to be made"""
|
"""Request connection to be made"""
|
||||||
# Now we can request the actual connection
|
# Now we can request the actual connection
|
||||||
|
@ -201,7 +199,6 @@ class Socks5Connection(Socks5):
|
||||||
|
|
||||||
class Socks5Resolver(Socks5):
|
class Socks5Resolver(Socks5):
|
||||||
"""DNS resolver class using socks5"""
|
"""DNS resolver class using socks5"""
|
||||||
|
|
||||||
def __init__(self, host):
|
def __init__(self, host):
|
||||||
self.host = host
|
self.host = host
|
||||||
self.port = 8444
|
self.port = 8444
|
||||||
|
|
|
@ -40,12 +40,10 @@ if (
|
||||||
else:
|
else:
|
||||||
sslProtocolCiphers = "AECDH-AES256-SHA"
|
sslProtocolCiphers = "AECDH-AES256-SHA"
|
||||||
|
|
||||||
|
|
||||||
class TLSDispatcher(AdvancedDispatcher):
|
class TLSDispatcher(AdvancedDispatcher):
|
||||||
"""TLS functionality for classes derived from AdvancedDispatcher"""
|
"""TLS functionality for classes derived from AdvancedDispatcher"""
|
||||||
# pylint: disable=too-many-instance-attributes, too-many-arguments
|
# pylint: disable=too-many-instance-attributes, too-many-arguments
|
||||||
# pylint: disable=super-init-not-called
|
# pylint: disable=super-init-not-called
|
||||||
|
|
||||||
def __init__(self, _=None, sock=None, certfile=None, keyfile=None,
|
def __init__(self, _=None, sock=None, certfile=None, keyfile=None,
|
||||||
server_side=False, ciphers=sslProtocolCiphers):
|
server_side=False, ciphers=sslProtocolCiphers):
|
||||||
self.want_read = self.want_write = True
|
self.want_read = self.want_write = True
|
||||||
|
|
|
@ -22,7 +22,6 @@ class Cipher(object):
|
||||||
ctx2 = pyelliptic.Cipher("secretkey", iv, 0, ciphername='aes-256-cfb')
|
ctx2 = pyelliptic.Cipher("secretkey", iv, 0, ciphername='aes-256-cfb')
|
||||||
print ctx2.ciphering(ciphertext)
|
print ctx2.ciphering(ciphertext)
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, key, iv, do, ciphername='aes-256-cbc'):
|
def __init__(self, key, iv, do, ciphername='aes-256-cbc'):
|
||||||
"""
|
"""
|
||||||
do == 1 => Encrypt; do == 0 => Decrypt
|
do == 1 => Encrypt; do == 0 => Decrypt
|
||||||
|
|
|
@ -100,7 +100,6 @@ class _OpenSSL(object):
|
||||||
Wrapper for OpenSSL using ctypes
|
Wrapper for OpenSSL using ctypes
|
||||||
"""
|
"""
|
||||||
# pylint: disable=too-many-statements, too-many-instance-attributes
|
# pylint: disable=too-many-statements, too-many-instance-attributes
|
||||||
|
|
||||||
def __init__(self, library):
|
def __init__(self, library):
|
||||||
"""
|
"""
|
||||||
Build the wrapper
|
Build the wrapper
|
||||||
|
|
|
@ -43,7 +43,6 @@ Returns an instance of :class:`QPixmap` which have generated identicon image.
|
||||||
from six.moves import range
|
from six.moves import range
|
||||||
from PyQt6 import QtCore, QtGui
|
from PyQt6 import QtCore, QtGui
|
||||||
|
|
||||||
|
|
||||||
class IdenticonRendererBase(object):
|
class IdenticonRendererBase(object):
|
||||||
"""Encapsulate methods around rendering identicons"""
|
"""Encapsulate methods around rendering identicons"""
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@ class singleinstance(object):
|
||||||
Implements a single instance application by creating a lock file
|
Implements a single instance application by creating a lock file
|
||||||
at appdata.
|
at appdata.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, flavor_id="", daemon=False):
|
def __init__(self, flavor_id="", daemon=False):
|
||||||
self.initialized = False
|
self.initialized = False
|
||||||
self.counter = 0
|
self.counter = 0
|
||||||
|
|
|
@ -11,7 +11,6 @@ from .storage import InventoryItem, InventoryStorage
|
||||||
|
|
||||||
class SqliteInventory(InventoryStorage):
|
class SqliteInventory(InventoryStorage):
|
||||||
"""Inventory using SQLite"""
|
"""Inventory using SQLite"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super(SqliteInventory, self).__init__()
|
super(SqliteInventory, self).__init__()
|
||||||
# of objects (like msg payloads and pubkey payloads)
|
# of objects (like msg payloads and pubkey payloads)
|
||||||
|
|
|
@ -15,7 +15,6 @@ class translateClass:
|
||||||
when we are in daemon mode and not using any QT functions.
|
when we are in daemon mode and not using any QT functions.
|
||||||
"""
|
"""
|
||||||
# pylint: disable=old-style-class,too-few-public-methods
|
# pylint: disable=old-style-class,too-few-public-methods
|
||||||
|
|
||||||
def __init__(self, context, text):
|
def __init__(self, context, text):
|
||||||
self.context = context
|
self.context = context
|
||||||
self.text = text
|
self.text = text
|
||||||
|
|
Reference in New Issue
Block a user