2019-11-04 15:45:18 +01:00
|
|
|
"""
|
|
|
|
A thread for creating addresses
|
|
|
|
"""
|
2013-06-21 14:44:37 +02:00
|
|
|
import hashlib
|
2020-01-24 15:03:13 +01:00
|
|
|
import time
|
2017-09-21 17:24:51 +02:00
|
|
|
from binascii import hexlify
|
|
|
|
|
2023-12-20 04:00:51 +01:00
|
|
|
from six.moves import configparser, queue
|
|
|
|
|
2017-09-21 17:24:51 +02:00
|
|
|
import defaults
|
|
|
|
import highlevelcrypto
|
2020-01-24 15:03:13 +01:00
|
|
|
import queues
|
|
|
|
import shared
|
|
|
|
import state
|
2017-09-21 17:24:51 +02:00
|
|
|
from addresses import decodeAddress, encodeAddress, encodeVarint
|
2022-01-28 13:55:23 +01:00
|
|
|
from bmconfigparser import config
|
2019-01-31 16:42:22 +01:00
|
|
|
from fallback import RIPEMD160Hash
|
2019-10-27 14:15:45 +01:00
|
|
|
from network import StoppableThread
|
2020-01-24 15:03:13 +01:00
|
|
|
from pyelliptic.openssl import OpenSSL
|
2023-12-20 04:00:51 +01:00
|
|
|
from tr import _translate
|
2017-09-21 17:24:51 +02:00
|
|
|
|
2013-06-21 14:44:37 +02:00
|
|
|
|
2021-08-20 16:54:28 +02:00
|
|
|
class AddressGeneratorException(Exception):
|
|
|
|
'''Generic AddressGenerator exception'''
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2019-08-01 13:37:26 +02:00
|
|
|
class addressGenerator(StoppableThread):
|
2019-11-04 15:45:18 +01:00
|
|
|
"""A thread for creating addresses"""
|
2013-06-21 14:44:37 +02:00
|
|
|
|
2019-08-01 13:37:26 +02:00
|
|
|
name = "addressGenerator"
|
2017-09-21 17:24:51 +02:00
|
|
|
|
2015-11-24 01:55:17 +01:00
|
|
|
def stopThread(self):
|
2023-12-20 04:00:51 +01:00
|
|
|
"""Tell the thread to stop putting a special command to it's queue"""
|
2015-11-24 01:55:17 +01:00
|
|
|
try:
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.addressGeneratorQueue.put(("stopThread", "data"))
|
2021-08-16 16:29:02 +02:00
|
|
|
except queue.Full:
|
|
|
|
self.logger.error('addressGeneratorQueue is Full')
|
|
|
|
|
2015-11-24 01:55:17 +01:00
|
|
|
super(addressGenerator, self).stopThread()
|
2013-06-21 14:44:37 +02:00
|
|
|
|
|
|
|
def run(self):
|
2019-10-27 14:15:45 +01:00
|
|
|
"""
|
|
|
|
Process the requests for addresses generation
|
|
|
|
from `.queues.addressGeneratorQueue`
|
|
|
|
"""
|
2023-12-20 04:00:51 +01:00
|
|
|
# pylint: disable=too-many-locals,too-many-branches,too-many-statements
|
2021-08-20 16:54:28 +02:00
|
|
|
# pylint: disable=too-many-nested-blocks
|
|
|
|
|
2017-01-14 23:20:15 +01:00
|
|
|
while state.shutdown == 0:
|
2017-02-08 13:41:56 +01:00
|
|
|
queueValue = queues.addressGeneratorQueue.get()
|
2013-06-21 14:44:37 +02:00
|
|
|
nonceTrialsPerByte = 0
|
|
|
|
payloadLengthExtraBytes = 0
|
2016-10-28 22:07:16 +02:00
|
|
|
live = True
|
2013-06-26 17:55:33 +02:00
|
|
|
if queueValue[0] == 'createChan':
|
2017-09-21 17:24:51 +02:00
|
|
|
command, addressVersionNumber, streamNumber, label, \
|
|
|
|
deterministicPassphrase, live = queueValue
|
2013-06-26 17:55:33 +02:00
|
|
|
eighteenByteRipe = False
|
|
|
|
numberOfAddressesToMake = 1
|
2013-09-18 06:04:01 +02:00
|
|
|
numberOfNullBytesDemandedOnFrontOfRipeHash = 1
|
2013-06-26 17:55:33 +02:00
|
|
|
elif queueValue[0] == 'joinChan':
|
2017-09-21 17:24:51 +02:00
|
|
|
command, chanAddress, label, deterministicPassphrase, \
|
|
|
|
live = queueValue
|
2013-06-26 17:55:33 +02:00
|
|
|
eighteenByteRipe = False
|
2013-07-22 07:10:22 +02:00
|
|
|
addressVersionNumber = decodeAddress(chanAddress)[1]
|
|
|
|
streamNumber = decodeAddress(chanAddress)[2]
|
2013-06-26 17:55:33 +02:00
|
|
|
numberOfAddressesToMake = 1
|
2013-09-18 06:04:01 +02:00
|
|
|
numberOfNullBytesDemandedOnFrontOfRipeHash = 1
|
2013-06-26 17:55:33 +02:00
|
|
|
elif len(queueValue) == 7:
|
2017-09-21 17:24:51 +02:00
|
|
|
command, addressVersionNumber, streamNumber, label, \
|
|
|
|
numberOfAddressesToMake, deterministicPassphrase, \
|
|
|
|
eighteenByteRipe = queueValue
|
2021-08-16 16:29:02 +02:00
|
|
|
|
|
|
|
numberOfNullBytesDemandedOnFrontOfRipeHash = \
|
2022-01-28 13:55:23 +01:00
|
|
|
config.safeGetInt(
|
2021-08-16 16:29:02 +02:00
|
|
|
'bitmessagesettings',
|
|
|
|
'numberofnullbytesonaddress',
|
|
|
|
2 if eighteenByteRipe else 1
|
|
|
|
)
|
2013-06-21 14:44:37 +02:00
|
|
|
elif len(queueValue) == 9:
|
2017-09-21 17:24:51 +02:00
|
|
|
command, addressVersionNumber, streamNumber, label, \
|
|
|
|
numberOfAddressesToMake, deterministicPassphrase, \
|
|
|
|
eighteenByteRipe, nonceTrialsPerByte, \
|
|
|
|
payloadLengthExtraBytes = queueValue
|
2021-08-16 16:29:02 +02:00
|
|
|
|
|
|
|
numberOfNullBytesDemandedOnFrontOfRipeHash = \
|
2022-01-28 13:55:23 +01:00
|
|
|
config.safeGetInt(
|
2021-08-16 16:29:02 +02:00
|
|
|
'bitmessagesettings',
|
|
|
|
'numberofnullbytesonaddress',
|
|
|
|
2 if eighteenByteRipe else 1
|
|
|
|
)
|
2015-11-24 01:55:17 +01:00
|
|
|
elif queueValue[0] == 'stopThread':
|
|
|
|
break
|
2013-06-21 14:44:37 +02:00
|
|
|
else:
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.error(
|
2017-09-21 17:24:51 +02:00
|
|
|
'Programming error: A structure with the wrong number'
|
|
|
|
' of values was passed into the addressGeneratorQueue.'
|
|
|
|
' Here is the queueValue: %r\n', queueValue)
|
2013-09-13 06:27:34 +02:00
|
|
|
if addressVersionNumber < 3 or addressVersionNumber > 4:
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.error(
|
2017-09-21 17:24:51 +02:00
|
|
|
'Program error: For some reason the address generator'
|
|
|
|
' queue has been given a request to create at least'
|
|
|
|
' one version %s address which it cannot do.\n',
|
|
|
|
addressVersionNumber)
|
2013-06-21 14:44:37 +02:00
|
|
|
if nonceTrialsPerByte == 0:
|
2022-01-28 13:55:23 +01:00
|
|
|
nonceTrialsPerByte = config.getint(
|
2013-06-21 14:44:37 +02:00
|
|
|
'bitmessagesettings', 'defaultnoncetrialsperbyte')
|
2017-09-21 17:24:51 +02:00
|
|
|
if nonceTrialsPerByte < \
|
|
|
|
defaults.networkDefaultProofOfWorkNonceTrialsPerByte:
|
|
|
|
nonceTrialsPerByte = \
|
|
|
|
defaults.networkDefaultProofOfWorkNonceTrialsPerByte
|
2013-06-21 14:44:37 +02:00
|
|
|
if payloadLengthExtraBytes == 0:
|
2022-01-28 13:55:23 +01:00
|
|
|
payloadLengthExtraBytes = config.getint(
|
2013-06-21 14:44:37 +02:00
|
|
|
'bitmessagesettings', 'defaultpayloadlengthextrabytes')
|
2017-09-21 17:24:51 +02:00
|
|
|
if payloadLengthExtraBytes < \
|
|
|
|
defaults.networkDefaultPayloadLengthExtraBytes:
|
|
|
|
payloadLengthExtraBytes = \
|
|
|
|
defaults.networkDefaultPayloadLengthExtraBytes
|
2013-09-13 06:27:34 +02:00
|
|
|
if command == 'createRandomAddress':
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.UISignalQueue.put((
|
2017-09-21 17:24:51 +02:00
|
|
|
'updateStatusBar',
|
2023-12-20 04:00:51 +01:00
|
|
|
_translate(
|
2017-09-21 17:24:51 +02:00
|
|
|
"MainWindow", "Generating one new address")
|
|
|
|
))
|
|
|
|
# This next section is a little bit strange. We're going
|
|
|
|
# to generate keys over and over until we find one
|
|
|
|
# that starts with either \x00 or \x00\x00. Then when
|
|
|
|
# we pack them into a Bitmessage address, we won't store
|
|
|
|
# the \x00 or \x00\x00 bytes thus making the address shorter.
|
2013-09-13 06:27:34 +02:00
|
|
|
startTime = time.time()
|
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix = 0
|
|
|
|
potentialPrivSigningKey = OpenSSL.rand(32)
|
2017-09-21 17:24:51 +02:00
|
|
|
potentialPubSigningKey = highlevelcrypto.pointMult(
|
|
|
|
potentialPrivSigningKey)
|
2013-09-13 06:27:34 +02:00
|
|
|
while True:
|
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix += 1
|
|
|
|
potentialPrivEncryptionKey = OpenSSL.rand(32)
|
2014-05-21 12:06:20 +02:00
|
|
|
potentialPubEncryptionKey = highlevelcrypto.pointMult(
|
2013-09-13 06:27:34 +02:00
|
|
|
potentialPrivEncryptionKey)
|
|
|
|
sha = hashlib.new('sha512')
|
|
|
|
sha.update(
|
|
|
|
potentialPubSigningKey + potentialPubEncryptionKey)
|
2019-01-31 16:42:22 +01:00
|
|
|
ripe = RIPEMD160Hash(sha.digest()).digest()
|
|
|
|
if (
|
2021-08-16 16:29:02 +02:00
|
|
|
ripe[:numberOfNullBytesDemandedOnFrontOfRipeHash]
|
2021-08-20 16:54:28 +02:00
|
|
|
== b'\x00' * numberOfNullBytesDemandedOnFrontOfRipeHash
|
2019-01-31 16:42:22 +01:00
|
|
|
):
|
2013-09-18 06:04:01 +02:00
|
|
|
break
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.info(
|
2019-01-31 16:42:22 +01:00
|
|
|
'Generated address with ripe digest: %s', hexlify(ripe))
|
2015-01-08 23:11:30 +01:00
|
|
|
try:
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.info(
|
2017-09-21 17:24:51 +02:00
|
|
|
'Address generator calculated %s addresses at %s'
|
|
|
|
' addresses per second before finding one with'
|
|
|
|
' the correct ripe-prefix.',
|
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix,
|
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix
|
|
|
|
/ (time.time() - startTime))
|
2015-01-08 23:11:30 +01:00
|
|
|
except ZeroDivisionError:
|
2017-09-21 17:24:51 +02:00
|
|
|
# The user must have a pretty fast computer.
|
|
|
|
# time.time() - startTime equaled zero.
|
2015-01-08 23:11:30 +01:00
|
|
|
pass
|
2017-09-21 17:24:51 +02:00
|
|
|
address = encodeAddress(
|
2019-01-31 16:42:22 +01:00
|
|
|
addressVersionNumber, streamNumber, ripe)
|
2013-09-13 06:27:34 +02:00
|
|
|
|
2021-08-06 14:44:35 +02:00
|
|
|
privSigningKeyWIF = highlevelcrypto.encodeWalletImportFormat(
|
|
|
|
potentialPrivSigningKey)
|
|
|
|
privEncryptionKeyWIF = highlevelcrypto.encodeWalletImportFormat(
|
|
|
|
potentialPrivEncryptionKey)
|
2013-09-13 06:27:34 +02:00
|
|
|
|
2022-01-28 13:55:23 +01:00
|
|
|
config.add_section(address)
|
|
|
|
config.set(address, 'label', label)
|
|
|
|
config.set(address, 'enabled', 'true')
|
|
|
|
config.set(address, 'decoy', 'false')
|
|
|
|
config.set(address, 'noncetrialsperbyte', str(
|
2013-09-13 06:27:34 +02:00
|
|
|
nonceTrialsPerByte))
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(address, 'payloadlengthextrabytes', str(
|
2013-09-13 06:27:34 +02:00
|
|
|
payloadLengthExtraBytes))
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(
|
2022-07-04 17:33:42 +02:00
|
|
|
address, 'privsigningkey', privSigningKeyWIF.decode())
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(
|
2022-07-04 17:33:42 +02:00
|
|
|
address, 'privencryptionkey',
|
|
|
|
privEncryptionKeyWIF.decode())
|
2022-01-28 13:55:23 +01:00
|
|
|
config.save()
|
2013-09-13 06:27:34 +02:00
|
|
|
|
|
|
|
# The API and the join and create Chan functionality
|
|
|
|
# both need information back from the address generator.
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.apiAddressGeneratorReturnQueue.put(address)
|
2013-09-13 06:27:34 +02:00
|
|
|
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.UISignalQueue.put((
|
2017-09-21 17:24:51 +02:00
|
|
|
'updateStatusBar',
|
2023-12-20 04:00:51 +01:00
|
|
|
_translate(
|
2017-09-21 17:24:51 +02:00
|
|
|
"MainWindow",
|
|
|
|
"Done generating address. Doing work necessary"
|
|
|
|
" to broadcast it...")
|
|
|
|
))
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.UISignalQueue.put(('writeNewAddressToTable', (
|
2013-09-13 06:27:34 +02:00
|
|
|
label, address, streamNumber)))
|
|
|
|
shared.reloadMyAddressHashes()
|
|
|
|
if addressVersionNumber == 3:
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.workerQueue.put((
|
2019-01-31 16:42:22 +01:00
|
|
|
'sendOutOrStoreMyV3Pubkey', ripe))
|
2013-09-13 06:27:34 +02:00
|
|
|
elif addressVersionNumber == 4:
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.workerQueue.put((
|
2013-09-13 06:27:34 +02:00
|
|
|
'sendOutOrStoreMyV4Pubkey', address))
|
|
|
|
|
2023-12-20 04:00:51 +01:00
|
|
|
elif command in (
|
|
|
|
'createDeterministicAddresses', 'createChan',
|
|
|
|
'getDeterministicAddress', 'joinChan'
|
|
|
|
):
|
2019-11-04 15:45:18 +01:00
|
|
|
if not deterministicPassphrase:
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.warning(
|
2017-09-21 17:24:51 +02:00
|
|
|
'You are creating deterministic'
|
|
|
|
' address(es) using a blank passphrase.'
|
|
|
|
' Bitmessage will do it but it is rather stupid.')
|
2013-09-13 06:27:34 +02:00
|
|
|
if command == 'createDeterministicAddresses':
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.UISignalQueue.put((
|
2017-09-21 17:24:51 +02:00
|
|
|
'updateStatusBar',
|
2023-12-20 04:00:51 +01:00
|
|
|
_translate(
|
2017-09-21 17:24:51 +02:00
|
|
|
"MainWindow",
|
|
|
|
"Generating %1 new addresses."
|
|
|
|
).arg(str(numberOfAddressesToMake))
|
|
|
|
))
|
2013-09-13 06:27:34 +02:00
|
|
|
signingKeyNonce = 0
|
|
|
|
encryptionKeyNonce = 1
|
2017-09-21 17:24:51 +02:00
|
|
|
# We fill out this list no matter what although we only
|
|
|
|
# need it if we end up passing the info to the API.
|
|
|
|
listOfNewAddressesToSendOutThroughTheAPI = []
|
2013-09-13 06:27:34 +02:00
|
|
|
|
2018-05-02 17:29:55 +02:00
|
|
|
for _ in range(numberOfAddressesToMake):
|
2017-09-21 17:24:51 +02:00
|
|
|
# This next section is a little bit strange. We're
|
|
|
|
# going to generate keys over and over until we find
|
|
|
|
# one that has a RIPEMD hash that starts with either
|
|
|
|
# \x00 or \x00\x00. Then when we pack them into a
|
|
|
|
# Bitmessage address, we won't store the \x00 or
|
2013-09-13 06:27:34 +02:00
|
|
|
# \x00\x00 bytes thus making the address shorter.
|
2013-06-21 14:44:37 +02:00
|
|
|
startTime = time.time()
|
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix = 0
|
|
|
|
while True:
|
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix += 1
|
2013-09-13 06:27:34 +02:00
|
|
|
potentialPrivSigningKey = hashlib.sha512(
|
2021-08-16 16:29:02 +02:00
|
|
|
deterministicPassphrase
|
|
|
|
+ encodeVarint(signingKeyNonce)
|
2017-09-21 17:24:51 +02:00
|
|
|
).digest()[:32]
|
2013-09-13 06:27:34 +02:00
|
|
|
potentialPrivEncryptionKey = hashlib.sha512(
|
2021-08-16 16:29:02 +02:00
|
|
|
deterministicPassphrase
|
|
|
|
+ encodeVarint(encryptionKeyNonce)
|
2017-09-21 17:24:51 +02:00
|
|
|
).digest()[:32]
|
2014-05-21 12:06:20 +02:00
|
|
|
potentialPubSigningKey = highlevelcrypto.pointMult(
|
2013-09-13 06:27:34 +02:00
|
|
|
potentialPrivSigningKey)
|
2014-05-21 12:06:20 +02:00
|
|
|
potentialPubEncryptionKey = highlevelcrypto.pointMult(
|
2013-06-21 14:44:37 +02:00
|
|
|
potentialPrivEncryptionKey)
|
2013-09-13 06:27:34 +02:00
|
|
|
signingKeyNonce += 2
|
|
|
|
encryptionKeyNonce += 2
|
2013-06-21 14:44:37 +02:00
|
|
|
sha = hashlib.new('sha512')
|
|
|
|
sha.update(
|
|
|
|
potentialPubSigningKey + potentialPubEncryptionKey)
|
2019-01-31 16:42:22 +01:00
|
|
|
ripe = RIPEMD160Hash(sha.digest()).digest()
|
|
|
|
if (
|
2021-08-16 16:29:02 +02:00
|
|
|
ripe[:numberOfNullBytesDemandedOnFrontOfRipeHash]
|
2021-08-20 16:54:28 +02:00
|
|
|
== b'\x00' * numberOfNullBytesDemandedOnFrontOfRipeHash
|
2019-01-31 16:42:22 +01:00
|
|
|
):
|
2013-09-18 06:04:01 +02:00
|
|
|
break
|
2013-06-21 14:44:37 +02:00
|
|
|
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.info(
|
2019-01-31 16:42:22 +01:00
|
|
|
'Generated address with ripe digest: %s', hexlify(ripe))
|
2015-01-08 23:11:30 +01:00
|
|
|
try:
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.info(
|
2017-09-21 17:24:51 +02:00
|
|
|
'Address generator calculated %s addresses'
|
|
|
|
' at %s addresses per second before finding'
|
|
|
|
' one with the correct ripe-prefix.',
|
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix,
|
2021-08-16 16:29:02 +02:00
|
|
|
numberOfAddressesWeHadToMakeBeforeWeFoundOneWithTheCorrectRipePrefix
|
|
|
|
/ (time.time() - startTime)
|
2017-09-21 17:24:51 +02:00
|
|
|
)
|
2015-01-08 23:11:30 +01:00
|
|
|
except ZeroDivisionError:
|
2017-09-21 17:24:51 +02:00
|
|
|
# The user must have a pretty fast computer.
|
|
|
|
# time.time() - startTime equaled zero.
|
2015-01-08 23:11:30 +01:00
|
|
|
pass
|
2017-09-21 17:24:51 +02:00
|
|
|
address = encodeAddress(
|
2019-01-31 16:42:22 +01:00
|
|
|
addressVersionNumber, streamNumber, ripe)
|
2013-06-21 14:44:37 +02:00
|
|
|
|
2013-09-13 06:27:34 +02:00
|
|
|
saveAddressToDisk = True
|
2017-09-21 17:24:51 +02:00
|
|
|
# If we are joining an existing chan, let us check
|
|
|
|
# to make sure it matches the provided Bitmessage address
|
2013-09-13 06:27:34 +02:00
|
|
|
if command == 'joinChan':
|
|
|
|
if address != chanAddress:
|
2017-09-21 17:24:51 +02:00
|
|
|
listOfNewAddressesToSendOutThroughTheAPI.append(
|
|
|
|
'chan name does not match address')
|
2013-06-26 17:55:33 +02:00
|
|
|
saveAddressToDisk = False
|
2013-09-13 06:27:34 +02:00
|
|
|
if command == 'getDeterministicAddress':
|
|
|
|
saveAddressToDisk = False
|
2013-06-26 17:55:33 +02:00
|
|
|
|
2016-10-28 22:07:16 +02:00
|
|
|
if saveAddressToDisk and live:
|
2021-08-06 14:44:35 +02:00
|
|
|
privSigningKeyWIF = \
|
|
|
|
highlevelcrypto.encodeWalletImportFormat(
|
|
|
|
potentialPrivSigningKey)
|
|
|
|
privEncryptionKeyWIF = \
|
|
|
|
highlevelcrypto.encodeWalletImportFormat(
|
|
|
|
potentialPrivEncryptionKey)
|
2013-06-21 14:44:37 +02:00
|
|
|
|
2013-09-13 06:27:34 +02:00
|
|
|
try:
|
2022-01-28 13:55:23 +01:00
|
|
|
config.add_section(address)
|
2015-01-08 23:11:30 +01:00
|
|
|
addressAlreadyExists = False
|
2021-08-16 16:29:02 +02:00
|
|
|
except configparser.DuplicateSectionError:
|
2013-09-13 06:27:34 +02:00
|
|
|
addressAlreadyExists = True
|
2017-09-21 17:24:51 +02:00
|
|
|
|
2015-01-08 23:11:30 +01:00
|
|
|
if addressAlreadyExists:
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.info(
|
2017-09-21 17:24:51 +02:00
|
|
|
'%s already exists. Not adding it again.',
|
|
|
|
address
|
|
|
|
)
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.UISignalQueue.put((
|
2017-09-21 17:24:51 +02:00
|
|
|
'updateStatusBar',
|
2023-12-20 04:00:51 +01:00
|
|
|
_translate(
|
2017-09-21 17:24:51 +02:00
|
|
|
"MainWindow",
|
|
|
|
"%1 is already in 'Your Identities'."
|
|
|
|
" Not adding it again."
|
|
|
|
).arg(address)
|
|
|
|
))
|
2015-01-08 23:11:30 +01:00
|
|
|
else:
|
2019-08-06 13:04:33 +02:00
|
|
|
self.logger.debug('label: %s', label)
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(address, 'label', label)
|
|
|
|
config.set(address, 'enabled', 'true')
|
|
|
|
config.set(address, 'decoy', 'false')
|
2023-12-20 04:00:51 +01:00
|
|
|
if command in ('createChan', 'joinChan'):
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(address, 'chan', 'true')
|
|
|
|
config.set(
|
2017-09-21 17:24:51 +02:00
|
|
|
address, 'noncetrialsperbyte',
|
|
|
|
str(nonceTrialsPerByte))
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(
|
2017-09-21 17:24:51 +02:00
|
|
|
address, 'payloadlengthextrabytes',
|
|
|
|
str(payloadLengthExtraBytes))
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(
|
2022-07-04 17:33:42 +02:00
|
|
|
address, 'privsigningkey',
|
|
|
|
privSigningKeyWIF.decode())
|
2022-01-28 13:55:23 +01:00
|
|
|
config.set(
|
2022-07-04 17:33:42 +02:00
|
|
|
address, 'privencryptionkey',
|
|
|
|
privEncryptionKeyWIF.decode())
|
2022-01-28 13:55:23 +01:00
|
|
|
config.save()
|
2013-06-21 14:44:37 +02:00
|
|
|
|
2017-09-21 17:24:51 +02:00
|
|
|
queues.UISignalQueue.put((
|
|
|
|
'writeNewAddressToTable',
|
|
|
|
(label, address, str(streamNumber))
|
|
|
|
))
|
2013-09-13 06:27:34 +02:00
|
|
|
listOfNewAddressesToSendOutThroughTheAPI.append(
|
|
|
|
address)
|
2019-01-31 16:42:22 +01:00
|
|
|
shared.myECCryptorObjects[ripe] = \
|
2017-09-21 17:24:51 +02:00
|
|
|
highlevelcrypto.makeCryptor(
|
2019-11-04 15:45:18 +01:00
|
|
|
hexlify(potentialPrivEncryptionKey))
|
2019-01-31 16:42:22 +01:00
|
|
|
shared.myAddressesByHash[ripe] = address
|
2017-09-21 17:24:51 +02:00
|
|
|
tag = hashlib.sha512(hashlib.sha512(
|
2021-08-16 16:29:02 +02:00
|
|
|
encodeVarint(addressVersionNumber)
|
|
|
|
+ encodeVarint(streamNumber) + ripe
|
2017-09-21 17:24:51 +02:00
|
|
|
).digest()).digest()[32:]
|
2013-09-15 03:06:26 +02:00
|
|
|
shared.myAddressesByTag[tag] = address
|
2013-09-13 06:27:34 +02:00
|
|
|
if addressVersionNumber == 3:
|
2017-09-21 17:24:51 +02:00
|
|
|
# If this is a chan address,
|
|
|
|
# the worker thread won't send out
|
|
|
|
# the pubkey over the network.
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.workerQueue.put((
|
2019-01-31 16:42:22 +01:00
|
|
|
'sendOutOrStoreMyV3Pubkey', ripe))
|
2013-09-13 06:27:34 +02:00
|
|
|
elif addressVersionNumber == 4:
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.workerQueue.put((
|
2013-09-13 06:27:34 +02:00
|
|
|
'sendOutOrStoreMyV4Pubkey', address))
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.UISignalQueue.put((
|
2017-09-21 17:24:51 +02:00
|
|
|
'updateStatusBar',
|
2023-12-20 04:00:51 +01:00
|
|
|
_translate(
|
2017-09-21 17:24:51 +02:00
|
|
|
"MainWindow", "Done generating address")
|
|
|
|
))
|
|
|
|
elif saveAddressToDisk and not live \
|
2022-01-28 13:55:23 +01:00
|
|
|
and not config.has_section(address):
|
2017-09-21 17:24:51 +02:00
|
|
|
listOfNewAddressesToSendOutThroughTheAPI.append(
|
|
|
|
address)
|
2013-06-21 14:44:37 +02:00
|
|
|
|
2013-09-13 06:27:34 +02:00
|
|
|
# Done generating addresses.
|
2023-12-20 04:00:51 +01:00
|
|
|
if command in (
|
|
|
|
'createDeterministicAddresses', 'createChan', 'joinChan'
|
|
|
|
):
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.apiAddressGeneratorReturnQueue.put(
|
2015-12-05 11:18:51 +01:00
|
|
|
listOfNewAddressesToSendOutThroughTheAPI)
|
|
|
|
elif command == 'getDeterministicAddress':
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.apiAddressGeneratorReturnQueue.put(address)
|
2013-09-13 06:27:34 +02:00
|
|
|
else:
|
2021-08-20 16:54:28 +02:00
|
|
|
raise AddressGeneratorException(
|
2021-08-16 16:29:02 +02:00
|
|
|
"Error in the addressGenerator thread. Thread was"
|
|
|
|
+ " given a command it could not understand: " + command)
|
2017-02-08 13:41:56 +01:00
|
|
|
queues.addressGeneratorQueue.task_done()
|