This repository has been archived on 2024-12-26. You can view files and clone it, but cannot push or open issues or pull requests.
PyBitmessage-2024-12-26/src/state.py

134 lines
3.0 KiB
Python
Raw Normal View History

2019-09-20 13:19:04 +02:00
"""
2019-12-26 16:56:04 +01:00
src/state.py
=================================
2019-09-20 13:19:04 +02:00
"""
import collections
neededPubkeys = {}
streamsInWhichIAmParticipating = []
2019-12-26 16:56:04 +01:00
# For UPnP
extPort = None
2019-12-26 16:56:04 +01:00
# for Tor hidden service
socksIP = None
2019-12-26 16:56:04 +01:00
# Network protocols availability, initialised below
networkProtocolAvailability = None
appdata = '' # holds the location of the application data storage directory
# Set to 1 by the doCleanShutdown function.
# Used to tell the proof of work worker threads to exit.
2018-04-18 12:34:12 +02:00
shutdown = 0
2018-04-09 06:38:48 +02:00
# Component control flags - set on startup, do not change during runtime
# The defaults are for standalone GUI (default operating mode)
2019-12-26 16:56:04 +01:00
enableNetwork = True # enable network threads
enableObjProc = True # enable object processing threads
enableAPI = True # enable API (if configured)
enableGUI = True # enable GUI (QT or ncurses)
enableSTDIO = False # enable STDIO threads
2017-02-02 15:48:56 +01:00
curses = False
2019-12-26 16:56:04 +01:00
sqlReady = False # set to true by sqlTread when ready for processing
maximumNumberOfHalfOpenConnections = 0
maximumLengthOfTimeToBotherResendingMessages = 0
invThread = None
addrThread = None
downloadThread = None
uploadThread = None
ownAddresses = {}
# If the trustedpeer option is specified in keys.dat then this will
# contain a Peer which will be connected to instead of using the
# addresses advertised by other peers. The client will only connect to
# this peer and the timing attack mitigation will be disabled in order
# to download data faster. The expected use case is where the user has
# a fast connection to a trusted server where they run a BitMessage
# daemon permanently. If they then run a second instance of the client
# on a local machine periodically when they want to check for messages
# it will sync with the network a lot faster without compromising
# security.
trustedPeer = None
discoveredPeers = {}
Peer = collections.namedtuple('Peer', ['host', 'port'])
2017-01-12 19:18:56 +01:00
2019-09-20 13:19:04 +02:00
def resetNetworkProtocolAvailability():
"""This method helps to reset the availability of network protocol"""
# pylint: disable=global-statement
global networkProtocolAvailability
networkProtocolAvailability = {'IPv4': None, 'IPv6': None, 'onion': None}
resetNetworkProtocolAvailability()
dandelion = 0
testmode = False
kivy = False
association = ''
kivyapp = None
navinstance = None
mail_id = 0
2019-06-06 15:48:20 +02:00
myAddressObj = None
2019-06-06 15:48:20 +02:00
detailPageType = None
ackdata = None
status = None
screen_density = None
msg_counter_objs = None
check_sent_acc = None
sent_count = 0
inbox_count = 0
trash_count = 0
draft_count = 0
all_count = 0
searcing_text = ''
search_screen = ''
send_draft_mail = None
2019-09-11 17:03:51 +02:00
is_allmail = False
in_composer = False
2019-09-17 15:38:05 +02:00
availabe_credit = 0
2019-12-12 15:38:07 +01:00
in_sent_method = False
2019-12-30 13:10:02 +01:00
in_search_mode = False
2020-06-10 12:16:16 +02:00
clientHasReceivedIncomingConnections = False
"""used by API command clientStatus"""
numberOfMessagesProcessed = 0
numberOfBroadcastsProcessed = 0
numberOfPubkeysProcessed = 0
statusIconColor = 'red'
"""
GUI status icon color
.. note:: bad style, refactor it
"""
ackdataForWhichImWatching = {}
thisapp = None
"""Singleton instance"""
imageDir = None