From b6a81f1252531ff6ebe5b6563e6f17778f905eba Mon Sep 17 00:00:00 2001 From: lakshyacis Date: Wed, 15 Jan 2020 16:17:26 +0530 Subject: [PATCH 1/7] Formatting and fix License --- LICENSE | 24 ++++++++++++++++++++++++ src/addresses.py | 2 +- src/bitmessagemain.py | 4 ++-- src/bmconfigparser.py | 6 ++++-- src/class_singleWorker.py | 3 ++- src/class_smtpDeliver.py | 8 +++++--- src/class_smtpServer.py | 6 ++++-- src/class_sqlThread.py | 2 +- src/depends.py | 3 ++- src/namecoin.py | 23 +---------------------- src/shared.py | 4 ++-- src/tr.py | 5 +++-- 12 files changed, 51 insertions(+), 39 deletions(-) diff --git a/LICENSE b/LICENSE index 2c718643..c2eeff82 100644 --- a/LICENSE +++ b/LICENSE @@ -68,3 +68,27 @@ CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +===== based on namecoin.py namecoin.py python implementation by Daniel Kraft + +Copyright (C) 2013 by Daniel Kraft + +This file is part of the Bitmessage project. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. \ No newline at end of file diff --git a/src/addresses.py b/src/addresses.py index bb0c9ec5..04e80383 100644 --- a/src/addresses.py +++ b/src/addresses.py @@ -180,7 +180,7 @@ def decodeAddress(address): returns (status, address version number, stream number, data (almost certainly a ripe hash)) """ - # pylint: disable=too-many-return-statements,too-many-statements,too-many-return-statements,too-many-branches + # pylint: disable=too-many-return-statements,too-many-statements,too-many-branches address = str(address).strip() diff --git a/src/bitmessagemain.py b/src/bitmessagemain.py index 48ed9738..17c08fc0 100755 --- a/src/bitmessagemain.py +++ b/src/bitmessagemain.py @@ -412,7 +412,7 @@ class Main(object): # wait until grandchild ready while True: time.sleep(1) - os._exit(0) # pylint: disable=protected-access + os._exit(0) # pylint: disable=protected-access except AttributeError: # fork not implemented pass @@ -433,7 +433,7 @@ class Main(object): # wait until child ready while True: time.sleep(1) - os._exit(0) # pylint: disable=protected-access + os._exit(0) # pylint: disable=protected-access except AttributeError: # fork not implemented pass diff --git a/src/bmconfigparser.py b/src/bmconfigparser.py index 1851144d..c08ba062 100644 --- a/src/bmconfigparser.py +++ b/src/bmconfigparser.py @@ -58,7 +58,8 @@ class BMConfigParser(ConfigParser.SafeConfigParser): raise ValueError("Invalid value %s" % value) return ConfigParser.ConfigParser.set(self, section, option, value) - def get(self, section, option, raw=False, variables=None): # pylint: disable=arguments-differ + def get(self, section, option, raw=False, variables=None): + # pylint: disable=arguments-differ try: if section == "bitmessagesettings" and option == "timeformat": return ConfigParser.ConfigParser.get( @@ -109,8 +110,9 @@ class BMConfigParser(ConfigParser.SafeConfigParser): ValueError, AttributeError): return default - def items(self, section, raw=False, variables=None): # pylint: disable=arguments-differ + def items(self, section, raw=False, variables=None): """Return section variables as parent, but override the "raw" argument to always True""" + # pylint: disable=arguments-differ return ConfigParser.ConfigParser.items(self, section, True, variables) @staticmethod diff --git a/src/class_singleWorker.py b/src/class_singleWorker.py index d035c092..e3f93ec6 100644 --- a/src/class_singleWorker.py +++ b/src/class_singleWorker.py @@ -1,7 +1,8 @@ """ Thread for performing PoW """ -# pylint: disable=protected-access,too-many-branches,too-many-statements,no-self-use,too-many-lines,too-many-locals +# pylint: disable=protected-access,too-many-branches,too-many-statements +# pylint: disable=no-self-use,too-many-lines,too-many-locals from __future__ import division diff --git a/src/class_smtpDeliver.py b/src/class_smtpDeliver.py index 14df14c9..4f8422cc 100644 --- a/src/class_smtpDeliver.py +++ b/src/class_smtpDeliver.py @@ -22,8 +22,9 @@ class smtpDeliver(StoppableThread): _instance = None def stopThread(self): + # pylint: disable=no-member try: - queues.UISignallerQueue.put(("stopThread", "data")) # pylint: disable=no-member + queues.UISignallerQueue.put(("stopThread", "data")) except: pass super(smtpDeliver, self).stopThread() @@ -37,6 +38,7 @@ class smtpDeliver(StoppableThread): def run(self): # pylint: disable=too-many-branches,too-many-statements,too-many-locals + # pylint: disable=deprecated-lambda while state.shutdown == 0: command, data = queues.UISignalQueue.get() if command == 'writeNewAddressToTable': @@ -59,9 +61,9 @@ class smtpDeliver(StoppableThread): msg = MIMEText(body, 'plain', 'utf-8') msg['Subject'] = Header(subject, 'utf-8') msg['From'] = fromAddress + '@' + SMTPDOMAIN - toLabel = map( # pylint: disable=deprecated-lambda + toLabel = map( lambda y: BMConfigParser().safeGet(y, "label"), - filter( # pylint: disable=deprecated-lambda + filter( lambda x: x == toAddress, BMConfigParser().addresses()) ) if toLabel: diff --git a/src/class_smtpServer.py b/src/class_smtpServer.py index cdf867a9..453ca640 100644 --- a/src/class_smtpServer.py +++ b/src/class_smtpServer.py @@ -76,8 +76,9 @@ class smtpServerPyBitmessage(smtpd.SMTPServer): # print >> DEBUGSTREAM, 'Incoming connection from %s' % repr(addr) self.channel = smtpServerChannel(self, conn, addr) - def send(self, fromAddress, toAddress, subject, message): # pylint: disable=arguments-differ + def send(self, fromAddress, toAddress, subject, message): """Send a bitmessage""" + # pylint: disable=arguments-differ streamNumber, ripe = decodeAddress(toAddress)[2:] stealthLevel = BMConfigParser().safeGetInt('bitmessagesettings', 'ackstealthlevel') ackdata = genAckPayload(streamNumber, stealthLevel) @@ -114,8 +115,9 @@ class smtpServerPyBitmessage(smtpd.SMTPServer): return ret - def process_message(self, peer, mailfrom, rcpttos, data): # pylint: disable=too-many-locals, too-many-branches + def process_message(self, peer, mailfrom, rcpttos, data): """Process an email""" + # pylint: disable=too-many-locals, too-many-branches # print 'Receiving message from:', peer p = re.compile(".*<([^>]+)>") if not hasattr(self.channel, "auth") or not self.channel.auth: diff --git a/src/class_sqlThread.py b/src/class_sqlThread.py index 3d59803c..78d70f79 100644 --- a/src/class_sqlThread.py +++ b/src/class_sqlThread.py @@ -27,7 +27,7 @@ class sqlThread(threading.Thread): def __init__(self): threading.Thread.__init__(self, name="SQL") - def run(self): # pylint: disable=too-many-locals, too-many-branches, too-many-statements + def run(self): # pylint: disable=too-many-locals, too-many-branches, too-many-statements """Process SQL queries from `.helper_sql.sqlSubmitQueue`""" self.conn = sqlite3.connect(state.appdata + 'messages.dat') self.conn.text_factory = str diff --git a/src/depends.py b/src/depends.py index 68fba01a..03e297f1 100755 --- a/src/depends.py +++ b/src/depends.py @@ -231,12 +231,13 @@ def check_sqlite(): conn.close() -def check_openssl(): # pylint: disable=too-many-branches, too-many-return-statements +def check_openssl(): """Do openssl dependency check. Here we are checking for openssl with its all dependent libraries and version checking. """ + # pylint: disable=too-many-branches, too-many-return-statements # pylint: disable=protected-access, redefined-outer-name ctypes = try_import('ctypes') if not ctypes: diff --git a/src/namecoin.py b/src/namecoin.py index c9238f63..63ca5653 100644 --- a/src/namecoin.py +++ b/src/namecoin.py @@ -1,28 +1,7 @@ -# pylint: disable=too-many-branches,protected-access """ -Copyright (C) 2013 by Daniel Kraft - Namecoin queries """ -# This file is part of the Bitmessage project. - -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to deal -# in the Software without restriction, including without limitation the rights -# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -# copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: - -# The above copyright notice and this permission notice shall be included in all -# copies or substantial portions of the Software. - -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -# SOFTWARE. +# pylint: disable=too-many-branches,protected-access import base64 import httplib diff --git a/src/shared.py b/src/shared.py index 90cea89d..dfc86ab6 100644 --- a/src/shared.py +++ b/src/shared.py @@ -118,7 +118,7 @@ def decodeWalletImportFormat(WIFstring): ' 6 characters of the PRIVATE key: %s', str(WIFstring)[:6] ) - os._exit(0) # pylint: disable=protected-access + os._exit(0) # pylint: disable=protected-access # return "" elif privkey[0] == '\x80': # checksum passed return privkey[1:] @@ -128,7 +128,7 @@ def decodeWalletImportFormat(WIFstring): ' the checksum passed but the key doesn\'t begin with hex 80.' ' Here is the PRIVATE key: %s', WIFstring ) - os._exit(0) # pylint: disable=protected-access + os._exit(0) # pylint: disable=protected-access def reloadMyAddressHashes(): diff --git a/src/tr.py b/src/tr.py index 87e67219..ac76ef4b 100644 --- a/src/tr.py +++ b/src/tr.py @@ -25,7 +25,8 @@ class translateClass: return self.text -def _translate(context, text, disambiguation=None, encoding=None, n=None): # pylint: disable=unused-argument +def _translate(context, text, disambiguation=None, encoding=None, n=None): + # pylint: disable=unused-argument return translateText(context, text, n) @@ -45,7 +46,7 @@ def translateText(context, text, n=None): ' or by searching Google for \'PyQt Download\'.'\ ' If you want to run in daemon mode, see https://bitmessage.org/wiki/Daemon' print 'Error message:', err - os._exit(0) # pylint: disable=protected-access + os._exit(0) # pylint: disable=protected-access if n is None: return QtGui.QApplication.translate(context, text) return QtGui.QApplication.translate(context, text, None, QtCore.QCoreApplication.CodecForTr, n) From 3211fca9532aabf87df8db1f934d4a7a912412e1 Mon Sep 17 00:00:00 2001 From: lakshyacis Date: Fri, 17 Jan 2020 18:57:36 +0530 Subject: [PATCH 2/7] formatting and shorten line length --- src/addresses.py | 4 +- src/api.py | 107 ++++++++++++++++++++-------------- src/bitmessagemain.py | 29 +++++---- src/bmconfigparser.py | 7 ++- src/build_osx.py | 10 +++- src/class_addressGenerator.py | 3 +- src/class_objectProcessor.py | 9 ++- src/class_singleWorker.py | 10 +++- 8 files changed, 109 insertions(+), 70 deletions(-) diff --git a/src/addresses.py b/src/addresses.py index 04e80383..2895e256 100644 --- a/src/addresses.py +++ b/src/addresses.py @@ -2,7 +2,6 @@ Operations with addresses """ # pylint: disable=redefined-outer-name,inconsistent-return-statements - import hashlib from binascii import hexlify, unhexlify from struct import pack, unpack @@ -180,7 +179,8 @@ def decodeAddress(address): returns (status, address version number, stream number, data (almost certainly a ripe hash)) """ - # pylint: disable=too-many-return-statements,too-many-statements,too-many-branches + # pylint: disable=too-many-return-statements,too-many-statements + # pylint: disable=too-many-branches address = str(address).strip() diff --git a/src/api.py b/src/api.py index 3201fba5..6652657f 100644 --- a/src/api.py +++ b/src/api.py @@ -1,15 +1,11 @@ -# pylint: disable=too-many-locals,too-many-lines,no-self-use,too-many-public-methods,too-many-branches -# pylint: disable=too-many-statements - -# Copyright (c) 2012-2016 Jonathan Warren -# Copyright (c) 2012-2020 The Bitmessage developers - """ This is not what you run to run the Bitmessage API. Instead, enable the API ( https://bitmessage.org/wiki/API ) and optionally enable daemon mode ( https://bitmessage.org/wiki/Daemon ) then run bitmessagemain.py. """ - +# Copyright (c) 2012-2016 Jonathan Warren +# Copyright (c) 2012-2020 The Bitmessage developers +# pylint: disable=too-many-lines,no-self-use,unused-variable,unused-argument import base64 import errno import hashlib @@ -33,7 +29,13 @@ import queues import shared import shutdown import state -from addresses import addBMIfNotPresent, calculateInventoryHash, decodeAddress, decodeVarint, varintDecodeError +from addresses import ( + addBMIfNotPresent, + calculateInventoryHash, + decodeAddress, + decodeVarint, + varintDecodeError +) from bmconfigparser import BMConfigParser from debug import logger from helper_ackPayload import genAckPayload @@ -136,9 +138,11 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): """ This is one of several classes that constitute the API - This class was written by Vaibhav Bhatia. Modified by Jonathan Warren (Atheros). + This class was written by Vaibhav Bhatia. + Modified by Jonathan Warren (Atheros). http://code.activestate.com/recipes/501148-xmlrpc-serverclient-which-does-cookie-handling-and/ """ + # pylint: disable=too-many-public-methods def do_POST(self): """ @@ -175,7 +179,8 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): # SimpleXMLRPCDispatcher. To maintain backwards compatibility, # check to see if a subclass implements _dispatch and dispatch # using that method if present. - response = self.server._marshaled_dispatch( # pylint: disable=protected-access + # pylint: disable=protected-access + response = self.server._marshaled_dispatch( data, getattr(self, '_dispatch', None) ) except BaseException: # This should only happen if the module is buggy @@ -213,8 +218,10 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): _, encstr = self.headers.get('Authorization').split() emailid, password = encstr.decode('base64').split(':') return ( - emailid == BMConfigParser().get('bitmessagesettings', 'apiusername') and - password == BMConfigParser().get('bitmessagesettings', 'apipassword') + emailid == BMConfigParser().get( + 'bitmessagesettings', 'apiusername') and + password == BMConfigParser().get( + 'bitmessagesettings', 'apipassword') ) else: logger.warning( @@ -251,10 +258,14 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): if status == 'invalidcharacters': raise APIError(9, 'Invalid characters in address: ' + address) if status == 'versiontoohigh': - raise APIError(10, 'Address version number too high (or zero) in address: ' + address) + raise APIError( + 10, + 'Address version number too high (or zero) in address: ' + + address) if status == 'varintmalformed': raise APIError(26, 'Malformed varint in address: ' + address) - raise APIError(7, 'Could not decode address: %s : %s' % (address, status)) + raise APIError( + 7, 'Could not decode address: %s : %s' % (address, status)) if addressVersionNumber < 2 or addressVersionNumber > 4: raise APIError( 11, 'The address version number currently must be 2, 3 or 4.' @@ -272,10 +283,9 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): def HandleListAddresses(self, method): """Handle a request to list addresses""" - data = '{"addresses":[' for addressInKeysFile in BMConfigParser().addresses(): - status, addressVersionNumber, streamNumber, hash01 = decodeAddress( # pylint: disable=unused-variable + status, addressVersionNumber, streamNumber, hash01 = decodeAddress( addressInKeysFile) if len(data) > 20: data += ',' @@ -379,16 +389,19 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): elif len(params) == 3: label, eighteenByteRipe, totalDifficulty = params nonceTrialsPerByte = int( - defaults.networkDefaultProofOfWorkNonceTrialsPerByte * totalDifficulty) + defaults.networkDefaultProofOfWorkNonceTrialsPerByte * + totalDifficulty) payloadLengthExtraBytes = BMConfigParser().get( 'bitmessagesettings', 'defaultpayloadlengthextrabytes') elif len(params) == 4: label, eighteenByteRipe, totalDifficulty, \ smallMessageDifficulty = params nonceTrialsPerByte = int( - defaults.networkDefaultProofOfWorkNonceTrialsPerByte * totalDifficulty) + defaults.networkDefaultProofOfWorkNonceTrialsPerByte * + totalDifficulty) payloadLengthExtraBytes = int( - defaults.networkDefaultPayloadLengthExtraBytes * smallMessageDifficulty) + defaults.networkDefaultPayloadLengthExtraBytes * + smallMessageDifficulty) else: raise APIError(0, 'Too many parameters!') label = self._decode(label, "base64") @@ -406,6 +419,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): def HandleCreateDeterministicAddresses(self, params): """Handle a request to create a deterministic address""" + # pylint: disable=too-many-branches, too-many-statements if not params: raise APIError(0, 'I need parameters!') @@ -461,7 +475,8 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): passphrase, numberOfAddresses, addressVersionNumber, \ streamNumber, eighteenByteRipe, totalDifficulty = params nonceTrialsPerByte = int( - defaults.networkDefaultProofOfWorkNonceTrialsPerByte * totalDifficulty) + defaults.networkDefaultProofOfWorkNonceTrialsPerByte * + totalDifficulty) payloadLengthExtraBytes = BMConfigParser().get( 'bitmessagesettings', 'defaultpayloadlengthextrabytes') @@ -470,9 +485,11 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): streamNumber, eighteenByteRipe, totalDifficulty, \ smallMessageDifficulty = params nonceTrialsPerByte = int( - defaults.networkDefaultProofOfWorkNonceTrialsPerByte * totalDifficulty) + defaults.networkDefaultProofOfWorkNonceTrialsPerByte * + totalDifficulty) payloadLengthExtraBytes = int( - defaults.networkDefaultPayloadLengthExtraBytes * smallMessageDifficulty) + defaults.networkDefaultPayloadLengthExtraBytes * + smallMessageDifficulty) else: raise APIError(0, 'Too many parameters!') if not passphrase: @@ -606,9 +623,8 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): label = str_chan + ' ' + passphrase except BaseException: label = str_chan + ' ' + repr(passphrase) - - status, addressVersionNumber, streamNumber, toRipe = self._verifyAddress( # pylint: disable=unused-variable - suppliedAddress) + status, addressVersionNumber, streamNumber, toRipe = ( + self._verifyAddress(suppliedAddress)) suppliedAddress = addBMIfNotPresent(suppliedAddress) queues.apiAddressGeneratorReturnQueue.queue.clear() queues.addressGeneratorQueue.put(( @@ -631,8 +647,8 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): raise APIError(0, 'I need parameters.') elif len(params) == 1: address, = params - # pylint: disable=unused-variable - status, addressVersionNumber, streamNumber, toRipe = self._verifyAddress(address) + status, addressVersionNumber, streamNumber, toRipe = ( + self._verifyAddress(address)) address = addBMIfNotPresent(address) if not BMConfigParser().has_section(address): raise APIError( @@ -653,8 +669,8 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): raise APIError(0, 'I need parameters.') elif len(params) == 1: address, = params - # pylint: disable=unused-variable - status, addressVersionNumber, streamNumber, toRipe = self._verifyAddress(address) + status, addressVersionNumber, streamNumber, toRipe = ( + self._verifyAddress(address)) address = addBMIfNotPresent(address) if not BMConfigParser().has_section(address): raise APIError( @@ -666,7 +682,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): shared.reloadMyAddressHashes() return 'success' - def HandleGetAllInboxMessages(self, params): # pylint: disable=unused-argument + def HandleGetAllInboxMessages(self, params): """Handle a request to get all inbox messages""" queryreturn = sqlQuery( @@ -694,7 +710,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): data += ']}' return data - def HandleGetAllInboxMessageIds(self, params): # pylint: disable=unused-argument + def HandleGetAllInboxMessageIds(self, params): """Handle a request to get all inbox message IDs""" queryreturn = sqlQuery( @@ -753,7 +769,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): data += ']}' return data - def HandleGetAllSentMessages(self, params): # pylint: disable=unused-argument + def HandleGetAllSentMessages(self, params): """Handle a request to get all sent messages""" queryreturn = sqlQuery( @@ -782,7 +798,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): data += ']}' return data - def HandleGetAllSentMessageIds(self, params): # pylint: disable=unused-argument + def HandleGetAllSentMessageIds(self, params): """Handle a request to get all sent message IDs""" queryreturn = sqlQuery( @@ -873,7 +889,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): data = '{"sentMessages":[' for row in queryreturn: msgid, toAddress, fromAddress, subject, lastactiontime, message, \ - encodingtype, status, ackdata = row # pylint: disable=unused-variable + encodingtype, status, ackdata = row subject = shared.fixPotentiallyInvalidUTF8Data(subject) message = shared.fixPotentiallyInvalidUTF8Data(message) if len(data) > 25: @@ -952,7 +968,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): sqlExecute('''UPDATE sent SET folder='trash' WHERE msgid=?''', msgid) return 'Trashed sent message (assuming message existed).' - def HandleSendMessage(self, params): + def HandleSendMessage(self, params): # pylint: disable=too-many-locals """Handle a request to send a message""" if not params: @@ -983,7 +999,6 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): TTL = 28 * 24 * 60 * 60 toAddress = addBMIfNotPresent(toAddress) fromAddress = addBMIfNotPresent(fromAddress) - # pylint: disable=unused-variable status, addressVersionNumber, streamNumber, toRipe = \ self._verifyAddress(toAddress) self._verifyAddress(fromAddress) @@ -1157,10 +1172,9 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): queues.UISignalQueue.put(('rerenderSubscriptions', '')) return 'Deleted subscription if it existed.' - def ListSubscriptions(self, params): # pylint: disable=unused-argument + def ListSubscriptions(self, params): """Handle a request to list susbcriptions""" - # pylint: disable=unused-variable queryreturn = sqlQuery( "SELECT label, address, enabled FROM subscriptions") data = {'subscriptions': []} @@ -1195,12 +1209,15 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): ) with shared.printLock: print( - '(For msg message via API) Doing proof of work. Total required difficulty:', + '(For msg message via API) Doing proof of work.' + 'Total required difficulty:', float( requiredAverageProofOfWorkNonceTrialsPerByte ) / defaults.networkDefaultProofOfWorkNonceTrialsPerByte, 'Required small message difficulty:', - float(requiredPayloadLengthExtraBytes) / defaults.networkDefaultPayloadLengthExtraBytes, + float( + requiredPayloadLengthExtraBytes + ) / defaults.networkDefaultPayloadLengthExtraBytes, ) powStartTime = time.time() initialHash = hashlib.sha512(encryptedPayload).digest() @@ -1209,8 +1226,9 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): print '(For msg message via API) Found proof of work', trialValue, 'Nonce:', nonce try: print( - 'POW took', int(time.time() - powStartTime), 'seconds.', - nonce / (time.time() - powStartTime), 'nonce trials per second.', + 'POW took', int(time.time() - powStartTime), + 'seconds.', nonce / (time.time() - powStartTime), + 'nonce trials per second.', ) except BaseException: pass @@ -1237,7 +1255,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): sqlExecute("UPDATE sent SET folder='trash' WHERE ackdata=?", ackdata) return 'Trashed sent message (assuming message existed).' - def HandleDissimatePubKey(self, params): # pylint: disable=unused-argument + def HandleDissimatePubKey(self, params): """Handle a request to disseminate a public key""" # The device issuing this command to PyBitmessage supplies a pubkey @@ -1266,7 +1284,6 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): pubkeyReadPosition += 8 else: pubkeyReadPosition += 4 - # pylint: disable=unused-variable addressVersion, addressVersionLength = decodeVarint( payload[pubkeyReadPosition:pubkeyReadPosition + 10]) pubkeyReadPosition += addressVersionLength @@ -1325,7 +1342,7 @@ class MySimpleXMLRPCRequestHandler(SimpleXMLRPCRequestHandler): data += ']}' return data - def HandleClientStatus(self, params): # pylint: disable=unused-argument + def HandleClientStatus(self, params): """Handle a request to get the status of the client""" connections_num = len(network.stats.connectedHostsList()) diff --git a/src/bitmessagemain.py b/src/bitmessagemain.py index 17c08fc0..770173b9 100755 --- a/src/bitmessagemain.py +++ b/src/bitmessagemain.py @@ -9,7 +9,6 @@ The PyBitmessage startup script # Right now, PyBitmessage only support connecting to stream 1. It doesn't # yet contain logic to expand into further streams. - import os import sys @@ -46,14 +45,15 @@ from inventory import Inventory from knownnodes import readKnownNodes # Network objects and threads from network import ( - BMConnectionPool, Dandelion, - AddrThread, AnnounceThread, BMNetworkThread, InvThread, ReceiveQueueThread, - DownloadThread, UploadThread) + BMConnectionPool, Dandelion, AddrThread, AnnounceThread, BMNetworkThread, + InvThread, ReceiveQueueThread, DownloadThread, UploadThread +) from singleinstance import singleinstance # Synchronous threads from threads import ( - set_thread_name, - addressGenerator, objectProcessor, singleCleaner, singleWorker, sqlThread) + set_thread_name, addressGenerator, objectProcessor, singleCleaner, + singleWorker, sqlThread +) def connectToStream(streamNumber): @@ -90,7 +90,8 @@ def _fixSocket(): addressToString = ctypes.windll.ws2_32.WSAAddressToStringA def inet_ntop(family, host): - """Converting an IP address in packed binary format to string format""" + """Converting an IP address in packed + binary format to string format""" if family == socket.AF_INET: if len(host) != 4: raise ValueError("invalid IPv4 host") @@ -112,7 +113,8 @@ def _fixSocket(): stringToAddress = ctypes.windll.ws2_32.WSAStringToAddressA def inet_pton(family, host): - """Converting an IP address in string format to a packed binary format""" + """Converting an IP address in string format + to a packed binary format""" buf = "\0" * 28 lengthBuf = pack("I", len(buf)) if stringToAddress(str(host), @@ -153,8 +155,8 @@ def signal_handler(signum, frame): if thread.name not in ("PyBitmessage", "MainThread"): return logger.error("Got signal %i", signum) - # there are possible non-UI variants to run bitmessage which should shutdown - # especially test-mode + # there are possible non-UI variants to run bitmessage + # which should shutdown especially test-mode if shared.thisapp.daemon or not state.enableGUI: shutdown.doCleanShutdown() else: @@ -386,10 +388,13 @@ class Main(object): while state.shutdown == 0: time.sleep(1) if ( - state.testmode and time.time() - state.last_api_response >= 30): + state.testmode and time.time() - + state.last_api_response >= 30 + ): self.stop() elif not state.enableGUI: - from tests import core as test_core # pylint: disable=relative-import + # pylint: disable=relative-import + from tests import core as test_core test_core_result = test_core.run() state.enableGUI = True self.stop() diff --git a/src/bmconfigparser.py b/src/bmconfigparser.py index c08ba062..abef971a 100644 --- a/src/bmconfigparser.py +++ b/src/bmconfigparser.py @@ -47,6 +47,7 @@ class BMConfigParser(ConfigParser.SafeConfigParser): Singleton class inherited from :class:`ConfigParser.SafeConfigParser` with additional methods specific to bitmessage config. """ + # pylint: disable=too-many-ancestors _temp = {} @@ -95,7 +96,8 @@ class BMConfigParser(ConfigParser.SafeConfigParser): return False def safeGetInt(self, section, field, default=0): - """Return value as integer, default on exceptions, 0 if default missing""" + """Return value as integer, default on exceptions, + 0 if default missing""" try: return self.getint(section, field) except (ConfigParser.NoSectionError, ConfigParser.NoOptionError, @@ -111,7 +113,8 @@ class BMConfigParser(ConfigParser.SafeConfigParser): return default def items(self, section, raw=False, variables=None): - """Return section variables as parent, but override the "raw" argument to always True""" + """Return section variables as parent, + but override the "raw" argument to always True""" # pylint: disable=arguments-differ return ConfigParser.ConfigParser.items(self, section, True, variables) diff --git a/src/build_osx.py b/src/build_osx.py index 7ab74dc2..c929f48a 100644 --- a/src/build_osx.py +++ b/src/build_osx.py @@ -13,8 +13,14 @@ DATA_FILES = [ ('bitmsghash', ['bitmsghash/bitmsghash.cl', 'bitmsghash/bitmsghash.so']), ('translations', glob('translations/*.qm')), ('ui', glob('bitmessageqt/*.ui')), - ('translations', glob(str(QtCore.QLibraryInfo.location(QtCore.QLibraryInfo.TranslationsPath)) + '/qt_??.qm')), - ('translations', glob(str(QtCore.QLibraryInfo.location(QtCore.QLibraryInfo.TranslationsPath)) + '/qt_??_??.qm')), + ( + 'translations', + glob(os.path.join(str(QtCore.QLibraryInfo.location( + QtCore.QLibraryInfo.TranslationsPath)), 'qt_??.qm'))), + ( + 'translations', + glob(os.path.join(str(QtCore.QLibraryInfo.location( + QtCore.QLibraryInfo.TranslationsPath)), 'qt_??_??.qm'))), ] setup( diff --git a/src/class_addressGenerator.py b/src/class_addressGenerator.py index 9e19cf50..5fbf7633 100644 --- a/src/class_addressGenerator.py +++ b/src/class_addressGenerator.py @@ -36,7 +36,8 @@ class addressGenerator(StoppableThread): Process the requests for addresses generation from `.queues.addressGeneratorQueue` """ - # pylint: disable=too-many-locals, too-many-branches, protected-access, too-many-statements + # pylint: disable=too-many-locals, too-many-branches + # pylint: disable=protected-access, too-many-statements while state.shutdown == 0: queueValue = queues.addressGeneratorQueue.get() nonceTrialsPerByte = 0 diff --git a/src/class_objectProcessor.py b/src/class_objectProcessor.py index 1a2f7751..a2151482 100644 --- a/src/class_objectProcessor.py +++ b/src/class_objectProcessor.py @@ -1,6 +1,9 @@ """ -The objectProcessor thread, of which there is only one, processes the network objects +The objectProcessor thread, of which there is only one, +processes the network objects """ +# pylint: disable=too-many-locals,too-many-return-statements +# pylint: disable=too-many-branches,too-many-statements import hashlib import logging import random @@ -34,7 +37,6 @@ import tr from fallback import RIPEMD160Hash import l10n -# pylint: disable=too-many-locals, too-many-return-statements, too-many-branches, too-many-statements logger = logging.getLogger('default') @@ -647,7 +649,8 @@ class objectProcessor(threading.Thread): if decodeAddress(toAddress)[1] >= 3 \ and not BMConfigParser().safeGetBoolean(toAddress, 'chan'): # If I'm not friendly with this person: - if not shared.isAddressInMyAddressBookSubscriptionsListOrWhitelist(fromAddress): + if not shared.isAddressInMyAddressBookSubscriptionsListOrWhitelist( + fromAddress): requiredNonceTrialsPerByte = BMConfigParser().getint( toAddress, 'noncetrialsperbyte') requiredPayloadLengthExtraBytes = BMConfigParser().getint( diff --git a/src/class_singleWorker.py b/src/class_singleWorker.py index e3f93ec6..6d7514d4 100644 --- a/src/class_singleWorker.py +++ b/src/class_singleWorker.py @@ -24,7 +24,9 @@ import queues import shared import state import tr -from addresses import calculateInventoryHash, decodeAddress, decodeVarint, encodeVarint +from addresses import ( + calculateInventoryHash, decodeAddress, decodeVarint, encodeVarint +) from bmconfigparser import BMConfigParser from helper_sql import sqlExecute, sqlQuery from inventory import Inventory @@ -237,11 +239,13 @@ class singleWorker(StoppableThread): return payload def doPOWForMyV2Pubkey(self, adressHash): - """ This function also broadcasts out the pubkey message once it is done with the POW""" + """ This function also broadcasts out the pubkey + message once it is done with the POW""" # Look up my stream number based on my address hash myAddress = shared.myAddressesByHash[adressHash] # status - _, addressVersionNumber, streamNumber, adressHash = decodeAddress(myAddress) + _, addressVersionNumber, streamNumber, adressHash = ( + decodeAddress(myAddress)) # 28 days from now plus or minus five minutes TTL = int(28 * 24 * 60 * 60 + helper_random.randomrandrange(-300, 300)) From 6139efc377a24efa6238080efaef1caa5f6802a6 Mon Sep 17 00:00:00 2001 From: lakshyacis Date: Fri, 24 Jan 2020 19:46:05 +0530 Subject: [PATCH 3/7] Imported packages sequencing and formatting 2 --- src/messagetypes/__init__.py | 2 +- src/network/announcethread.py | 1 - src/network/bmproto.py | 10 +++++----- src/network/receivequeuethread.py | 2 +- src/network/socks4a.py | 2 +- src/network/tls.py | 5 ++--- src/plugins/menu_qrcode.py | 2 +- src/plugins/proxyconfig_stem.py | 2 +- src/plugins/sound_canberra.py | 3 +-- src/pyelliptic/__init__.py | 4 ++-- src/pyelliptic/openssl.py | 4 ++-- src/storage/filesystem.py | 6 +++--- src/storage/sqlite.py | 4 ++-- 13 files changed, 22 insertions(+), 25 deletions(-) diff --git a/src/messagetypes/__init__.py b/src/messagetypes/__init__.py index af6bcdaa..4cae718c 100644 --- a/src/messagetypes/__init__.py +++ b/src/messagetypes/__init__.py @@ -1,6 +1,6 @@ import logging from importlib import import_module -from os import path, listdir +from os import listdir, path from string import lower import messagetypes diff --git a/src/network/announcethread.py b/src/network/announcethread.py index 17c8bcd3..19038ab6 100644 --- a/src/network/announcethread.py +++ b/src/network/announcethread.py @@ -4,7 +4,6 @@ Announce myself (node address) import time import state - from bmconfigparser import BMConfigParser from network.assemble import assemble_addr from network.connectionpool import BMConnectionPool diff --git a/src/network/bmproto.py b/src/network/bmproto.py index d5d3dbe3..2dcd1208 100644 --- a/src/network/bmproto.py +++ b/src/network/bmproto.py @@ -19,9 +19,9 @@ from bmconfigparser import BMConfigParser from inventory import Inventory from network.advanceddispatcher import AdvancedDispatcher from network.bmobject import ( - BMObject, BMObjectInsufficientPOWError, BMObjectInvalidDataError, - BMObjectExpiredError, BMObjectUnwantedStreamError, - BMObjectInvalidError, BMObjectAlreadyHaveError + BMObject, BMObjectAlreadyHaveError, BMObjectExpiredError, + BMObjectInsufficientPOWError, BMObjectInvalidDataError, + BMObjectInvalidError, BMObjectUnwantedStreamError ) from network.constants import ( ADDRESS_ALIVE, MAX_MESSAGE_SIZE, MAX_OBJECT_COUNT, @@ -30,8 +30,8 @@ from network.constants import ( from network.dandelion import Dandelion from network.proxy import ProxyError from node import Node, Peer -from objectracker import missingObjects, ObjectTracker -from queues import objectProcessorQueue, portCheckerQueue, invQueue, addrQueue +from objectracker import ObjectTracker, missingObjects +from queues import addrQueue, invQueue, objectProcessorQueue, portCheckerQueue from randomtrackingdict import RandomTrackingDict logger = logging.getLogger('default') diff --git a/src/network/receivequeuethread.py b/src/network/receivequeuethread.py index 1f5533b3..bf1d8300 100644 --- a/src/network/receivequeuethread.py +++ b/src/network/receivequeuethread.py @@ -6,8 +6,8 @@ import Queue import socket import state -from network.connectionpool import BMConnectionPool from network.advanceddispatcher import UnknownStateError +from network.connectionpool import BMConnectionPool from queues import receiveDataQueue from threads import StoppableThread diff --git a/src/network/socks4a.py b/src/network/socks4a.py index 42eab4b7..0d4310bc 100644 --- a/src/network/socks4a.py +++ b/src/network/socks4a.py @@ -5,7 +5,7 @@ SOCKS4a proxy module import socket import struct -from proxy import Proxy, ProxyError, GeneralProxyError +from proxy import GeneralProxyError, Proxy, ProxyError class Socks4aError(ProxyError): diff --git a/src/network/tls.py b/src/network/tls.py index f756591c..1b325696 100644 --- a/src/network/tls.py +++ b/src/network/tls.py @@ -7,11 +7,10 @@ import socket import ssl import sys -from network.advanceddispatcher import AdvancedDispatcher import network.asyncore_pollchoose as asyncore - -from queues import receiveDataQueue import paths +from network.advanceddispatcher import AdvancedDispatcher +from queues import receiveDataQueue logger = logging.getLogger('default') diff --git a/src/plugins/menu_qrcode.py b/src/plugins/menu_qrcode.py index 63644db6..ea322a49 100644 --- a/src/plugins/menu_qrcode.py +++ b/src/plugins/menu_qrcode.py @@ -6,7 +6,7 @@ A menu plugin showing QR-Code for bitmessage address in modal dialog. import urllib import qrcode -from PyQt4 import QtGui, QtCore +from PyQt4 import QtCore, QtGui from pybitmessage.tr import _translate diff --git a/src/plugins/proxyconfig_stem.py b/src/plugins/proxyconfig_stem.py index bc760ef1..7e8dc089 100644 --- a/src/plugins/proxyconfig_stem.py +++ b/src/plugins/proxyconfig_stem.py @@ -11,8 +11,8 @@ Configure tor proxy and hidden service with * otherwise use stem's 'BEST' version and save onion keys to the new section using *onionhostname* as name for future use. """ -import os import logging +import os import random # noseq import tempfile diff --git a/src/plugins/sound_canberra.py b/src/plugins/sound_canberra.py index 20bd054d..9fea8197 100644 --- a/src/plugins/sound_canberra.py +++ b/src/plugins/sound_canberra.py @@ -3,9 +3,8 @@ Sound theme plugin using pycanberra """ -from pybitmessage.bitmessageqt import sound - import pycanberra +from pybitmessage.bitmessageqt import sound _canberra = pycanberra.Canberra() diff --git a/src/pyelliptic/__init__.py b/src/pyelliptic/__init__.py index 65279ded..dbc1b2af 100644 --- a/src/pyelliptic/__init__.py +++ b/src/pyelliptic/__init__.py @@ -9,11 +9,11 @@ For modern cryptography with ECC, AES, HMAC, Blowfish, ... This is an abandoned package maintained inside of the PyBitmessage. """ -from .openssl import OpenSSL +from .cipher import Cipher from .ecc import ECC from .eccblind import ECCBlind -from .cipher import Cipher from .hash import hmac_sha256, hmac_sha512, pbkdf2 +from .openssl import OpenSSL __version__ = '1.3' diff --git a/src/pyelliptic/openssl.py b/src/pyelliptic/openssl.py index f769f0e3..4933ac44 100644 --- a/src/pyelliptic/openssl.py +++ b/src/pyelliptic/openssl.py @@ -6,9 +6,9 @@ This module loads openssl libs with ctypes and incapsulates needed openssl functionality in class _OpenSSL. """ -# pylint: disable=protected-access -import sys import ctypes +import sys +# pylint: disable=protected-access OpenSSL = None diff --git a/src/storage/filesystem.py b/src/storage/filesystem.py index 571a16c1..b19d9272 100644 --- a/src/storage/filesystem.py +++ b/src/storage/filesystem.py @@ -1,14 +1,14 @@ """ Module for using filesystem (directory with files) for inventory storage """ +import string +import time from binascii import hexlify, unhexlify from os import listdir, makedirs, path, remove, rmdir -import string from threading import RLock -import time from paths import lookupAppdataFolder -from storage import InventoryStorage, InventoryItem +from storage import InventoryItem, InventoryStorage class FilesystemInventory(InventoryStorage): diff --git a/src/storage/sqlite.py b/src/storage/sqlite.py index 7f41abc5..0992c00e 100644 --- a/src/storage/sqlite.py +++ b/src/storage/sqlite.py @@ -5,8 +5,8 @@ import sqlite3 import time from threading import RLock -from helper_sql import sqlQuery, SqlBulkExecute, sqlExecute -from storage import InventoryStorage, InventoryItem +from helper_sql import SqlBulkExecute, sqlExecute, sqlQuery +from storage import InventoryItem, InventoryStorage class SqliteInventory(InventoryStorage): # pylint: disable=too-many-ancestors From 6f35da4096770a668c4944c3024cd7ddb34be092 Mon Sep 17 00:00:00 2001 From: lakshyacis Date: Fri, 24 Jan 2020 19:33:13 +0530 Subject: [PATCH 4/7] Imported packages sequencing and formatting --- src/addresses.py | 1 - src/api.py | 3 +-- src/bitmessagecli.py | 10 +++++----- src/bitmessagemain.py | 2 +- src/bmconfigparser.py | 2 +- src/build_osx.py | 2 +- src/class_addressGenerator.py | 16 ++++++++-------- src/class_objectProcessor.py | 30 ++++++++++++++---------------- src/class_singleCleaner.py | 2 +- src/class_sqlThread.py | 15 +++++++-------- src/helper_ackPayload.py | 2 +- src/helper_msgcoding.py | 10 +++++----- src/helper_random.py | 2 ++ src/helper_sql.py | 2 +- src/inventory.py | 2 +- src/l10n.py | 1 - src/main.py | 2 +- src/namecoin.py | 4 ++-- src/openclpow.py | 6 +++--- src/paths.py | 1 - src/protocol.py | 2 +- src/qidenticon.py | 4 ++-- src/shared.py | 7 ++++--- src/threads.py | 12 ++++++------ 24 files changed, 68 insertions(+), 72 deletions(-) diff --git a/src/addresses.py b/src/addresses.py index 2895e256..0d3d4400 100644 --- a/src/addresses.py +++ b/src/addresses.py @@ -8,7 +8,6 @@ from struct import pack, unpack from debug import logger - ALPHABET = "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz" diff --git a/src/api.py b/src/api.py index 6652657f..70da0cda 100644 --- a/src/api.py +++ b/src/api.py @@ -18,8 +18,6 @@ from binascii import hexlify, unhexlify from SimpleXMLRPCServer import SimpleXMLRPCRequestHandler, SimpleXMLRPCServer from struct import pack -from version import softwareVersion - import defaults import helper_inbox import helper_sent @@ -42,6 +40,7 @@ from helper_ackPayload import genAckPayload from helper_sql import SqlBulkExecute, sqlExecute, sqlQuery, sqlStoredProcedure from inventory import Inventory from network.threads import StoppableThread +from version import softwareVersion str_chan = '[chan]' diff --git a/src/bitmessagecli.py b/src/bitmessagecli.py index 02fed7e9..01dbc9bb 100644 --- a/src/bitmessagecli.py +++ b/src/bitmessagecli.py @@ -13,15 +13,15 @@ TODO: fix the following (currently ignored) violations: """ -import xmlrpclib import datetime import imghdr -import ntpath import json -import socket -import time -import sys +import ntpath import os +import socket +import sys +import time +import xmlrpclib from bmconfigparser import BMConfigParser diff --git a/src/bitmessagemain.py b/src/bitmessagemain.py index 770173b9..d6cb289b 100755 --- a/src/bitmessagemain.py +++ b/src/bitmessagemain.py @@ -33,8 +33,8 @@ from struct import pack import defaults import shared -import state import shutdown +import state from bmconfigparser import BMConfigParser from debug import logger # this should go before any threads from helper_startup import ( diff --git a/src/bmconfigparser.py b/src/bmconfigparser.py index abef971a..328cf0c7 100644 --- a/src/bmconfigparser.py +++ b/src/bmconfigparser.py @@ -3,8 +3,8 @@ BMConfigParser class definition and default configuration settings """ import ConfigParser -import shutil import os +import shutil from datetime import datetime import state diff --git a/src/build_osx.py b/src/build_osx.py index c929f48a..83d2f280 100644 --- a/src/build_osx.py +++ b/src/build_osx.py @@ -1,6 +1,6 @@ """Building osx.""" -from glob import glob import os +from glob import glob from PyQt4 import QtCore from setuptools import setup diff --git a/src/class_addressGenerator.py b/src/class_addressGenerator.py index 5fbf7633..3df6501f 100644 --- a/src/class_addressGenerator.py +++ b/src/class_addressGenerator.py @@ -1,22 +1,22 @@ """ A thread for creating addresses """ -import time import hashlib +import time from binascii import hexlify -from pyelliptic import arithmetic -from pyelliptic.openssl import OpenSSL -import tr -import queues -import state -import shared import defaults import highlevelcrypto -from bmconfigparser import BMConfigParser +import queues +import shared +import state +import tr from addresses import decodeAddress, encodeAddress, encodeVarint +from bmconfigparser import BMConfigParser from fallback import RIPEMD160Hash from network import StoppableThread +from pyelliptic import arithmetic +from pyelliptic.openssl import OpenSSL class addressGenerator(StoppableThread): diff --git a/src/class_objectProcessor.py b/src/class_objectProcessor.py index a2151482..824580c2 100644 --- a/src/class_objectProcessor.py +++ b/src/class_objectProcessor.py @@ -12,31 +12,29 @@ import time from binascii import hexlify from subprocess import call # nosec -import highlevelcrypto -import knownnodes -import shared -from addresses import ( - calculateInventoryHash, decodeAddress, decodeVarint, encodeAddress, - encodeVarint, varintDecodeError -) -from bmconfigparser import BMConfigParser - import helper_bitcoin import helper_inbox import helper_msgcoding import helper_sent -from helper_sql import SqlBulkExecute, sqlExecute, sqlQuery -from helper_ackPayload import genAckPayload -from network import bmproto -from network.node import Peer - +import highlevelcrypto +import knownnodes +import l10n import protocol import queues +import shared import state import tr +from addresses import ( + calculateInventoryHash, decodeAddress, decodeVarint, + encodeAddress, encodeVarint, varintDecodeError +) +from bmconfigparser import BMConfigParser from fallback import RIPEMD160Hash - -import l10n +from helper_ackPayload import genAckPayload +from helper_sql import SqlBulkExecute, sqlExecute, sqlQuery +from network import bmproto +from network.node import Peer +# pylint: disable=too-many-locals, too-many-return-statements, too-many-branches, too-many-statements logger = logging.getLogger('default') diff --git a/src/class_singleCleaner.py b/src/class_singleCleaner.py index 68a5e727..b9fe3d1c 100644 --- a/src/class_singleCleaner.py +++ b/src/class_singleCleaner.py @@ -29,7 +29,7 @@ import shared import state import tr from bmconfigparser import BMConfigParser -from helper_sql import sqlQuery, sqlExecute +from helper_sql import sqlExecute, sqlQuery from inventory import Inventory from network import BMConnectionPool, StoppableThread diff --git a/src/class_sqlThread.py b/src/class_sqlThread.py index 78d70f79..7e9eb6c5 100644 --- a/src/class_sqlThread.py +++ b/src/class_sqlThread.py @@ -2,15 +2,12 @@ sqlThread is defined here """ -import threading -from bmconfigparser import BMConfigParser - -import sqlite3 -import time -import shutil # used for moving the messages.dat file -import sys import os -from debug import logger +import shutil # used for moving the messages.dat file +import sqlite3 +import sys +import threading +import time import helper_sql import helper_startup @@ -18,6 +15,8 @@ import paths import queues import state import tr +from bmconfigparser import BMConfigParser +from debug import logger # pylint: disable=attribute-defined-outside-init,protected-access diff --git a/src/helper_ackPayload.py b/src/helper_ackPayload.py index dcce3153..d30f4c0d 100644 --- a/src/helper_ackPayload.py +++ b/src/helper_ackPayload.py @@ -5,8 +5,8 @@ This module is for generating ack payload from binascii import hexlify from struct import pack -import highlevelcrypto import helper_random +import highlevelcrypto from addresses import encodeVarint diff --git a/src/helper_msgcoding.py b/src/helper_msgcoding.py index ae2bf80b..76dad423 100644 --- a/src/helper_msgcoding.py +++ b/src/helper_msgcoding.py @@ -5,6 +5,11 @@ Message encoding end decoding functions import string import zlib +import messagetypes +from bmconfigparser import BMConfigParser +from debug import logger +from tr import _translate + try: import msgpack except ImportError: @@ -13,11 +18,6 @@ except ImportError: except ImportError: import fallback.umsgpack.umsgpack as msgpack -import messagetypes -from bmconfigparser import BMConfigParser -from debug import logger -from tr import _translate - BITMESSAGE_ENCODING_IGNORE = 0 BITMESSAGE_ENCODING_TRIVIAL = 1 BITMESSAGE_ENCODING_SIMPLE = 2 diff --git a/src/helper_random.py b/src/helper_random.py index 0785c737..9a29d5e2 100644 --- a/src/helper_random.py +++ b/src/helper_random.py @@ -2,7 +2,9 @@ import os import random + from pyelliptic.openssl import OpenSSL + NoneType = type(None) diff --git a/src/helper_sql.py b/src/helper_sql.py index e7f2a60e..9b5dc29d 100644 --- a/src/helper_sql.py +++ b/src/helper_sql.py @@ -16,8 +16,8 @@ SQLite objects can only be used from one thread. or isn't thread-safe. """ -import threading import Queue +import threading sqlSubmitQueue = Queue.Queue() """the queue for SQL""" diff --git a/src/inventory.py b/src/inventory.py index 4b9ad226..fc06e455 100644 --- a/src/inventory.py +++ b/src/inventory.py @@ -1,8 +1,8 @@ """The Inventory singleton""" # TODO make this dynamic, and watch out for frozen, like with messagetypes -import storage.sqlite import storage.filesystem +import storage.sqlite from bmconfigparser import BMConfigParser from singleton import Singleton diff --git a/src/l10n.py b/src/l10n.py index bdfb03b3..7a78525b 100644 --- a/src/l10n.py +++ b/src/l10n.py @@ -7,7 +7,6 @@ import time from bmconfigparser import BMConfigParser - logger = logging.getLogger('default') diff --git a/src/main.py b/src/main.py index 969dbe56..71a4cb50 100644 --- a/src/main.py +++ b/src/main.py @@ -1,6 +1,6 @@ """This module is for thread start.""" -from bitmessagemain import main import state +from bitmessagemain import main if __name__ == '__main__': state.kivy = True diff --git a/src/namecoin.py b/src/namecoin.py index 63ca5653..ae2bde79 100644 --- a/src/namecoin.py +++ b/src/namecoin.py @@ -10,11 +10,11 @@ import os import socket import sys -from addresses import decodeAddress -from debug import logger import defaults import tr # translate +from addresses import decodeAddress from bmconfigparser import BMConfigParser +from debug import logger configSection = "bitmessagesettings" diff --git a/src/openclpow.py b/src/openclpow.py index fad25fa3..35bf46d2 100644 --- a/src/openclpow.py +++ b/src/openclpow.py @@ -2,14 +2,14 @@ """ Module for Proof of Work using OpenCL """ -from struct import pack, unpack import hashlib import os +from struct import pack, unpack -from bmconfigparser import BMConfigParser import paths -from state import shutdown +from bmconfigparser import BMConfigParser from debug import logger +from state import shutdown libAvailable = True ctx = False diff --git a/src/paths.py b/src/paths.py index 59bc5e42..e2f8c97e 100644 --- a/src/paths.py +++ b/src/paths.py @@ -8,7 +8,6 @@ import sys from datetime import datetime from shutil import move - logger = logging.getLogger('default') # When using py2exe or py2app, the variable frozen is added to the sys diff --git a/src/protocol.py b/src/protocol.py index cdd50dce..4f2d0856 100644 --- a/src/protocol.py +++ b/src/protocol.py @@ -11,7 +11,7 @@ import socket import sys import time from binascii import hexlify -from struct import pack, unpack, Struct +from struct import Struct, pack, unpack import defaults import highlevelcrypto diff --git a/src/qidenticon.py b/src/qidenticon.py index deafc570..6eab09cd 100644 --- a/src/qidenticon.py +++ b/src/qidenticon.py @@ -11,8 +11,8 @@ Return a PIL Image class instance which have generated identicon image. """ from PyQt4 import QtGui -from PyQt4.QtCore import QSize, QPointF, Qt -from PyQt4.QtGui import QPixmap, QPainter, QPolygonF +from PyQt4.QtCore import QPointF, QSize, Qt +from PyQt4.QtGui import QPainter, QPixmap, QPolygonF class IdenticonRendererBase(object): diff --git a/src/shared.py b/src/shared.py index dfc86ab6..beed52ed 100644 --- a/src/shared.py +++ b/src/shared.py @@ -10,12 +10,11 @@ from __future__ import division # Libraries. import hashlib import os -import sys import stat -import threading import subprocess +import sys +import threading from binascii import hexlify -from pyelliptic import arithmetic # Project imports. import highlevelcrypto @@ -25,6 +24,8 @@ from bmconfigparser import BMConfigParser from debug import logger from helper_sql import sqlQuery +from pyelliptic import arithmetic + verbose = 1 # This is obsolete with the change to protocol v3 diff --git a/src/threads.py b/src/threads.py index 08d61196..b7471508 100644 --- a/src/threads.py +++ b/src/threads.py @@ -15,6 +15,12 @@ There are also other threads in the `.network` package. import threading +from class_addressGenerator import addressGenerator +from class_objectProcessor import objectProcessor +from class_singleCleaner import singleCleaner +from class_singleWorker import singleWorker +from class_sqlThread import sqlThread + try: import prctl except ImportError: @@ -33,12 +39,6 @@ else: threading.Thread.__bootstrap_original__ = threading.Thread._Thread__bootstrap threading.Thread._Thread__bootstrap = _thread_name_hack -from class_addressGenerator import addressGenerator -from class_objectProcessor import objectProcessor -from class_singleCleaner import singleCleaner -from class_singleWorker import singleWorker -from class_sqlThread import sqlThread - __all__ = [ "addressGenerator", "objectProcessor", "singleCleaner", "singleWorker", From 11bec55be56e73502fbd569bf0327a8876b54315 Mon Sep 17 00:00:00 2001 From: Peter Surda Date: Wed, 5 Feb 2020 20:34:45 +0800 Subject: [PATCH 5/7] Don't put addresses into queue - attempt to fix #1598 - seems to work - addresses won't be uploaded/announced anymore other than after connecting, Later I need to find out how to announce them without causing problems, but for the time disabling this seems an acceptable drawback --- src/network/bmproto.py | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/network/bmproto.py b/src/network/bmproto.py index 2dcd1208..64bde74c 100644 --- a/src/network/bmproto.py +++ b/src/network/bmproto.py @@ -31,7 +31,7 @@ from network.dandelion import Dandelion from network.proxy import ProxyError from node import Node, Peer from objectracker import ObjectTracker, missingObjects -from queues import addrQueue, invQueue, objectProcessorQueue, portCheckerQueue +from queues import invQueue, objectProcessorQueue, portCheckerQueue from randomtrackingdict import RandomTrackingDict logger = logging.getLogger('default') @@ -466,8 +466,9 @@ class BMProto(AdvancedDispatcher, ObjectTracker): } # since we don't track peers outside of knownnodes, # only spread if in knownnodes to prevent flood - addrQueue.put((stream, peer, seenTime, - self.destination)) + # DISABLED TO WORKAROUND FLOOD/LEAK + # addrQueue.put((stream, peer, seenTime, + # self.destination)) return True def bm_command_portcheck(self): From 3fb34370a761659f0d0cdbb70e31f91d1420a0ee Mon Sep 17 00:00:00 2001 From: Peter Surda Date: Tue, 11 Feb 2020 23:48:10 +0800 Subject: [PATCH 6/7] Wine build script update - update and clean up and make sure it works - it builds the binary but I haven't tried to run the binary - it probably still missing some fine tuning, OpenCL probably doesn't work --- buildscripts/builder.sh | 173 ----------------------- buildscripts/winbuild.sh | 164 +++++++++++++++++++++ packages/pyinstaller/bitmessagemain.spec | 4 +- 3 files changed, 166 insertions(+), 175 deletions(-) delete mode 100755 buildscripts/builder.sh create mode 100755 buildscripts/winbuild.sh diff --git a/buildscripts/builder.sh b/buildscripts/builder.sh deleted file mode 100755 index 07949fa4..00000000 --- a/buildscripts/builder.sh +++ /dev/null @@ -1,173 +0,0 @@ -#!/bin/bash - -# INIT -MACHINE_TYPE=`uname -m` -BASE_DIR=$(pwd) -PYTHON_VERSION=2.7.15 -PYQT_VERSION=4-4.11.4-gpl-Py2.7-Qt4.8.7 -OPENSSL_VERSION=1_0_2t -DIRECTORY32BIT=SoftwareDownloads32bit -DIRECTORY64BIT=SoftwareDownloads64bit - -if [ ${MACHINE_TYPE} == 'x86_64' ]; then - if [ ! -d "$DIRECTORY64BIT" ]; then - mkdir SoftwareDownloads64bit - cd SoftwareDownloads64bit - else - echo "Directory already exists" - cd SoftwareDownloads64bit - fi -else - if [ ! -d "$DIRECTORY32BIT" ]; then - mkdir SoftwareDownloads32bit - cd SoftwareDownloads32bit - else - echo "Directory 32 bit alrready exists" - cd SoftwareDownloads32bit - fi -fi -#Functions -function install_wine { - - - wget -nc https://dl.winehq.org/wine-builds/Release.key --no-check-certificate - sudo apt-key add Release.key - sudo apt-add-repository 'https://dl.winehq.org/wine-builds/ubuntu/' - sudo apt-get -y update - sudo apt-get -y install wine1.8 winetricks - if [ ${MACHINE_TYPE} == 'x86_64' ]; then - sudo apt-get -y install wine64-development - env WINEPREFIX=$HOME/.wine64 WINEARCH=win64 winecfg - WINE="env WINEPREFIX=$HOME/.wine64 wine" - export WINEPREFIX - - else - sudo apt-get -y install wine32-development - env WINEPREFIX=$HOME/.wine32 WINEARCH=win32 winecfg - WINE="env WINEPREFIX=$HOME/.wine32 wine" - export WINEPREFIX - - fi -} - -function install_python(){ - echo "Download Python2.7" - - if [ ${MACHINE_TYPE} == 'x86_64' ]; then - # For 64 bit machine - wget -nc wget http://www.python.org/ftp/python/${PYTHON_VERSION}/python-${PYTHON_VERSION}.amd64.msi --no-check-certificate - echo "Install Python2.7 for 64 bit" - $WINE msiexec -i python-${PYTHON_VERSION}.amd64.msi /q /norestart - - wget -nc https://download.microsoft.com/download/d/2/4/d242c3fb-da5a-4542-ad66-f9661d0a8d19/vcredist_x64.exe --no-check-certificate - $WINE vcredist_x64.exe /q /norestart - echo "Installed vcredist for 64 bit" - $WINE pip install --upgrade pip - - else - # For 32 bit machine - wget -nc https://www.python.org/ftp/python/${PYTHON_VERSION}/python-${PYTHON_VERSION}.msi --no-check-certificate - echo "Install Python2.7 for 32 bit" - $WINE msiexec -i python-${PYTHON_VERSION}.msi /q /norestart - - echo "Installing vc_redist for 32 bit " - wget -nc https://download.microsoft.com/download/1/1/1/1116b75a-9ec3-481a-a3c8-1777b5381140/vcredist_x86.exe --no-check-certificate - $WINE vcredist_x86.exe /q /norestart - #insatlled msvcr120.dll for 32 bit system - wget -nc http://www.dll-found.com/zip/m/msvcr120.dll.zip --no-check-certificate - unzip msvcr120.dll.zip - sudo cp msvcr120.dll $HOME/.wine32/drive_c/windows/system32/ - $WINE pip install --upgrade pip - - fi -} - -function install_pyqt(){ - - echo "Download PyQT" - if [ ${MACHINE_TYPE} == 'x86_64' ]; then - # For 64 bit machine - wget -nc --content-disposition https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/PyQt4-4.11.4-gpl-Py2.7-Qt4.8.7-x64.exe?raw=true --no-check-certificate - $WINE PyQt4-4.11.4-gpl-Py2.7-Qt4.8.7-x64.exe /q /norestart /silent /verysiling /sp- /suppressmsgboxes - else - # For 32 bit machine - wget -nc --content-disposition https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/PyQt4-4.11.4-gpl-Py2.7-Qt4.8.7-x32.exe?raw=true --no-check-certificate - $WINE PyQt4-4.11.4-gpl-Py2.7-Qt4.8.7-x32.exe /q /norestart /silent /verysiling /sp- /suppressmsgboxes - fi -} - -function install_openssl(){ - if [ ${MACHINE_TYPE} == 'x86_64' ]; then - wget -nc --content-disposition https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/Win64OpenSSL-${OPENSSL_VERSION}.exe?raw=true --no-check-certificate - $WINE Win64OpenSSL-${OPENSSL_VERSION}.exe /q /norestart /silent /verysiling /sp- /suppressmsgboxes - - else - wget -nc --content-disposition https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/Win32OpenSSL-${OPENSSL_VERSION}.exe?raw=true --no-check-certificate - $WINE Win32OpenSSL-${OPENSSL_VERSION}.exe /q /norestart /silent /verysiling /sp- /suppressmsgboxes - echo "Install PyInstaller 32 bit" - fi -} - -function install_pyinstaller() -{ - $WINE pip install pyinstaller - echo "Install PyInstaller" - echo "Install Pyopencl" - - if [ ${MACHINE_TYPE} == 'x86_64' ]; then - wget -nc https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/pyopencl-2015.1-cp27-none-win_amd64.whl --no-check-certificate - $WINE pip install pyopencl-2015.1-cp27-none-win_amd64.whl - $WINE pip install msgpack-python - - else - wget -nc --content-disposition https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/pyopencl-2015.1-cp27-none-win_amd64one-win32.whl?raw=true --no-check-certificate - $WINE pip install msgpack-python - $WINE pip install pyopencl-2015.1-cp27-none-win32.whl - fi - echo "Install Message Pack" - -} - - -function build_dll(){ - cd $BASE_DIR - rm -rf master.zip - rm -rf PyBitmessage - git clone https://github.com/Bitmessage/PyBitmessage.git - cd PyBitmessage/src/bitmsghash - if [ ${MACHINE_TYPE} == 'x86_64' ]; then - # Do stuff for 64 bit machine - echo "Install MinGW" - sudo apt-get -y install mingw-w64 - echo "Create dll" - x86_64-w64-mingw32-g++ -D_WIN32 -Wall -O3 -march=native -I$HOME/.wine64/drive_c/OpenSSL-Win64/include -I/usr/x86_64-w64-mingw32/include -L$HOME/.wine64/drive_c/OpenSSL-Win64/lib -c bitmsghash.cpp - x86_64-w64-mingw32-g++ -static-libgcc -shared bitmsghash.o -D_WIN32 -O3 -march=native -I$HOME/.wine64/drive_c/OpenSSL-Win64/include -L$HOME/.wine64/drive_c/OpenSSL-Win64 -L/usr/lib/x86_64-linux-gnu/wine -fPIC -shared -lcrypt32 -leay32 -lwsock32 -o bitmsghash64.dll -Wl,--out-implib,bitmsghash.a - echo "DLL generated successfully " - cd .. - cp -R bitmsghash ../../../src/ - cd ../../../ - cd packages/pyinstaller/ - env WINEPREFIX=$HOME/.wine64 wine pyinstaller bitmessagemain.spec - else - echo "Install MinGW for 32 bit" - sudo apt-get install mingw-w64 - echo "Create dll" - - - i686-w64-mingw32-g++ -D_WIN32 -Wall -m32 -O3 -march=native -I$HOME/.wine32/drive_c/OpenSSL-Win32/include -I/usr/i686-w64-mingw32/include -L$HOME/.wine32/drive_c/OpenSSL-Win32/lib -c bitmsghash.cpp - i686-w64-mingw32-g++ -static-libgcc -shared bitmsghash.o -D_WIN32 -O3 -march=native -I$HOME/.wine32/drive_c/OpenSSL-Win32/include -L$HOME/.wine32/drive_c/OpenSSL-Win32/lib/MinGW -fPIC -shared -lcrypt32 -leay32 -lwsock32 -o bitmsghash32.dll -Wl,--out-implib,bitmsghash.a - cd .. - cp -R bitmsghash ../../../src/ - cd ../../../ - cd packages/pyinstaller/ - env WINEPREFIX=$HOME/.wine32 wine pyinstaller bitmessagemain.spec - fi -} - - -install_wine -install_python -install_pyqt -install_openssl -install_pyinstaller -build_dll diff --git a/buildscripts/winbuild.sh b/buildscripts/winbuild.sh new file mode 100755 index 00000000..4d9dbf9c --- /dev/null +++ b/buildscripts/winbuild.sh @@ -0,0 +1,164 @@ +#!/bin/bash + +# INIT +MACHINE_TYPE=`uname -m` +BASE_DIR=$(pwd) +PYTHON_VERSION=2.7.17 +PYQT_VERSION=4-4.11.4-gpl-Py2.7-Qt4.8.7 +OPENSSL_VERSION=1_0_2t +SRCPATH=~/Downloads + +#Functions +function download_sources_32 { + if [ ! -d ${SRCPATH} ]; then + mkdir -p ${SRCPATH} + fi + wget -P ${SRCPATH} -c -nc --content-disposition \ + https://www.python.org/ftp/python/${PYTHON_VERSION}/python-${PYTHON_VERSION}.msi \ + https://download.microsoft.com/download/1/1/1/1116b75a-9ec3-481a-a3c8-1777b5381140/vcredist_x86.exe \ + https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/PyQt${PYQT_VERSION}-x32.exe?raw=true \ + https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/Win32OpenSSL-${OPENSSL_VERSION}.exe?raw=true \ + https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/pyopencl-2015.1-cp27-none-win32.whl?raw=true + #wget -P ${SRCPATH} -nc http://www.dll-found.com/zip/m/msvcr120.dll.zip + #wget -P ${SRCPATH} -nc http://www.dll-found.com/zip/m/msvcr100.dll.zip +} + +function download_sources_64 { + if [ ! -d ${SRCPATH} ]; then + mkdir -p ${SRCPATH} + fi + wget -P ${SRCPATH} -c -nc --content-disposition \ + http://www.python.org/ftp/python/${PYTHON_VERSION}/python-${PYTHON_VERSION}.amd64.msi \ + https://download.microsoft.com/download/d/2/4/d242c3fb-da5a-4542-ad66-f9661d0a8d19/vcredist_x64.exe \ + https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/PyQt${PYQT_VERSION}-x64.exe?raw=true \ + https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/Win64OpenSSL-${OPENSSL_VERSION}.exe?raw=true \ + https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/pyopencl-2015.1-cp27-none-win_amd64.whl?raw=true +} + +function download_sources { + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + download_sources_64 + else + download_sources_32 + fi +} + +function install_wine { + echo "Setting up wine" + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + export WINEPREFIX=${HOME}/.wine64 WINEARCH=win64 + else + export WINEPREFIX=${HOME}/.wine32 WINEARCH=win32 + fi + rm -rf ${WINEPREFIX} + rm -rf packages/pyinstaller/{build,dist} +} + +function install_python(){ + cd ${SRCPATH} + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + echo "Installing Python ${PYTHON_VERSION} 64b" + wine msiexec -i python-${PYTHON_VERSION}.amd64.msi /q /norestart + echo "Installing vcredist for 64 bit" + wine vcredist_x64.exe /q /norestart + echo "Upgrading pip" + wine python -m pip install --upgrade pip + else + echo "Installing Python ${PYTHON_VERSION} 32b" + wine msiexec -i python-${PYTHON_VERSION}.msi /q /norestart + echo "Installing vc_redist for 32 bit " + wine vcredist_x86.exe /q /norestart + #echo "Unpacking MSVCR120.DLL" + #unzip msvcr120.dll.zip -o -d $HOME/.wine32/drive_c/windows/system32/ + #unzip msvcr100.dll.zip -o -d $HOME/.wine32/drive_c/windows/system32/ + echo "Upgrading pip" + wine python -m pip install --upgrade pip + + fi +} + +function install_pyqt(){ + + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + echo "Installing PyQt-${PYQT_VERSION} 64b" + wine PyQt${PYQT_VERSION}-x64.exe /S /WX + else + echo "Installing PyQt-${PYQT_VERSION} 32b" + wine PyQt${PYQT_VERSION}-x32.exe /S /WX + fi +} + +function install_openssl(){ + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + echo "Installing OpenSSL ${OPENSSL_VERSION} 64b" + wine Win64OpenSSL-${OPENSSL_VERSION}.exe /q /norestart /silent /verysilent /sp- /suppressmsgboxes + else + echo "Installing OpenSSL ${OPENSSL_VERSION} 32b" + wine Win32OpenSSL-${OPENSSL_VERSION}.exe /q /norestart /silent /verysilent /sp- /suppressmsgboxes + fi +} + +function install_pyinstaller() +{ + echo "Installing PyInstaller" + wine python -m pip install pyinstaller +} + +function install_msgpack() +{ + echo "Installing msgpack" + wine python -m pip install msgpack-python +} + +function install_pyopencl() +{ + cd $SRCPATH + echo "Installing PyOpenCL" + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + wine python -m pip install pyopencl-2015.1-cp27-none-win_amd64.whl + else + wine python -m pip install pyopencl-2015.1-cp27-none-win32.whl + fi +} + + +function build_dll(){ + cd $BASE_DIR + cd src/bitmsghash + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + echo "Create dll" + x86_64-w64-mingw32-g++ -D_WIN32 -Wall -O3 -march=native -I$HOME/.wine64/drive_c/OpenSSL-Win64/include -I/usr/x86_64-w64-mingw32/include -L$HOME/.wine64/drive_c/OpenSSL-Win64/lib -c bitmsghash.cpp + x86_64-w64-mingw32-g++ -static-libgcc -shared bitmsghash.o -D_WIN32 -O3 -march=native -I$HOME/.wine64/drive_c/OpenSSL-Win64/include -L$HOME/.wine64/drive_c/OpenSSL-Win64 -L/usr/lib/x86_64-linux-gnu/wine -fPIC -shared -lcrypt32 -leay32 -lwsock32 -o bitmsghash64.dll -Wl,--out-implib,bitmsghash.a + else + echo "Create dll" + i686-w64-mingw32-g++ -D_WIN32 -Wall -m32 -O3 -march=native -I$HOME/.wine32/drive_c/OpenSSL-Win32/include -I/usr/i686-w64-mingw32/include -L$HOME/.wine32/drive_c/OpenSSL-Win32/lib -c bitmsghash.cpp + i686-w64-mingw32-g++ -static-libgcc -shared bitmsghash.o -D_WIN32 -O3 -march=native -I$HOME/.wine32/drive_c/OpenSSL-Win32/include -L$HOME/.wine32/drive_c/OpenSSL-Win32/lib/MinGW -fPIC -shared -lcrypt32 -leay32 -lwsock32 -o bitmsghash32.dll -Wl,--out-implib,bitmsghash.a + fi +} + +function build_exe(){ + cd $BASE_DIR + cd packages/pyinstaller + wine pyinstaller bitmessagemain.spec +} + +# prepare on ubuntu +# dpkg --add-architecture i386 +# apt update +# apt -y install wget wine-stable wine-development winetricks mingw-w64 wine32 wine64 xvfb + + +download_sources +if [ "$1" == "--download-only" ]; then + exit +fi + +install_wine +install_python +install_pyqt +install_openssl +install_pyopencl +install_msgpack +install_pyinstaller +build_dll +build_exe diff --git a/packages/pyinstaller/bitmessagemain.spec b/packages/pyinstaller/bitmessagemain.spec index 7f30cedf..fe86d7bd 100644 --- a/packages/pyinstaller/bitmessagemain.spec +++ b/packages/pyinstaller/bitmessagemain.spec @@ -33,7 +33,7 @@ os.rename(os.path.join(srcPath, '__init__.py'), os.path.join(srcPath, '__init__. a = Analysis( [srcPath + 'bitmessagemain.py'], pathex=[outPath], - hiddenimports=['pyopencl','numpy', 'win32com' , 'setuptools.msvc' ,'_cffi_backend'], + hiddenimports=['bitmessageqt.languagebox', 'pyopencl','numpy', 'win32com' , 'setuptools.msvc' ,'_cffi_backend'], hookspath=None, runtime_hooks=None ) @@ -94,7 +94,7 @@ exe = EXE(pyz, debug=False, strip=None, upx=True, - console=True, icon= os.path.join(srcPath, 'images', 'can-icon.ico')) + console=False, icon= os.path.join(srcPath, 'images', 'can-icon.ico')) coll = COLLECT(exe, a.binaries, From 73ecf07dec70f66e9afa074ec0c18bed0cf050f0 Mon Sep 17 00:00:00 2001 From: Peter Surda Date: Sun, 16 Feb 2020 00:20:40 +0800 Subject: [PATCH 7/7] Wine build cleanup and XP fix - spec file was cleaned up - 32bit build runs on XP (downgrade of PyInstaller needed) --- buildscripts/winbuild.sh | 35 ++++++++-------- packages/pyinstaller/bitmessagemain.spec | 53 ++++++++++++++---------- 2 files changed, 48 insertions(+), 40 deletions(-) diff --git a/buildscripts/winbuild.sh b/buildscripts/winbuild.sh index 4d9dbf9c..5b4fc37f 100755 --- a/buildscripts/winbuild.sh +++ b/buildscripts/winbuild.sh @@ -19,8 +19,6 @@ function download_sources_32 { https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/PyQt${PYQT_VERSION}-x32.exe?raw=true \ https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/Win32OpenSSL-${OPENSSL_VERSION}.exe?raw=true \ https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/pyopencl-2015.1-cp27-none-win32.whl?raw=true - #wget -P ${SRCPATH} -nc http://www.dll-found.com/zip/m/msvcr120.dll.zip - #wget -P ${SRCPATH} -nc http://www.dll-found.com/zip/m/msvcr100.dll.zip } function download_sources_64 { @@ -61,24 +59,19 @@ function install_python(){ wine msiexec -i python-${PYTHON_VERSION}.amd64.msi /q /norestart echo "Installing vcredist for 64 bit" wine vcredist_x64.exe /q /norestart - echo "Upgrading pip" - wine python -m pip install --upgrade pip else echo "Installing Python ${PYTHON_VERSION} 32b" wine msiexec -i python-${PYTHON_VERSION}.msi /q /norestart - echo "Installing vc_redist for 32 bit " - wine vcredist_x86.exe /q /norestart - #echo "Unpacking MSVCR120.DLL" - #unzip msvcr120.dll.zip -o -d $HOME/.wine32/drive_c/windows/system32/ - #unzip msvcr100.dll.zip -o -d $HOME/.wine32/drive_c/windows/system32/ - echo "Upgrading pip" - wine python -m pip install --upgrade pip - + # MSVCR 2008 required for Windows XP + cd ${SRCPATH} + echo "Installing vc_redist (2008) for 32 bit " + wine vcredist_x86.exe /Q fi + echo "Upgrading pip" + wine python -m pip install --upgrade pip } function install_pyqt(){ - if [ ${MACHINE_TYPE} == 'x86_64' ]; then echo "Installing PyQt-${PYQT_VERSION} 64b" wine PyQt${PYQT_VERSION}-x64.exe /S /WX @@ -100,19 +93,27 @@ function install_openssl(){ function install_pyinstaller() { + cd ${BASE_DIR} echo "Installing PyInstaller" - wine python -m pip install pyinstaller + if [ ${MACHINE_TYPE} == 'x86_64' ]; then + wine python -m pip install pyinstaller + else + # 3.2.1 is the last version to work on XP + # see https://github.com/pyinstaller/pyinstaller/issues/2931 + wine python -m pip install -I pyinstaller==3.2.1 + fi } function install_msgpack() { + cd ${BASE_DIR} echo "Installing msgpack" wine python -m pip install msgpack-python } function install_pyopencl() { - cd $SRCPATH + cd ${SRCPATH} echo "Installing PyOpenCL" if [ ${MACHINE_TYPE} == 'x86_64' ]; then wine python -m pip install pyopencl-2015.1-cp27-none-win_amd64.whl @@ -123,7 +124,7 @@ function install_pyopencl() function build_dll(){ - cd $BASE_DIR + cd ${BASE_DIR} cd src/bitmsghash if [ ${MACHINE_TYPE} == 'x86_64' ]; then echo "Create dll" @@ -137,7 +138,7 @@ function build_dll(){ } function build_exe(){ - cd $BASE_DIR + cd ${BASE_DIR} cd packages/pyinstaller wine pyinstaller bitmessagemain.spec } diff --git a/packages/pyinstaller/bitmessagemain.spec b/packages/pyinstaller/bitmessagemain.spec index fe86d7bd..92e52f6a 100644 --- a/packages/pyinstaller/bitmessagemain.spec +++ b/packages/pyinstaller/bitmessagemain.spec @@ -11,13 +11,13 @@ else: sslName = 'OpenSSL-Win%s' % ("32" if arch == 32 else "64") site_root = os.path.abspath(HOMEPATH) spec_root = os.path.abspath(SPECPATH) -cdrivePath= site_root[0:3] -srcPath = spec_root[:-20]+"src\\" -qtPath = site_root+"\\PyQt4\\" -openSSLPath = cdrivePath+sslName+"\\" -msvcrDllPath = cdrivePath+"windows\\system32\\" -pythonDllPath = cdrivePath+"Python27\\" -outPath = spec_root+"\\bitmessagemain" +cdrivePath = site_root[0:3] +srcPath = os.path.join(spec_root[:-20], "src") +qtBase = "PyQt4" +openSSLPath = os.path.join(cdrivePath, sslName) +msvcrDllPath = os.path.join(cdrivePath, "windows", "system32") +pythonDllPath = os.path.join(cdrivePath, "Python27") +outPath = os.path.join(spec_root, "bitmessagemain") importPath = srcPath sys.path.insert(0,importPath) @@ -31,7 +31,7 @@ os.rename(os.path.join(srcPath, '__init__.py'), os.path.join(srcPath, '__init__. # -*- mode: python -*- a = Analysis( - [srcPath + 'bitmessagemain.py'], + [os.path.join(srcPath, 'bitmessagemain.py')], pathex=[outPath], hiddenimports=['bitmessageqt.languagebox', 'pyopencl','numpy', 'win32com' , 'setuptools.msvc' ,'_cffi_backend'], hookspath=None, @@ -43,23 +43,32 @@ os.rename(os.path.join(srcPath, '__init__.py.backup'), os.path.join(srcPath, '__ def addTranslations(): import os extraDatas = [] - for file in os.listdir(srcPath + 'translations'): - if file[-3:] != ".qm": + for file_ in os.listdir(os.path.join(srcPath, 'translations')): + if file_[-3:] != ".qm": continue - extraDatas.append((os.path.join('translations', file), os.path.join(srcPath, 'translations', file), 'DATA')) - for file in os.listdir(qtPath + 'translations'): - if file[0:3] != "qt_" or file[5:8] != ".qm": + extraDatas.append((os.path.join('translations', file_), + os.path.join(srcPath, 'translations', file_), 'DATA')) + for libdir in sys.path: + qtdir = os.path.join(libdir, qtBase, 'translations') + if os.path.isdir(qtdir): + break + if not os.path.isdir(qtdir): + return extraDatas + for file_ in os.listdir(qtdir): + if file_[0:3] != "qt_" or file_[5:8] != ".qm": continue - extraDatas.append((os.path.join('translations', file), os.path.join(qtPath, 'translations', file), 'DATA')) + extraDatas.append((os.path.join('translations', file_), + os.path.join(qtdir, file_), 'DATA')) return extraDatas def addUIs(): import os extraDatas = [] - for file in os.listdir(srcPath + 'bitmessageqt'): - if file[-3:] != ".ui": + for file_ in os.listdir(os.path.join(srcPath, 'bitmessageqt')): + if file_[-3:] != ".ui": continue - extraDatas.append((os.path.join('ui', file), os.path.join(srcPath, 'bitmessageqt', file), 'DATA')) + extraDatas.append((os.path.join('ui', file_), os.path.join(srcPath, + 'bitmessageqt', file_), 'DATA')) return extraDatas # append the translations directory @@ -67,10 +76,8 @@ a.datas += addTranslations() a.datas += addUIs() - -a.binaries += [('libeay32.dll', openSSLPath + 'libeay32.dll', 'BINARY'), - ('python27.dll', pythonDllPath + 'python27.dll', 'BINARY'), - ('msvcr120.dll', msvcrDllPath + 'msvcr120.dll','BINARY'), +a.binaries += [('libeay32.dll', os.path.join(openSSLPath, 'libeay32.dll'), 'BINARY'), + ('python27.dll', os.path.join(pythonDllPath, 'python27.dll'), 'BINARY'), (os.path.join('bitmsghash', 'bitmsghash%i.dll' % (arch)), os.path.join(srcPath, 'bitmsghash', 'bitmsghash%i.dll' % (arch)), 'BINARY'), (os.path.join('bitmsghash', 'bitmsghash.cl'), os.path.join(srcPath, 'bitmsghash', 'bitmsghash.cl'), 'BINARY'), (os.path.join('sslkeys', 'cert.pem'), os.path.join(srcPath, 'sslkeys', 'cert.pem'), 'BINARY'), @@ -93,7 +100,7 @@ exe = EXE(pyz, name=fname, debug=False, strip=None, - upx=True, + upx=False, console=False, icon= os.path.join(srcPath, 'images', 'can-icon.ico')) coll = COLLECT(exe, @@ -101,6 +108,6 @@ coll = COLLECT(exe, a.zipfiles, a.datas, strip=False, - upx=True, + upx=False, name='main')