You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Kristaps Kaupe 8798b8bc6e
Redirect back to / after /refreshorderbook and /rotateOb
2 years ago
..
obwatch Redirect back to / after /refreshorderbook and /rotateOb 2 years ago
snicker Add local Tor autostart to missing scripts 4 years ago
README.md Update README.md 5 years ago
add-utxo.py Unify cli user input code where limited range of answers are allowed 2 years ago
bond-calculator.py Script: Add bond-calculator.py 4 years ago
bumpfee.py Unify cli user input code where limited range of answers are allowed 2 years ago
genwallet.py genwallet.py: Add option --recovery-seed-file 4 years ago
jmwalletd.py chmod +x scripts/jmwalletd.py 3 years ago
joinmarket-qt.py Release notes and version for v0.9.11 2 years ago
joinmarket-qt.sh Apply all current shellcheck suggestions to rest of the scripts 3 years ago
joinmarketd.py BIP78 sender protocol via daemon 5 years ago
qtsupport.py update Qt for new tumbler algo 3 years ago
receive-payjoin.py Add local Tor autostart to missing scripts 4 years ago
sample-schedule-for-testnet fix sample schedule for testnet 6 years ago
sendpayment.py Unify cli user input code where limited range of answers are allowed 2 years ago
sendtomany.py Unify cli user input code where limited range of answers are allowed 2 years ago
tumbler.py Unify cli user input code where limited range of answers are allowed 2 years ago
wallet-tool.py Change shebang to python3 and +x for scripts 6 years ago
yg-privacyenhanced.py Remove imports from future and past 2 years ago
yield-generator-basic.py Move YG settings to a config file 5 years ago

README.md

Command line scripts for Joinmarket

(If upgrading to version 0.3.0+, don't forget to read this on upgrading the wallet.)

All user level scripts here.

(The phrase "normal Joinmarket" in the below refers to the existing repo.

The subdirectories logs and wallets have the same role as in normal Joinmarket. The subdirectory cmtdata contains only your commitments.json storage of your used commitments (ignored by github of course!). The filename is set in joinmarket.cfg.

The joinmarket.cfg will be created and maintained in this directory.

Brief explanation of the function of each of the scripts:

sendpayment.py

Either use the same syntax as for normal Joinmarket:

`python sendpayment.py -N 3 -m 1 -P wallet.jmdat 50000000 <address>`

or use the new schedule approach. For an example, see the sample schedule file. Do:

`python sendpayment.py -S sample-schedule-for-testnet wallet.jmdat`

Note that the magic string INTERNAL in the file creates a payment to a new address in the next mixdepth (wrapping around to zero if you reach the maximum mixdepth).

To pay a fraction of the total in a mixdepth you can simply make the amount field in the schedule a decimal instead of an integer (0.0 < amt < 1.0 of course).

The schedule file can have any name, and is a comma separated value file, the lists must follow that format; see the comment in the sample file above (each list is length 5 items).

*This part can be ignored for a first run:

Additional fields in config: in the config section [DAEMON] you can specify whether to run the daemon as a separate process or not. By default, the daemon will run in the same Python process, for maximum convenience, so you needn't separately start joinmarketd.py (see below).

You can run the daemon separately by setting nodaemon=0 in [DAEMON]. You can choose to use ssl within this single-process configuration with use_ssl=true (again, see below for more on this).*

tumbler.py

This is an extension of the functionality of sendpayment.py in that it auto-generates a schedule of payments to internal and external addresses, following the same algo as in normal Joinmarket and described here.

For detailed information on how to use this, please read this.

wallet-tool.py

This is the same as in normal Joinmarket.

joinmarketd.py

This file is to be considered experimental for now. It only takes two arguments, the port it serves on (default 27183), and whether to use TLS for client-server communication (default 0=no tls, 1=tls):

`python joinmarketd.py [port number] [1/0]`

To use tls you must create a key.pem and cert.pem in a subdirectory /ssl, representing a self-signed certificate. This needs some work to be cleaned up, but does work already.

add-utxo.py

This works exactly as in normal Joinmarket, with the exception of the location of the commitments.json file, explained above.

sendtomany.py

As above.

genwallet.py

Non-interactively generate a wallet, giving only wallet name and password. Returns wallet seed as recovery_seed:. Useful for automating JoinMarket deployments.