Set Bitcoincash .conf file and port from basicswap.json.

This commit is contained in:
tecnovert 2024-11-02 11:17:00 +02:00
parent 5df9b044ab
commit 5ee28d0aa3
No known key found for this signature in database
GPG key ID: 8ED6D8750C4E3F93
6 changed files with 82 additions and 43 deletions

View file

@ -20,7 +20,7 @@ jobs:
pip install flake8 codespell pip install flake8 codespell
- name: Running flake8 - name: Running flake8
run: | run: |
PYTHONWARNINGS="ignore" flake8 --ignore=E501,F841,W503 --exclude=basicswap/contrib,basicswap/interface/contrib,messages_pb2.py,.eggs,.tox,bin/install_certifi.py flake8 --ignore=E501,F841,W503 --per-file-ignores="basicswap/interface/bch.py:E131,E702" --exclude=basicswap/contrib,basicswap/interface/contrib,messages_pb2.py,.eggs,.tox,bin/install_certifi.py
- name: Running codespell - name: Running codespell
run: | run: |
codespell --check-filenames --disable-colors --quiet-level=7 --ignore-words=tests/lint/spelling.ignore-words.txt -S .git,.eggs,.tox,pgp,*.pyc,*basicswap/contrib,*basicswap/interface/contrib,*mnemonics.py,bin/install_certifi.py,*basicswap/static codespell --check-filenames --disable-colors --quiet-level=7 --ignore-words=tests/lint/spelling.ignore-words.txt -S .git,.eggs,.tox,pgp,*.pyc,*basicswap/contrib,*basicswap/interface/contrib,*mnemonics.py,bin/install_certifi.py,*basicswap/static

View file

