joinmarket: automatically generate wallet
This commit is contained in:
parent
d6d3e8ff62
commit
d0701f518c
|
@ -19,6 +19,7 @@ let
|
||||||
${config.services.nbxplorer.dataDir}
|
${config.services.nbxplorer.dataDir}
|
||||||
${config.services.btcpayserver.dataDir}
|
${config.services.btcpayserver.dataDir}
|
||||||
${config.services.joinmarket.dataDir}
|
${config.services.joinmarket.dataDir}
|
||||||
|
/secrets/jm-wallet-seed
|
||||||
/var/lib/tor
|
/var/lib/tor
|
||||||
# Extra files
|
# Extra files
|
||||||
${cfg.extraFiles}
|
${cfg.extraFiles}
|
||||||
|
|
|
@ -143,13 +143,30 @@ in {
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
requires = [ "bitcoind.service" ];
|
requires = [ "bitcoind.service" ];
|
||||||
after = [ "bitcoind.service" ];
|
after = [ "bitcoind.service" ];
|
||||||
|
path = [ pkgs.sudo ];
|
||||||
serviceConfig = nix-bitcoin-services.defaultHardening // {
|
serviceConfig = nix-bitcoin-services.defaultHardening // {
|
||||||
ExecStartPre = nix-bitcoin-services.privileged ''
|
ExecStartPre = nix-bitcoin-services.privileged ''
|
||||||
install -o '${cfg.user}' -g '${cfg.group}' -m 640 ${configFile} ${cfg.dataDir}/joinmarket.cfg
|
install -o '${cfg.user}' -g '${cfg.group}' -m 640 ${configFile} ${cfg.dataDir}/joinmarket.cfg
|
||||||
sed -i \
|
sed -i \
|
||||||
"s|@@RPC_PASSWORD@@|rpc_password = $(cat ${config.nix-bitcoin.secretsDir}/bitcoin-rpcpassword-privileged)|" \
|
"s|@@RPC_PASSWORD@@|rpc_password = $(cat ${secretsDir}/bitcoin-rpcpassword-privileged)|" \
|
||||||
'${cfg.dataDir}/joinmarket.cfg'
|
'${cfg.dataDir}/joinmarket.cfg'
|
||||||
'';
|
'';
|
||||||
|
ExecStartPost = nix-bitcoin-services.privileged ''
|
||||||
|
walletname=wallet.jmdat
|
||||||
|
pw=$(cat "${secretsDir}"/jm-wallet-password)
|
||||||
|
mnemonic=${secretsDir}/jm-wallet-seed
|
||||||
|
if [[ ! -f ${cfg.dataDir}/wallets/$walletname ]]; then
|
||||||
|
echo Create joinmarket wallet
|
||||||
|
# Use bash variables so commands don't proceed on previous failures
|
||||||
|
# (like with pipes)
|
||||||
|
cd ${cfg.dataDir} && \
|
||||||
|
out=$(sudo -u ${cfg.user} \
|
||||||
|
${pkgs.nix-bitcoin.joinmarket}/bin/jm-genwallet \
|
||||||
|
--datadir=${cfg.dataDir} $walletname $pw)
|
||||||
|
recoveryseed=$(echo "$out" | grep 'recovery_seed')
|
||||||
|
echo "$recoveryseed" | cut -d ':' -f2 > $mnemonic
|
||||||
|
fi
|
||||||
|
'';
|
||||||
ExecStart = "${pkgs.nix-bitcoin.joinmarket}/bin/joinmarketd";
|
ExecStart = "${pkgs.nix-bitcoin.joinmarket}/bin/joinmarketd";
|
||||||
WorkingDirectory = "${cfg.dataDir}"; # The service creates 'commitmentlist' in the working dir
|
WorkingDirectory = "${cfg.dataDir}"; # The service creates 'commitmentlist' in the working dir
|
||||||
User = "${cfg.user}";
|
User = "${cfg.user}";
|
||||||
|
|
|
@ -18,7 +18,7 @@ makePasswordSecret liquid-rpcpassword
|
||||||
makePasswordSecret lightning-charge-token
|
makePasswordSecret lightning-charge-token
|
||||||
makePasswordSecret spark-wallet-password
|
makePasswordSecret spark-wallet-password
|
||||||
makePasswordSecret backup-encryption-password
|
makePasswordSecret backup-encryption-password
|
||||||
touch jm-wallet-password
|
makePasswordSecret jm-wallet-password
|
||||||
|
|
||||||
[[ -e bitcoin-HMAC-privileged ]] || makeHMAC privileged
|
[[ -e bitcoin-HMAC-privileged ]] || makeHMAC privileged
|
||||||
[[ -e bitcoin-HMAC-public ]] || makeHMAC public
|
[[ -e bitcoin-HMAC-public ]] || makeHMAC public
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{ stdenv, fetchurl, python3 }:
|
{ stdenv, fetchurl, python3, pkgs }:
|
||||||
|
|
||||||
let
|
let
|
||||||
version = "0.7.0";
|
version = "0.7.0";
|
||||||
|
@ -32,11 +32,13 @@ let
|
||||||
joinmarketdaemon
|
joinmarketdaemon
|
||||||
];
|
];
|
||||||
|
|
||||||
|
genwallet = pkgs.writeScriptBin "genwallet" (builtins.readFile ./genwallet/genwallet.py);
|
||||||
|
|
||||||
pythonEnv = python.withPackages (_: runtimePackages);
|
pythonEnv = python.withPackages (_: runtimePackages);
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
pname = "joinmarket";
|
pname = "joinmarket";
|
||||||
inherit version src;
|
inherit version src genwallet;
|
||||||
|
|
||||||
buildInputs = [ pythonEnv ];
|
buildInputs = [ pythonEnv ];
|
||||||
|
|
||||||
|
@ -57,6 +59,7 @@ stdenv.mkDerivation {
|
||||||
cpBin tumbler.py
|
cpBin tumbler.py
|
||||||
cpBin wallet-tool.py
|
cpBin wallet-tool.py
|
||||||
cpBin yg-privacyenhanced.py
|
cpBin yg-privacyenhanced.py
|
||||||
|
cp $genwallet/bin/genwallet $out/bin/jm-genwallet
|
||||||
|
|
||||||
chmod +x -R $out/bin
|
chmod +x -R $out/bin
|
||||||
patchShebangs $out/bin
|
patchShebangs $out/bin
|
||||||
|
|
36
pkgs/joinmarket/genwallet/genwallet.py
Normal file
36
pkgs/joinmarket/genwallet/genwallet.py
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
"""
|
||||||
|
Prototype: demonstrate you can automatically generate a wallet
|
||||||
|
"""
|
||||||
|
|
||||||
|
import sys
|
||||||
|
import os
|
||||||
|
from optparse import OptionParser
|
||||||
|
from jmclient import load_program_config, add_base_options, SegwitLegacyWallet, create_wallet, jm_single
|
||||||
|
from jmbase.support import get_log, jmprint
|
||||||
|
|
||||||
|
log = get_log()
|
||||||
|
|
||||||
|
def main():
|
||||||
|
parser = OptionParser(
|
||||||
|
usage='usage: %prog [options] wallet_file_name password',
|
||||||
|
description='Create a wallet with the given wallet name and password.')
|
||||||
|
add_base_options(parser)
|
||||||
|
(options, args) = parser.parse_args()
|
||||||
|
if options.wallet_password_stdin:
|
||||||
|
stdin = sys.stdin.read()
|
||||||
|
password = stdin.encode("utf-8")
|
||||||
|
else:
|
||||||
|
assert len(args) > 1, "must provide password via stdin (see --help), or as second argument."
|
||||||
|
password = args[1].encode("utf-8")
|
||||||
|
load_program_config(config_path=options.datadir)
|
||||||
|
wallet_root_path = os.path.join(jm_single().datadir, "wallets")
|
||||||
|
wallet_name = os.path.join(wallet_root_path, args[0])
|
||||||
|
wallet = create_wallet(wallet_name, password, 4, SegwitLegacyWallet)
|
||||||
|
jmprint("recovery_seed:{}"
|
||||||
|
.format(wallet.get_mnemonic_words()[0]), "important")
|
||||||
|
wallet.close()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
|
@ -107,7 +107,7 @@ def run_tests(extra_tests):
|
||||||
log_has_string("joinmarket", "P2EPDaemonServerProtocolFactory starting on 27184")
|
log_has_string("joinmarket", "P2EPDaemonServerProtocolFactory starting on 27184")
|
||||||
)
|
)
|
||||||
machine.wait_until_succeeds(
|
machine.wait_until_succeeds(
|
||||||
log_has_string("joinmarket-yieldgenerator", "Failed to open wallet",)
|
log_has_string("joinmarket-yieldgenerator", "Failure to get blockheight",)
|
||||||
)
|
)
|
||||||
|
|
||||||
# FIXME: use 'wait_for_unit' because 'create-web-index' always fails during startup due
|
# FIXME: use 'wait_for_unit' because 'create-web-index' always fails during startup due
|
||||||
|
@ -158,6 +158,10 @@ def run_tests(extra_tests):
|
||||||
"export $(cat /secrets/backup-encryption-env); duplicity list-current-files 'file:///var/lib/localBackups'",
|
"export $(cat /secrets/backup-encryption-env); duplicity list-current-files 'file:///var/lib/localBackups'",
|
||||||
"secrets/lnd-seed-mnemonic",
|
"secrets/lnd-seed-mnemonic",
|
||||||
)
|
)
|
||||||
|
assert_matches(
|
||||||
|
"export $(cat /secrets/backup-encryption-env); duplicity list-current-files 'file:///var/lib/localBackups'",
|
||||||
|
"secrets/jm-wallet-seed",
|
||||||
|
)
|
||||||
assert_matches(
|
assert_matches(
|
||||||
"export $(cat /secrets/backup-encryption-env); duplicity list-current-files 'file:///var/lib/localBackups'",
|
"export $(cat /secrets/backup-encryption-env); duplicity list-current-files 'file:///var/lib/localBackups'",
|
||||||
"var/lib/bitcoind/wallet.dat",
|
"var/lib/bitcoind/wallet.dat",
|
||||||
|
|
Loading…
Reference in New Issue
Block a user