docker: Add helper script to build docker config from fragments.
Set PIVX_PARAMSDIR automatically when usecontainers is set. Fix PIVX wallet encryption when added.
This commit is contained in:
parent
ac10c9db76
commit
9677c48f39
@ -833,7 +833,7 @@ def prepareDataDir(coin, settings, chain, particl_mnemonic, extra_opts={}):
|
|||||||
params_dir = os.path.join(data_dir, 'pivx-params')
|
params_dir = os.path.join(data_dir, 'pivx-params')
|
||||||
downloadPIVXParams(params_dir)
|
downloadPIVXParams(params_dir)
|
||||||
fp.write('prune=4000\n')
|
fp.write('prune=4000\n')
|
||||||
PIVX_PARAMSDIR = os.getenv('PIVX_PARAMSDIR', params_dir)
|
PIVX_PARAMSDIR = os.getenv('PIVX_PARAMSDIR', '/data/pivx-params' if extra_opts.get('use_containers', False) else params_dir)
|
||||||
fp.write(f'paramsdir={PIVX_PARAMSDIR}\n')
|
fp.write(f'paramsdir={PIVX_PARAMSDIR}\n')
|
||||||
if PIVX_RPC_USER != '':
|
if PIVX_RPC_USER != '':
|
||||||
fp.write('rpcauth={}:{}${}\n'.format(PIVX_RPC_USER, salt, password_to_hmac(salt, PIVX_RPC_PWD)))
|
fp.write('rpcauth={}:{}${}\n'.format(PIVX_RPC_USER, salt, password_to_hmac(salt, PIVX_RPC_PWD)))
|
||||||
@ -1085,7 +1085,7 @@ def initialise_wallets(particl_wallet_mnemonic, with_coins, data_dir, settings,
|
|||||||
try:
|
try:
|
||||||
swap_client = BasicSwap(fp, data_dir, settings, chain)
|
swap_client = BasicSwap(fp, data_dir, settings, chain)
|
||||||
|
|
||||||
coins_to_create_wallets_for = (Coins.PART, Coins.BTC, Coins.LTC, Coins.PIVX)
|
coins_to_create_wallets_for = (Coins.PART, Coins.BTC, Coins.LTC)
|
||||||
# Always start Particl, it must be running to initialise a wallet in addcoin mode
|
# Always start Particl, it must be running to initialise a wallet in addcoin mode
|
||||||
# Particl must be loaded first as subsequent coins are initialised from the Particl mnemonic
|
# Particl must be loaded first as subsequent coins are initialised from the Particl mnemonic
|
||||||
start_daemons = ['particl', ] + [c for c in with_coins if c != 'particl']
|
start_daemons = ['particl', ] + [c for c in with_coins if c != 'particl']
|
||||||
@ -1145,7 +1145,10 @@ def initialise_wallets(particl_wallet_mnemonic, with_coins, data_dir, settings,
|
|||||||
swap_client.waitForDaemonRPC(c)
|
swap_client.waitForDaemonRPC(c)
|
||||||
swap_client.initialiseWallet(c)
|
swap_client.initialiseWallet(c)
|
||||||
if WALLET_ENCRYPTION_PWD != '' and c not in coins_to_create_wallets_for:
|
if WALLET_ENCRYPTION_PWD != '' and c not in coins_to_create_wallets_for:
|
||||||
|
try:
|
||||||
swap_client.ci(c).changeWalletPassword('', WALLET_ENCRYPTION_PWD)
|
swap_client.ci(c).changeWalletPassword('', WALLET_ENCRYPTION_PWD)
|
||||||
|
except Exception as e:
|
||||||
|
logger.warning(f'changeWalletPassword failed for {coin_name}.')
|
||||||
|
|
||||||
finally:
|
finally:
|
||||||
if swap_client:
|
if swap_client:
|
||||||
|
1
docker/production/.gitignore
vendored
1
docker/production/.gitignore
vendored
@ -1,3 +1,4 @@
|
|||||||
.env
|
.env
|
||||||
docker-compose-prepare.yml
|
docker-compose-prepare.yml
|
||||||
docker-compose.yml
|
docker-compose.yml
|
||||||
|
*_bkp_*.yml
|
||||||
|
@ -11,6 +11,9 @@
|
|||||||
- ${DATA_PATH}/particl:/data/particl
|
- ${DATA_PATH}/particl:/data/particl
|
||||||
- ${DATA_PATH}/bitcoin:/data/bitcoin
|
- ${DATA_PATH}/bitcoin:/data/bitcoin
|
||||||
- ${DATA_PATH}/litecoin:/data/litecoin
|
- ${DATA_PATH}/litecoin:/data/litecoin
|
||||||
|
- ${DATA_PATH}/pivx:/data/pivx
|
||||||
|
- ${DATA_PATH}/dash:/data/dash
|
||||||
|
- ${DATA_PATH}/firo:/data/firo
|
||||||
environment:
|
environment:
|
||||||
- TZ
|
- TZ
|
||||||
- UI_HTML_PORT
|
- UI_HTML_PORT
|
||||||
@ -42,4 +45,19 @@
|
|||||||
- XMR_WALLET_RPC_USER
|
- XMR_WALLET_RPC_USER
|
||||||
- XMR_WALLET_RPC_PWD
|
- XMR_WALLET_RPC_PWD
|
||||||
- DEFAULT_XMR_RESTORE_HEIGHT
|
- DEFAULT_XMR_RESTORE_HEIGHT
|
||||||
|
- PIVX_DATA_DIR
|
||||||
|
- PIVX_RPC_HOST
|
||||||
|
- PIVX_RPC_PORT
|
||||||
|
- PIVX_RPC_USER
|
||||||
|
- PIVX_RPC_PWD
|
||||||
|
- DASH_DATA_DIR
|
||||||
|
- DASH_RPC_HOST
|
||||||
|
- DASH_RPC_PORT
|
||||||
|
- DASH_RPC_USER
|
||||||
|
- DASH_RPC_PWD
|
||||||
|
- FIRO_DATA_DIR
|
||||||
|
- FIRO_RPC_HOST
|
||||||
|
- FIRO_RPC_PORT
|
||||||
|
- FIRO_RPC_USER
|
||||||
|
- FIRO_RPC_PWD
|
||||||
restart: "no"
|
restart: "no"
|
||||||
|
@ -30,6 +30,11 @@ Set the latest Monero chain height, or the height your wallet must restore from:
|
|||||||
|
|
||||||
Create docker-compose config:
|
Create docker-compose config:
|
||||||
|
|
||||||
|
# Using the helper script:
|
||||||
|
./scripts/build_yml_files.py -c bitcoin monero
|
||||||
|
|
||||||
|
# Or
|
||||||
|
|
||||||
cat compose-fragments/0_start.yml > docker-compose.yml
|
cat compose-fragments/0_start.yml > docker-compose.yml
|
||||||
|
|
||||||
# Add the relevant coin fragments
|
# Add the relevant coin fragments
|
||||||
@ -124,6 +129,20 @@ Start BasicSwap:
|
|||||||
|
|
||||||
## Add a coin
|
## Add a coin
|
||||||
|
|
||||||
|
|
||||||
|
Stop all running containers
|
||||||
|
|
||||||
|
docker-compose stop
|
||||||
|
|
||||||
|
|
||||||
|
Update docker-compose config:
|
||||||
|
|
||||||
|
Rebuild using the helper script (must list all enabled coins):
|
||||||
|
|
||||||
|
./scripts/build_yml_files.py -c bitcoin monero
|
||||||
|
|
||||||
|
Or
|
||||||
|
|
||||||
cat compose-fragments/1_monero-wallet.yml >> docker-compose.yml
|
cat compose-fragments/1_monero-wallet.yml >> docker-compose.yml
|
||||||
cat compose-fragments/1_monero-wallet.yml >> docker-compose-prepare.yml
|
cat compose-fragments/1_monero-wallet.yml >> docker-compose-prepare.yml
|
||||||
|
|
||||||
@ -131,10 +150,16 @@ Start BasicSwap:
|
|||||||
cat compose-fragments/8_monero-daemon.yml >> docker-compose.yml
|
cat compose-fragments/8_monero-daemon.yml >> docker-compose.yml
|
||||||
|
|
||||||
|
|
||||||
|
Prepare config files:
|
||||||
|
|
||||||
|
docker-compose -f docker-compose-prepare.yml build swapprepare
|
||||||
|
|
||||||
export ADD_COIN=monero
|
export ADD_COIN=monero
|
||||||
docker-compose -f docker-compose-prepare.yml run --rm swapprepare \
|
docker-compose -f docker-compose-prepare.yml run --rm swapprepare \
|
||||||
basicswap-prepare --nocores --addcoin=${ADD_COIN} --htmlhost="0.0.0.0" --particl_mnemonic=none
|
basicswap-prepare --nocores --usecontainers --addcoin=${ADD_COIN} --htmlhost="0.0.0.0" --particl_mnemonic=none
|
||||||
|
|
||||||
|
|
||||||
|
Prepare wallet:
|
||||||
|
|
||||||
docker-compose build monero_daemon
|
docker-compose build monero_daemon
|
||||||
docker-compose build
|
docker-compose build
|
||||||
|
83
docker/production/scripts/build_yml_files.py
Executable file
83
docker/production/scripts/build_yml_files.py
Executable file
@ -0,0 +1,83 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
# Copyright (c) 2023 tecnovert
|
||||||
|
# Distributed under the MIT software license, see the accompanying
|
||||||
|
# file LICENSE or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
|
"""
|
||||||
|
Join docker compose fragments
|
||||||
|
"""
|
||||||
|
|
||||||
|
__version__ = '0.1'
|
||||||
|
|
||||||
|
import os
|
||||||
|
import argparse
|
||||||
|
|
||||||
|
|
||||||
|
def get_bkp_offset(filename, ext='yml'):
|
||||||
|
for i in range(1000):
|
||||||
|
if not os.path.exists(f'{filename}_bkp_{i}.{ext}'):
|
||||||
|
return i
|
||||||
|
raise ValueError(f'Unable to get backup filename for: {filename}.{ext}')
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
parser = argparse.ArgumentParser(description=__doc__)
|
||||||
|
parser.add_argument('-v', '--version', action='version',
|
||||||
|
version='%(prog)s {version}'.format(version=__version__))
|
||||||
|
parser.add_argument('-c', '--coins', nargs='+', help='<Required> Select coins', required=True)
|
||||||
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
with_coins = ['particl', ]
|
||||||
|
for coin_name in args.coins:
|
||||||
|
parsed_name = coin_name.lower()
|
||||||
|
if parsed_name not in with_coins:
|
||||||
|
with_coins.append(parsed_name)
|
||||||
|
|
||||||
|
print('Preparing docker compose files with coins:', ','.join(with_coins))
|
||||||
|
|
||||||
|
num_docker_compose = get_bkp_offset('docker-compose')
|
||||||
|
num_docker_compose_prepare = get_bkp_offset('docker-compose-prepare')
|
||||||
|
|
||||||
|
if os.path.exists('docker-compose.yml'):
|
||||||
|
os.rename('docker-compose.yml', f'docker-compose_bkp_{num_docker_compose}.yml')
|
||||||
|
if os.path.exists('docker-compose-prepare.yml'):
|
||||||
|
os.rename('docker-compose-prepare.yml', f'docker-compose-prepare_bkp_{num_docker_compose_prepare}.yml')
|
||||||
|
|
||||||
|
fragments_dir = 'compose-fragments'
|
||||||
|
with open('docker-compose.yml', 'wb') as fp, open('docker-compose-prepare.yml', 'wb') as fpp:
|
||||||
|
with open(os.path.join(fragments_dir, '0_start.yml'), 'rb') as fp_in:
|
||||||
|
for line in fp_in:
|
||||||
|
fp.write(line)
|
||||||
|
fpp.write(line)
|
||||||
|
|
||||||
|
for coin_name in with_coins:
|
||||||
|
if coin_name == 'particl':
|
||||||
|
# Nothing to do
|
||||||
|
continue
|
||||||
|
if coin_name == 'monero':
|
||||||
|
with open(os.path.join(fragments_dir, '1_monero-wallet.yml'), 'rb') as fp_in:
|
||||||
|
for line in fp_in:
|
||||||
|
fp.write(line)
|
||||||
|
fpp.write(line)
|
||||||
|
with open(os.path.join(fragments_dir, '8_monero-daemon.yml'), 'rb') as fp_in:
|
||||||
|
for line in fp_in:
|
||||||
|
fp.write(line)
|
||||||
|
continue
|
||||||
|
with open(os.path.join(fragments_dir, f'1_{coin_name}.yml'), 'rb') as fp_in:
|
||||||
|
for line in fp_in:
|
||||||
|
fp.write(line)
|
||||||
|
fpp.write(line)
|
||||||
|
|
||||||
|
with open(os.path.join(fragments_dir, '8_swapclient.yml'), 'rb') as fp_in:
|
||||||
|
for line in fp_in:
|
||||||
|
fp.write(line)
|
||||||
|
with open(os.path.join(fragments_dir, '9_swapprepare.yml'), 'rb') as fp_in:
|
||||||
|
for line in fp_in:
|
||||||
|
fpp.write(line)
|
||||||
|
print('Done.')
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
Loading…
Reference in New Issue
Block a user