@ -37,7 +37,7 @@ from basicswap.ui.util import getCoinName
from basicswap.util import toBool from basicswap.util import toBool
from basicswap.util.network import urlretrieve, make_reporthook from basicswap.util.network import urlretrieve, make_reporthook
from basicswap.util.rfc2440 import rfc2440_hash_password from basicswap.util.rfc2440 import rfc2440_hash_password
from basicswap.bin.run import startDaemon, startXmrWalletDaemon from basicswap.bin.run import startDaemon, startXmrWalletDaemon, getCoreBinName, getCoreBinArgs, getWalletBinName
PARTICL_VERSION = os.getenv('PARTICL_VERSION', '23.2.7.0') PARTICL_VERSION = os.getenv('PARTICL_VERSION', '23.2.7.0')
PARTICL_VERSION_TAG = os.getenv('PARTICL_VERSION_TAG', '') PARTICL_VERSION_TAG = os.getenv('PARTICL_VERSION_TAG', '')
@ -140,7 +140,8 @@ BIN_ARCH = os.getenv('BIN_ARCH', BIN_ARCH)
FILE_EXT = os.getenv('FILE_EXT', FILE_EXT) FILE_EXT = os.getenv('FILE_EXT', FILE_EXT)
logger = logging.getLogger() logger = logging.getLogger()
logger.level = logging.INFO LOG_LEVEL = logging.DEBUG
logger.level = LOG_LEVEL
if not len(logger.handlers): if not len(logger.handlers):
logger.addHandler(logging.StreamHandler(sys.stdout)) logger.addHandler(logging.StreamHandler(sys.stdout))
@ -193,7 +194,8 @@ BTC_RPC_PWD = os.getenv('BTC_RPC_PWD', '')
BCH_RPC_HOST = os.getenv('BCH_RPC_HOST', '127.0.0.1') BCH_RPC_HOST = os.getenv('BCH_RPC_HOST', '127.0.0.1')
BCH_RPC_PORT = int(os.getenv('BCH_RPC_PORT', 19997)) BCH_RPC_PORT = int(os.getenv('BCH_RPC_PORT', 19997))
BCH_ONION_PORT = int(os.getenv('BCH_ONION_PORT', 8334)) BCH_ONION_PORT = int(os.getenv('BCH_ONION_PORT', 8335))
BCH_PORT = int(os.getenv('BCH_PORT', 19798))
BCH_RPC_USER = os.getenv('BCH_RPC_USER', '') BCH_RPC_USER = os.getenv('BCH_RPC_USER', '')
BCH_RPC_PWD = os.getenv('BCH_RPC_PWD', '') BCH_RPC_PWD = os.getenv('BCH_RPC_PWD', '')
@ -319,6 +321,7 @@ def setConnectionParameters(timeout: int = 5, allow_set_tor: bool = True):
# Set low timeout for urlretrieve connections # Set low timeout for urlretrieve connections
socket.setdefaulttimeout(timeout) socket.setdefaulttimeout(timeout)
logger.level = logging.INFO
def popConnectionParameters() -> None: def popConnectionParameters() -> None:
@ -326,6 +329,7 @@ def popConnectionParameters() -> None:
socket.socket = default_socket socket.socket = default_socket
socket.getaddrinfo = default_socket_getaddrinfo socket.getaddrinfo = default_socket_getaddrinfo
socket.setdefaulttimeout(default_socket_timeout) socket.setdefaulttimeout(default_socket_timeout)
logger.level = LOG_LEVEL
def getRemoteFileLength(url: str) -> (int, bool): def getRemoteFileLength(url: str) -> (int, bool):
@ -893,7 +897,8 @@ def prepareDataDir(coin, settings, chain, particl_mnemonic, extra_opts={}):
os.makedirs(data_dir) os.makedirs(data_dir)
if coin in ('wownero', 'monero'): if coin in ('wownero', 'monero'):
core_conf_path = os.path.join(data_dir, coin + 'd.conf') conf_filename: str = core_settings.get('config_filename', coin + 'd.conf')
core_conf_path = os.path.join(data_dir, conf_filename)
if os.path.exists(core_conf_path): if os.path.exists(core_conf_path):
exitWithError('{} exists'.format(core_conf_path)) exitWithError('{} exists'.format(core_conf_path))
with open(core_conf_path, 'w') as fp: with open(core_conf_path, 'w') as fp:
@ -934,9 +939,8 @@ def prepareDataDir(coin, settings, chain, particl_mnemonic, extra_opts={}):
if not os.path.exists(wallets_dir): if not os.path.exists(wallets_dir):
os.makedirs(wallets_dir) os.makedirs(wallets_dir)
wallet_conf_path = os.path.join(wallets_dir, coin + '-wallet-rpc.conf') wallet_conf_filename: str = core_settings.get('wallet_config_filename', 'monero_wallet.conf' if coin == 'monero' else (coin + '-wallet-rpc.conf'))
if coin == 'monero': wallet_conf_path = os.path.join(wallets_dir, wallet_conf_filename)
wallet_conf_path = os.path.join(wallets_dir, 'monero_wallet.conf')
if os.path.exists(wallet_conf_path): if os.path.exists(wallet_conf_path):
exitWithError('{} exists'.format(wallet_conf_path)) exitWithError('{} exists'.format(wallet_conf_path))
with open(wallet_conf_path, 'w') as fp: with open(wallet_conf_path, 'w') as fp:
@ -966,7 +970,8 @@ def prepareDataDir(coin, settings, chain, particl_mnemonic, extra_opts={}):
if coin == 'decred': if coin == 'decred':
chainname = 'simnet' if chain == 'regtest' else chain chainname = 'simnet' if chain == 'regtest' else chain
core_conf_path = os.path.join(data_dir, 'dcrd.conf') conf_filename: str = core_settings.get('config_filename', 'dcrd.conf')
core_conf_path = os.path.join(data_dir, conf_filename)
if os.path.exists(core_conf_path): if os.path.exists(core_conf_path):
exitWithError('{} exists'.format(core_conf_path)) exitWithError('{} exists'.format(core_conf_path))
with open(core_conf_path, 'w') as fp: with open(core_conf_path, 'w') as fp:
@ -983,7 +988,8 @@ def prepareDataDir(coin, settings, chain, particl_mnemonic, extra_opts={}):
if tor_control_password is not None: if tor_control_password is not None:
writeTorSettings(fp, coin, core_settings, tor_control_password) writeTorSettings(fp, coin, core_settings, tor_control_password)
wallet_conf_path = os.path.join(data_dir, 'dcrwallet.conf') wallet_conf_filename: str = core_settings.get('wallet_config_filename', 'dcrwallet.conf')
wallet_conf_path = os.path.join(data_dir, wallet_conf_filename)
if os.path.exists(wallet_conf_path): if os.path.exists(wallet_conf_path):
exitWithError('{} exists'.format(wallet_conf_path)) exitWithError('{} exists'.format(wallet_conf_path))
with open(wallet_conf_path, 'w') as fp: with open(wallet_conf_path, 'w') as fp:
@ -1001,8 +1007,8 @@ def prepareDataDir(coin, settings, chain, particl_mnemonic, extra_opts={}):
return return
core_conf_name: str = 'bitcoin.conf' if coin == 'bitcoincash' else coin + '.conf' core_conf_name: str = core_settings.get('config_filename', coin + '.conf')
core_conf_path: str = os.path.join(data_dir, core_conf_name) core_conf_path = os.path.join(data_dir, core_conf_name)
if os.path.exists(core_conf_path): if os.path.exists(core_conf_path):
exitWithError('{} exists'.format(core_conf_path)) exitWithError('{} exists'.format(core_conf_path))
with open(core_conf_path, 'w') as fp: with open(core_conf_path, 'w') as fp:
@ -1136,14 +1142,14 @@ def modify_tor_config(settings, coin, tor_control_password=None, enable=False, e
data_dir = coin_settings['datadir'] data_dir = coin_settings['datadir']
if coin in ('monero', 'wownero'): if coin in ('monero', 'wownero'):
core_conf_path = os.path.join(data_dir, coin + 'd.conf') core_conf_name: str = coin_settings.get('config_filename', coin + 'd.conf')
core_conf_path = os.path.join(data_dir, core_conf_name)
if not os.path.exists(core_conf_path): if not os.path.exists(core_conf_path):
exitWithError('{} does not exist'.format(core_conf_path)) exitWithError('{} does not exist'.format(core_conf_path))
wallets_dir = coin_settings.get('walletsdir', data_dir) wallets_dir = coin_settings.get('walletsdir', data_dir)
wallet_conf_path = os.path.join(wallets_dir, coin + '-wallet-rpc.conf') wallet_conf_filename: str = coin_settings.get('wallet_config_filename', 'monero_wallet.conf' if coin == 'monero' else (coin + '-wallet-rpc.conf'))
if coin == 'monero': wallet_conf_path = os.path.join(wallets_dir, wallet_conf_filename)
wallet_conf_path = os.path.join(wallets_dir, 'monero_wallet.conf')
if not os.path.exists(wallet_conf_path): if not os.path.exists(wallet_conf_path):
exitWithError('{} does not exist'.format(wallet_conf_path)) exitWithError('{} does not exist'.format(wallet_conf_path))
@ -1198,10 +1204,8 @@ def modify_tor_config(settings, coin, tor_control_password=None, enable=False, e
coin_settings['trusted_daemon'] = extra_opts.get('trust_remote_node', 'auto') coin_settings['trusted_daemon'] = extra_opts.get('trust_remote_node', 'auto')
return return
if coin == 'decred': core_conf_name: str = coin_settings.get('config_filename', 'dcrd.conf' if coin == 'decred' else (coin + '.conf'))
config_path = os.path.join(data_dir, 'dcrd.conf') config_path = os.path.join(data_dir, core_conf_name)
else:
config_path = os.path.join(data_dir, coin + '.conf')
if not os.path.exists(config_path): if not os.path.exists(config_path):
exitWithError('{} does not exist'.format(config_path)) exitWithError('{} does not exist'.format(config_path))
@ -1322,8 +1326,9 @@ def test_particl_encryption(data_dir, settings, chain, use_tor_proxy):
c = Coins.PART c = Coins.PART
coin_name = 'particl' coin_name = 'particl'
coin_settings = settings['chainclients'][coin_name] coin_settings = settings['chainclients'][coin_name]
daemon_args += getCoreBinArgs(c, coin_settings)
if coin_settings['manage_daemon']: if coin_settings['manage_daemon']:
filename = coin_name + 'd' + ('.exe' if os.name == 'nt' else '') filename: str = getCoreBinName(c, coin_settings, coin_name + 'd')
daemons.append(startDaemon(coin_settings['datadir'], coin_settings['bindir'], filename, daemon_args)) daemons.append(startDaemon(coin_settings['datadir'], coin_settings['bindir'], filename, daemon_args))
swap_client.setDaemonPID(c, daemons[-1].handle.pid) swap_client.setDaemonPID(c, daemons[-1].handle.pid)
swap_client.setCoinRunParams(c) swap_client.setCoinRunParams(c)
@ -1374,17 +1379,19 @@ def initialise_wallets(particl_wallet_mnemonic, with_coins, data_dir, settings,
if c == Coins.XMR: if c == Coins.XMR:
if coin_settings['manage_wallet_daemon']: if coin_settings['manage_wallet_daemon']:
filename = coin_name + '-wallet-rpc' + ('.exe' if os.name == 'nt' else '') filename = coin_name + '-wallet-rpc' + ('.exe' if os.name == 'nt' else '')
filename: str = getWalletBinName(c, coin_settings, coin_name + '-wallet-rpc')
daemons.append(startXmrWalletDaemon(coin_settings['datadir'], coin_settings['bindir'], filename)) daemons.append(startXmrWalletDaemon(coin_settings['datadir'], coin_settings['bindir'], filename))
elif c == Coins.WOW: elif c == Coins.WOW:
if coin_settings['manage_wallet_daemon']: if coin_settings['manage_wallet_daemon']:
filename = coin_name + '-wallet-rpc' + ('.exe' if os.name == 'nt' else '') filename: str = getWalletBinName(c, coin_settings, coin_name + '-wallet-rpc')
daemons.append(startXmrWalletDaemon(coin_settings['datadir'], coin_settings['bindir'], filename)) daemons.append(startXmrWalletDaemon(coin_settings['datadir'], coin_settings['bindir'], filename))
elif c == Coins.DCR: elif c == Coins.DCR:
pass pass
else: else:
if coin_settings['manage_daemon']: if coin_settings['manage_daemon']:
filename = (coin_name if not coin_name == "bitcoincash" else "bitcoin") + 'd' + ('.exe' if os.name == 'nt' else '') filename: str = getCoreBinName(c, coin_settings, coin_name + 'd')
coin_args = ['-nofindpeers', '-nostaking'] if c == Coins.PART else [] coin_args = ['-nofindpeers', '-nostaking'] if c == Coins.PART else []
coin_args += getCoreBinArgs(c, coin_settings)
if c == Coins.FIRO: if c == Coins.FIRO:
coin_args += ['-hdseed={}'.format(swap_client.getWalletKey(Coins.FIRO, 1).hex())] coin_args += ['-hdseed={}'.format(swap_client.getWalletKey(Coins.FIRO, 1).hex())]
@ -1405,7 +1412,7 @@ def initialise_wallets(particl_wallet_mnemonic, with_coins, data_dir, settings,
'--pass={}'.format(dcr_password), '--pass={}'.format(dcr_password),
] ]
filename = 'dcrwallet' + ('.exe' if os.name == 'nt' else '') filename: str = getWalletBinName(c, coin_settings, 'dcrwallet')
args = [os.path.join(coin_settings['bindir'], filename), '--create'] + extra_opts args = [os.path.join(coin_settings['bindir'], filename), '--create'] + extra_opts
hex_seed = swap_client.getWalletKey(Coins.DCR, 1).hex() hex_seed = swap_client.getWalletKey(Coins.DCR, 1).hex()
createDCRWallet(args, hex_seed, logger, threading.Event()) createDCRWallet(args, hex_seed, logger, threading.Event())
@ -1786,13 +1793,15 @@ def main():
'core_version_group': 22, 'core_version_group': 22,
}, },
'bitcoincash': { 'bitcoincash': {
'connection_type': 'rpc' if 'bitcoincash' in with_coins else 'none', 'connection_type': 'rpc',
'manage_daemon': True if ('bitcoincash' in with_coins and BCH_RPC_HOST == '127.0.0.1') else False, 'manage_daemon': shouldManageDaemon('BCH'),
'rpchost': BCH_RPC_HOST, 'rpchost': BCH_RPC_HOST,
'rpcport': BCH_RPC_PORT + port_offset, 'rpcport': BCH_RPC_PORT + port_offset,
'onionport': BCH_ONION_PORT + port_offset, 'onionport': BCH_ONION_PORT + port_offset,
'datadir': os.getenv('BCH_DATA_DIR', os.path.join(data_dir, 'bitcoincash')), 'datadir': os.getenv('BCH_DATA_DIR', os.path.join(data_dir, 'bitcoincash')),
'bindir': os.path.join(bin_dir, 'bitcoincash'), 'bindir': os.path.join(bin_dir, 'bitcoincash'),
'port': BCH_PORT + port_offset,
'config_filename': 'bitcoin.conf',
'use_segwit': False, 'use_segwit': False,
'blocks_confirmed': 1, 'blocks_confirmed': 1,
'conf_target': 2, 'conf_target': 2,
@ -1830,6 +1839,7 @@ def main():
'blocks_confirmed': 2, 'blocks_confirmed': 2,
'conf_target': 2, 'conf_target': 2,
'core_type_group': 'dcr', 'core_type_group': 'dcr',
'config_filename': 'dcrd.conf',
'min_relay_fee': 0.00001, 'min_relay_fee': 0.00001,
}, },
'namecoin': { 'namecoin': {
@ -1866,6 +1876,7 @@ def main():
'rpctimeout': 60, 'rpctimeout': 60,
'walletrpctimeout': 120, 'walletrpctimeout': 120,
'walletrpctimeoutlong': 600, 'walletrpctimeoutlong': 600,
'wallet_config_filename': 'monero_wallet.conf',
'core_type_group': 'xmr', 'core_type_group': 'xmr',
}, },
'pivx': { 'pivx': {

View file

@ -69,7 +69,7 @@ def startDaemon(node_dir, bin_dir, daemon_bin, opts=[], extra_config={}):
config_to_add.remove(line) config_to_add.remove(line)
if len(config_to_add) > 0: if len(config_to_add) > 0:
logging.info('Rewriting litecoin.conf') logger.info('Rewriting litecoin.conf')
shutil.copyfile(ltc_conf_path, ltc_conf_path + '.last') shutil.copyfile(ltc_conf_path, ltc_conf_path + '.last')
with open(ltc_conf_path, 'a') as fp: with open(ltc_conf_path, 'a') as fp:
for line in config_to_add: for line in config_to_add:
@ -80,7 +80,8 @@ def startDaemon(node_dir, bin_dir, daemon_bin, opts=[], extra_config={}):
if add_datadir: if add_datadir:
args.append('-datadir=' + datadir_path) args.append('-datadir=' + datadir_path)
args += opts args += opts
logging.info('Starting node ' + daemon_bin + ' ' + (('-datadir=' + node_dir) if add_datadir else '')) logger.info('Starting node {}'.format(daemon_bin))
logger.debug('Arguments {}'.format(' '.join(args)))
opened_files = [] opened_files = []
if extra_config.get('stdout_to_file', False): if extra_config.get('stdout_to_file', False):
@ -103,7 +104,8 @@ def startXmrDaemon(node_dir, bin_dir, daemon_bin, opts=[]):
datadir_path = os.path.expanduser(node_dir) datadir_path = os.path.expanduser(node_dir)
config_filename = 'wownerod.conf' if daemon_bin.startswith('wow') else 'monerod.conf' config_filename = 'wownerod.conf' if daemon_bin.startswith('wow') else 'monerod.conf'
args = [daemon_path, '--non-interactive', '--config-file=' + os.path.join(datadir_path, config_filename)] + opts args = [daemon_path, '--non-interactive', '--config-file=' + os.path.join(datadir_path, config_filename)] + opts
logging.info('Starting node {} --data-dir={}'.format(daemon_path, node_dir)) logger.info('Starting node {}'.format(daemon_bin))
logger.debug('Arguments {}'.format(' '.join(args)))
# return subprocess.Popen(args, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE) # return subprocess.Popen(args, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
file_stdout = open(os.path.join(datadir_path, 'core_stdout.log'), 'w') file_stdout = open(os.path.join(datadir_path, 'core_stdout.log'), 'w')
@ -112,8 +114,8 @@ def startXmrDaemon(node_dir, bin_dir, daemon_bin, opts=[]):
def startXmrWalletDaemon(node_dir, bin_dir, wallet_bin, opts=[]): def startXmrWalletDaemon(node_dir, bin_dir, wallet_bin, opts=[]):
daemon_bin = os.path.expanduser(os.path.join(bin_dir, wallet_bin)) daemon_path = os.path.expanduser(os.path.join(bin_dir, wallet_bin))
args = [daemon_bin, '--non-interactive'] args = [daemon_path, '--non-interactive']
needs_rewrite: bool = False needs_rewrite: bool = False
config_to_remove = ['daemon-address=', 'untrusted-daemon=', 'trusted-daemon=', 'proxy='] config_to_remove = ['daemon-address=', 'untrusted-daemon=', 'trusted-daemon=', 'proxy=']
@ -127,19 +129,20 @@ def startXmrWalletDaemon(node_dir, bin_dir, wallet_bin, opts=[]):
with open(config_path) as fp: with open(config_path) as fp:
for line in fp: for line in fp:
if any(line.startswith(config_line) for config_line in config_to_remove): if any(line.startswith(config_line) for config_line in config_to_remove):
logging.warning('Found old config in monero_wallet.conf: {}'.format(line.strip())) logger.warning('Found old config in monero_wallet.conf: {}'.format(line.strip()))
needs_rewrite = True needs_rewrite = True
args += opts args += opts
if needs_rewrite: if needs_rewrite:
logging.info('Rewriting wallet config') logger.info('Rewriting wallet config')
shutil.copyfile(config_path, config_path + '.last') shutil.copyfile(config_path, config_path + '.last')
with open(config_path + '.last') as fp_from, open(config_path, 'w') as fp_to: with open(config_path + '.last') as fp_from, open(config_path, 'w') as fp_to:
for line in fp_from: for line in fp_from:
if not any(line.startswith(config_line) for config_line in config_to_remove): if not any(line.startswith(config_line) for config_line in config_to_remove):
fp_to.write(line) fp_to.write(line)
logging.info('Starting wallet daemon {} --wallet-dir={}'.format(daemon_bin, node_dir)) logger.info('Starting wallet daemon {}'.format(wallet_bin))
logger.debug('Arguments {}'.format(' '.join(args)))
# TODO: return subprocess.Popen(args, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, cwd=data_dir) # TODO: return subprocess.Popen(args, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, cwd=data_dir)
wallet_stdout = open(os.path.join(data_dir, 'wallet_stdout.log'), 'w') wallet_stdout = open(os.path.join(data_dir, 'wallet_stdout.log'), 'w')
@ -166,8 +169,25 @@ def ws_message_received(client, server, message):
swap_client.log.debug(f'ws_message_received {client["id"]} {message}') swap_client.log.debug(f'ws_message_received {client["id"]} {message}')
def getCoreBinName(coin_id: int, coin_settings, default_name: str) -> str:
return coin_settings.get('core_binname', chainparams[coin_id].get('core_binname', default_name)) + ('.exe' if os.name == 'nt' else '')
def getWalletBinName(coin_id: int, coin_settings, default_name: str) -> str:
return coin_settings.get('wallet_binname', chainparams[coin_id].get('wallet_binname', default_name)) + ('.exe' if os.name == 'nt' else '')
def getCoreBinArgs(coin_id: int, coin_settings):
extra_args = []
if 'config_filename' in coin_settings:
extra_args.append('--conf=' + coin_settings['config_filename'])
if 'port' in coin_settings:
extra_args.append('--port=' + str(int(coin_settings['port'])))
return extra_args
def runClient(fp, data_dir, chain, start_only_coins): def runClient(fp, data_dir, chain, start_only_coins):
global swap_client global swap_client, logger
daemons = [] daemons = []
pids = [] pids = []
threads = [] threads = []
@ -188,6 +208,7 @@ def runClient(fp, data_dir, chain, start_only_coins):
settings = json.load(fs) settings = json.load(fs)
swap_client = BasicSwap(fp, data_dir, settings, chain) swap_client = BasicSwap(fp, data_dir, settings, chain)
logger = swap_client.log
if os.path.exists(pids_path): if os.path.exists(pids_path):
with open(pids_path) as fd: with open(pids_path) as fd:
@ -214,7 +235,8 @@ def runClient(fp, data_dir, chain, start_only_coins):
if c in ('monero', 'wownero'): if c in ('monero', 'wownero'):
if v['manage_daemon'] is True: if v['manage_daemon'] is True:
swap_client.log.info(f'Starting {display_name} daemon') swap_client.log.info(f'Starting {display_name} daemon')
filename = (c if not c == "bitcoincash" else "bitcoin") + 'd' + ('.exe' if os.name == 'nt' else '') filename: str = getCoreBinName(coin_id, v, c + 'd')
daemons.append(startXmrDaemon(v['datadir'], v['bindir'], filename)) daemons.append(startXmrDaemon(v['datadir'], v['bindir'], filename))
pid = daemons[-1].handle.pid pid = daemons[-1].handle.pid
swap_client.log.info('Started {} {}'.format(filename, pid)) swap_client.log.info('Started {} {}'.format(filename, pid))
@ -240,7 +262,8 @@ def runClient(fp, data_dir, chain, start_only_coins):
opts.append(daemon_rpcuser + ':' + daemon_rpcpass) opts.append(daemon_rpcuser + ':' + daemon_rpcpass)
opts.append('--trusted-daemon' if trusted_daemon else '--untrusted-daemon') opts.append('--trusted-daemon' if trusted_daemon else '--untrusted-daemon')
filename = c + '-wallet-rpc' + ('.exe' if os.name == 'nt' else '') filename: str = getWalletBinName(coin_id, v, c + '-wallet-rpc')
daemons.append(startXmrWalletDaemon(v['datadir'], v['bindir'], filename, opts)) daemons.append(startXmrWalletDaemon(v['datadir'], v['bindir'], filename, opts))
pid = daemons[-1].handle.pid pid = daemons[-1].handle.pid
swap_client.log.info('Started {} {}'.format(filename, pid)) swap_client.log.info('Started {} {}'.format(filename, pid))
@ -253,7 +276,7 @@ def runClient(fp, data_dir, chain, start_only_coins):
use_shell: bool = True if os.name == 'nt' else False use_shell: bool = True if os.name == 'nt' else False
if v['manage_daemon'] is True: if v['manage_daemon'] is True:
swap_client.log.info(f'Starting {display_name} daemon') swap_client.log.info(f'Starting {display_name} daemon')
filename = 'dcrd' + ('.exe' if os.name == 'nt' else '') filename: str = getCoreBinName(coin_id, v, 'dcrd')
extra_config = {'add_datadir': False, 'stdout_to_file': True, 'stdout_filename': 'dcrd_stdout.log', 'use_shell': use_shell} extra_config = {'add_datadir': False, 'stdout_to_file': True, 'stdout_filename': 'dcrd_stdout.log', 'use_shell': use_shell}
daemons.append(startDaemon(appdata, v['bindir'], filename, opts=extra_opts, extra_config=extra_config)) daemons.append(startDaemon(appdata, v['bindir'], filename, opts=extra_opts, extra_config=extra_config))
@ -262,7 +285,7 @@ def runClient(fp, data_dir, chain, start_only_coins):
if v['manage_wallet_daemon'] is True: if v['manage_wallet_daemon'] is True:
swap_client.log.info(f'Starting {display_name} wallet daemon') swap_client.log.info(f'Starting {display_name} wallet daemon')
filename = 'dcrwallet' + ('.exe' if os.name == 'nt' else '') filename: str = getWalletBinName(coin_id, v, 'dcrwallet')
wallet_pwd = v['wallet_pwd'] wallet_pwd = v['wallet_pwd']
if wallet_pwd == '': if wallet_pwd == '':
@ -280,8 +303,9 @@ def runClient(fp, data_dir, chain, start_only_coins):
if v['manage_daemon'] is True: if v['manage_daemon'] is True:
swap_client.log.info(f'Starting {display_name} daemon') swap_client.log.info(f'Starting {display_name} daemon')
filename = (c if not c == "bitcoincash" else "bitcoin") + 'd' + ('.exe' if os.name == 'nt' else '') filename: str = getCoreBinName(coin_id, v, c + 'd')
daemons.append(startDaemon(v['datadir'], v['bindir'], filename)) extra_opts = getCoreBinArgs(coin_id, v)
daemons.append(startDaemon(v['datadir'], v['bindir'], filename, opts=extra_opts))
pid = daemons[-1].handle.pid pid = daemons[-1].handle.pid
pids.append((c, pid)) pids.append((c, pid))
swap_client.setDaemonPID(c, pid) swap_client.setDaemonPID(c, pid)

View file

@ -444,6 +444,7 @@ chainparams = {
'has_csv': True, 'has_csv': True,
'has_segwit': False, 'has_segwit': False,
'cli_binname': 'bitcoin-cli', 'cli_binname': 'bitcoin-cli',
'core_binname': 'bitcoind',
'mainnet': { 'mainnet': {
'rpcport': 8332, 'rpcport': 8332,
'pubkey_address': 0, 'pubkey_address': 0,

View file

@ -239,6 +239,7 @@ class BCHInterface(BTCInterface):
public_key: bytes = kwargs['public_key'] if 'public_key' in kwargs else Kal public_key: bytes = kwargs['public_key'] if 'public_key' in kwargs else Kal
timelock: int = kwargs['timelock'] timelock: int = kwargs['timelock']
# fmt: off
return CScript([ return CScript([
# // v4.1.0-CashTokens-Optimized # // v4.1.0-CashTokens-Optimized
# // Based on swaplock.cash v4.1.0-CashTokens # // Based on swaplock.cash v4.1.0-CashTokens
@ -313,6 +314,7 @@ class BCHInterface(BTCInterface):
# // BCH and/or CashTokens are simply forwarded to Refund contract. # // BCH and/or CashTokens are simply forwarded to Refund contract.
OP_ENDIF OP_ENDIF
]) ])
# fmt: on
def pubkey_to_segwit_address(self, pk: bytes) -> str: def pubkey_to_segwit_address(self, pk: bytes) -> str:
raise NotImplementedError() raise NotImplementedError()

View file

@ -105,6 +105,7 @@ def run_prepare(node_id, datadir_path, bins_path, with_coins, mnemonic_in=None,
os.environ['BTC_RPC_PORT'] = str(BITCOIN_RPC_PORT_BASE) os.environ['BTC_RPC_PORT'] = str(BITCOIN_RPC_PORT_BASE)
os.environ['LTC_RPC_PORT'] = str(LITECOIN_RPC_PORT_BASE) os.environ['LTC_RPC_PORT'] = str(LITECOIN_RPC_PORT_BASE)
os.environ['DCR_RPC_PORT'] = str(DECRED_RPC_PORT_BASE) os.environ['DCR_RPC_PORT'] = str(DECRED_RPC_PORT_BASE)
os.environ['BCH_PORT'] = str(BCH_BASE_PORT)
os.environ['BCH_RPC_PORT'] = str(BITCOINCASH_RPC_PORT_BASE) os.environ['BCH_RPC_PORT'] = str(BITCOINCASH_RPC_PORT_BASE)
os.environ['FIRO_RPC_PORT'] = str(FIRO_RPC_PORT_BASE) os.environ['FIRO_RPC_PORT'] = str(FIRO_RPC_PORT_BASE)
@ -329,7 +330,7 @@ def run_prepare(node_id, datadir_path, bins_path, with_coins, mnemonic_in=None,
for line in lines: for line in lines:
if not line.startswith('prune'): if not line.startswith('prune'):
fp.write(line) fp.write(line)
fp.write('port={}\n'.format(BCH_BASE_PORT + node_id + port_ofs)) # NOTE: port is set (when starting daemon) from basicswap.json
fp.write('bind=127.0.0.1\n') fp.write('bind=127.0.0.1\n')
fp.write('dnsseed=0\n') fp.write('dnsseed=0\n')
fp.write('discover=0\n') fp.write('discover=0\n')