Salta al contenuto principale
  1. Guide/

Come usare joinmarket per fare coinjoin

13 minuti· ·
Indice dei contenuti

JOINMARKET
#

Se avete trovato questa pagina cercando online “JoinTmarket” avete tutta la mia sincera stima. Siete capitati, però, in una guida che tratta un argomento completamente differente, ma estremamente interessante! 🚬🍁

L’obbiettivo di questo tutorial é quello di illustrare il funzionamento teorico e pratico di JoinMarket.

Questa guida ha richiesto tantissimo lavoro, tempo e impegno per essere completata ed é a disposizione in modo completamente gratuito. Se hai trovato i contenuti qui presenti interessanti e utili ti invito ad effettuare una donazione di un qualsiasi importo a sostegno del mio progetto di divulgazione. Questo sito non contiene analytics, pubblicità o elementi traccianti grazie a tutti coloro che supportano la mia divulgazione sostenendomi. 🐢 💚

Definizione teorica Joinmarket
#

Possiamo definire JoinMarket come uno strumento, o un wallet, che permette di effettuare CoinJoin con altri utenti in maniera totalmente trustless e senza alcun coordinatore centrale.
Essendo tutta la parte teorica di questo tool estremamente ampia, ho deciso di affrontarla in una puntata specifica del mio podcast. Consiglio vivamente di proseguire nella lettura dopo aver ascoltato l’episodio, così da assimilare al meglio i concetti di base per utilizzare in maniera corretta questo programma.

Potete recuperare la puntata a questi link diretti:

  • Spotify
  • Google podcast
  • Amazon music
  • Anchor (qua potrete ascoltarla direttamente da browser).
  • Antenna pod é un podcast manager gratuito e opensource che non richiede registrazione.
    Per trovare la puntata scaricate l’app, aggiungete manualmente il mio podcast incollando questo link nella sezione ¨feed rss¨, cercate poi la puntata dedicata a JoinMarket.

Da questo punto in poi tutti gli argomenti affrontati nel podcast veranno considerati già “conosciuti” e quindi non verranno ri-trattati.

Installazione
#

Sistemi operativi:

RaspiblitzDal menu principale del vostro sistema operativo (da questo punto in poi chiamato semplicemente OS) andate nella sezione "SERVICES" per installare i servizi aggiuntivi e mettete la spunta a "JOINMARKET & JOININBOX".

Una volta installato, per accedere al terminale, dal menu iniziale andate su “EXIT” e poi inviate il comando jm nella shell per passare ad un utente dedicato all’utilizzo di solo joinmarket.

Di default su raspiblitz si avvierà Joininbox (una GUI per JM), per accedere alla linea di comando vi basterà selezionare “Exit” nel menu.

UmbrelUmbrel é una delle distro plug & play più conosciuta anche se personalmente non la ho mai utilizzata. Nello store delle app é presente JAM (una versione con interfaccia grafica molto bella ma estremamente limitata nelle funzioni). Consiglio vivamente di usare JoinMarket (per fruire di tutte le sue possibilità) da shell seguendo questa guida. Per l'installazione é presente un tutorial direttamente sul [Github ufficiale](https://github.com/JoinMarket-Org/joinmarket-clientserver).
MyNodeSu mynode basta aprire un terminale ssh al vostro nodo per accedere alla linea di comando, arrivati qua JoinMarket sarà già preinstallato sul vostro sistema e potrete andare nella cartella contenente gli script per usare le varie funzioni da shell oppure lanciare joininbox con il comando `sudo mynode-joininbox`. Questa guida coprirà l'utilizzo di JM da terminale usando i vari script pre-installati.
RaspiboltTutta la parte di installazione e setup di Joinmarket è già coperta come parte opzionale all'interno della guida raspibolt.

File di configurazione
#

JoinMarket é un software personalizzabile e con un’infinitá di settaggi; quest’ultimi sono specificati in un file di configurazione presente nella directory principale del programma chiamato ´Joinmarket.cfg´.

In questa sezione andremo ad analizzare alcuni campi che potrebbe essere interessante approfondire e/o modificare, in base alle proprie esigenze. Vorrei sottolineare che tutte le modifiche di seguito elencate sono utili da conoscere per adattare il funzionamento del software alle esigenze personali pur non essendo obbligatorie.

Prima di tutto spostiamoci nella cartella joinmarket/scripts e lanciamo il comando:

python wallet-tool.py generate.

A questo punto dovremmo ottenere un errore, ma così facendo il software ci genererà un file di settings pre-impostato. Potremo andare a modificare il file di configurazione da terminale con:

nano joinmarket.cfg

oppure

vim joinmarket.cfg

una volta aperto noteremo numerose righe con varie impostazioni e relativa spiegazione in inglese. Nello specifico analizzeremo qua sotto le variabili piú interessanti:

  • merge_algorithm in caso facessimo da maker questo campo regola con quanta aggressivitá il software consoliderá gli Output non spesi. In caso avessimo molti UTXO da consolidare, potrebbe aver senso switchare da ´gradual´ a ´greedy´
  • tx_fees regola come taker le FEE con cui pagare la transazione, é molto utile modificare questo setting in caso usaste spesso il tumbler (ne parleremo in seguito) in quanto se ci fosse uno spike delle FEE durante l’esecuzione di quest’ultimo, se non settassimo correttamente questo campo, rischieremmo di andare a spendere tantissimi sats per i coinjoin. Settando valori in migliaia (come per esempio 2000) questo equivarrá a 2 sats/vByte, 3500 a 3.5 sats/vByte e cosi via. Mi sentirei di consigliare un numero che va da 1500 a 6000 in base alle vostre necessitá.
  • max_cj_fee_abs serve a specificare quanto siamo disposti a pagare in termini assoluti i maker che scegliamo durante il coinjoin. Di default questo campo per i maker é 200 sats, una buona opzione potrebbe essere un numero variabile da 200 a 1000 sats per controparte (questo in base a quanto volete spendere e quanto anon-set ricercate per i vostri coinjoin)
  • max_cj_fee_rel ha la stessa funzione del campo sopra ma specifica le FEE relative (percentuali) che siamo disposti a pagare ad ogni controparte. Essendo questo un valore “percentuale”, state attenti a non settare valori alti per evitare costi elevati nei coinjoin con grossi importi. Il valore di default per i maker é ´0.00002´, consiglio un valore simile o leggermente superiore.
  • minimum_makers é il campo che specifica con quante altre controparti facciamo CJ, di default joinmarket sceglie sempre da 4 a 9 controparti, volendo, per una maggiore privacy, possiamo alzare questo valore a 5 o 6 (renderá però le transazioni piú costose).
  • cjfee_a specifica, in caso facessimo da maker, quanti sats in termini assoluti vogliamo incassare per l’affitto della nostra liquiditá. Questo campo é totalmente soggettivo, il valore di default é gia ottimo (avremo così miglior privacy come maker) possiamo valutare di portarlo a 0 se vogliamo fare piú coinjoin in meno tempo.
  • cjfee_r uguale al campo sopra ma in termini percentuali e non assoluti. Anche qua consiglio di lasciare il valore di default o abbassarlo per attrarre piú takers.
  • ordertype con questo campo scegliamo da maker se farci pagare in maniera assoluta (absoffer) o percentuale (reloffer). Solitamente i takers preferiscono le offerte assolute per questioni economiche.
  • minsize se da maker non vogliamo avere UTXO troppo piccoli possiamo specificare il coinjoin minimo per partecipare. Questo campo é espresso in satoshi ed é totalmente soggettivo . Potremmo lasciare questo campo a 0 oppure aumentare fino a 500000 (sats), 1000000 (sats), ecc…

Prestate molta attenzione a non modificare per sbaglio i campi errati, alcune delle varibili presenti nel file joinmarket.cfg se impostate erroneamente potrebbero compromettere la funzionalitá del software o annientare completamente la vostra privacy, occhi aperti e attenzione al massimo!

Setup dell’ambiente di lavoro
#

Alcuni nodi impostano automaticamente i valori corretti per questi campi all’interno del file joinmarket.cfg Consiglio di ricontrollare manualmente:

  • rpc_user = yourusername-as-in-bitcoin.conf

  • rpc_password = yourpassword-as-in-bitcoin.conf

  • rpc_host = localhost #default usually correct

  • rpc_port = 8332 # default for mainnet

A questo punto potremo procedere con la creazione del nostro wallet all’interno di JoinMarket:

python wallet-tool.py generate

Questo comando ci fará inserire una password con cui criptare il wallet e il nome che vogliamo dare ad esso, quando vi chiederá se volete supportare o meno i fidelity bond consiglio di usare l’opzione ´yes´, l’output restituito sará simile a questo:

(jmvenv)$ python wallet-tool.py generate
Write down this wallet recovery mnemonic on paper:
    
matter aim multiply december stove march wolf nuclear yard boost worth supreme
    
Enter wallet encryption passphrase:
Reenter wallet encryption passphrase:
Input wallet file name (default: wallet.jmdat):
saved to wallet.jmdat

in caso dia errore é molto probabile che abbiamo settato male i 4 campi RPC sopra specificati. Nel caso potrebbe aiutare seguire questa guida presente nella documentazione originale di JM.

Abbiamo completato il setup del nostro ambiente di lavoro e possiamo cominciare ad esplorare i comandi che piú ci torneranno utili. Tutti gli script di cui parleremo possono essere lanciati in console seguiti da ´–help´ per avere una spiegazione approfondita.

Possiamo ora provare a lanciare:

python wallet-tool.py *nome del wallet prima creato*  
esempio: python wallet-tool.py wallet.jmdat

questo comando vi mostrerá tutti i vari mixdepth del portafoglio con i vari indirizzi catalogati come:

  • New (address mai usato)
  • Change-out (resto di una precedente transazione)
  • Cj-out (output di un coinjoin)

ecco un esempio pratico del risultato:

ora possiamo procedere a depositare i nostri primi satoshi all’interno di uno o piú indirizzi ricordando che, indipendendentemente da maker o taker, il software non andrá mai a consolidare utxo in mixdepth diversi direttamente, in questo modo potremo tenere separati sats con diverso livello di privacy all’interno del wallet.

Inviare bitcoin con coinjoin singolo
#

Possiamo ora muovere i nostri satoshi. Uno dei comandi principali di questo software é lo script:

pyhton sendpayment.py

che ci permetterá di inviare transazioni ad altri indirizzi con o senza coinjoin. Andiamo ad analizzare il suo funzionamento ed alcuni esempi pratici. Di default la formattazione del comando é:

python sendpayment.py *opzioni visionabili con --help* *nome del wallet* *ammontare di satoshi* *indirizzo di destinazione*

un esempio basic di utilizzo potrebbe essere:

python sendpayment.py wallet.jmdat 5000000 1mprGzBA9rQk82Ly41TsmpQGa8UPpZb2w8c

in questo caso andremo ad inviare all’indirizzo 1mprGzBA9rQk82Ly41TsmpQGa8UPpZb2w8c 0.05 Btc ovvero 5000000 satoshi dal nostro mixdepth 0 (quello di default) andando a scegliere da 4 a 9 controparti per il coinjoin (opzione di default).

Per avere maggior controllo su come e quali utxo spendere possiamo andare ad analizzare le opzioni aggiuntive a questo comando:

python sendpayment.py -N 5 -m 1 wallet.jmdat 100000000 1mprGzBA9rQk82Ly41TsmpQGa8UPpZb2w8c

in questo esempio abbiamo aggiunto due specifiche: -N indica con quante controparti andremo a mixare, -m il mixdepth da cui andremo a prelevare i fondi. Di fatto abbiamo inviato 100.000.000 sats (1 btc) all’indirizzo 1mprGzBA9rQk82Ly41TsmpQGa8UPpZb2w8c con i fondi presenti nel mixdepth 1 e mixando con 5 controparti.

Se mettessimo come valore di invio 0 specificando un mixdepth, joinmarket effettuerá un cosidetto ´sweep´, ovvero invierá tutti i fondi presenti in quel mixdepth consolidandoli tra di loro:

python sendpayment.py -N 7 -m 0 wallet.jmdat 0 1mprGzBA9rQk82Ly41TsmpQGa8UPpZb2w8c

quì abbiamo inviato tutti i fondi dal mixdepth 0 (potevamo anche non specificalo perché é quello di default) mixando con 7 controparti.

Il comando sendpayment serve per muovere fondi da joinmarket a wallet esterni o per inviare satoshi ad una persona aggiungendo un layer di privacy tra noi e lui. Per guadagnare un sufficiente livello di privacy sui nostri UTXO é piú indicato usare il comando tumbler.py che spiegheremo piú avanti in questa guida.

Fare da Maker
#

Lo script che andremo a trattare in questa sezione è:

yg-privacyenhanced.py

Questo programma serve per agire come maker nel marcato di joinmarket. Il software si connetterá al nostro nodo bitcoin ed al mercato interno della piattaforma in cui i maker si presentano come offerenti di liquiditá e i taker cercano le controparti.
In caso vogliate usare un fidelity bond potrete crearne uno con questa formattazione:

python3 wallet-tool.py *nome del wallet* gettimelockaddress *data del blocco espressa in YYYY-MM*

esempio:

python3 wallet-tool.py testwallet.jmdat gettimelockaddress 2025-11

l’output che vi verrá restituito sarà un indirizzo bitcoin (ovvero quello su cui dovrete depositare i fondi che volete destinare al fidelity).

!!ATTENZIONE!!

Ci sono due cose a cui fare molta attenzione se avete intenzione di creare un FB:

  • Una volta depositati i fondi, questi non potranno essere piú mossi fino alla scadenza di esso. Prestate attenzione a quanti sats inviate all’indirizzo e a come formattate la data. Non sono ammessi errori!
  • Il fidelity é facilmente riconoscibile onchain, pertanto é consigliabile depositare fondi attraverso un coinjoin e con provenienza non collegata alla vostra identitá. La stessa cosa é consigliabile farla anche una volta che vorrete spostare il bond scaduto fuori da JM.

É importante ricordare che é possibile refillare il fidelity con una sola transazione, in caso di multipli UTXO solo il maggiore verrà considerato valido per il FB.

Trattiamo ora lo script citato all’inizio di questo paragrafo, una volta creato il bond (opzionale) siamo pronti per avviare l’eseguibile per fare da maker su joinmarket.
Una volta depositati i satoshi ai vari indirizzi e mixdepth potremo dare il comando:

python yg-privacyenhanced.py *nome del wallet*

Da questo momento in poi (dopo qualche minuto di collegamento alla rete) e fino a quando non interromperemo lo script, il nostro client JM comparirà sulla lista dei maker attivi sul protocollo e offrirá la nostra liquiditá a varie controparti per effettuare coinjoin. Non aspettatevi decine di coinjoin al giorno (a meno di fidlity enorme e grande liquiditá depositata sul wallet), ricordate anche che fattori come le FEE richieste e i satoshi depositati influiscono sulla frequenza con cui farete da maker.
Eseguendo il comando sottostante potrete vedere lo storico di tutte le transazioni effettuate sul wallet e l’eventuale guadagno (se fate da maker) o spesa di FEE (se siete taker) che avete avuto in tutto l’arco di vita del portafoglio.

python wallet-tool.py *nome del wallet* history

Una volta che i vostri satoshi faranno dei coinjoin, si muoveranno da un mixdepth all’altro fino ad arrivare all’ultimo. Una volta superato il quarto torneranno al mixdepth 0, a voi la scelta di quanta privacy ottenere prima di spostarli su un cold wallet, é consigliabile concludere un ciclo completo del wallet.

Tumbler
#

Eccoci finalmente alla parte piú succosa di JoinMarket, il tumbler!
se avete ascoltato il podcast sapete giá di cosa si tratta. Una raccomandazione prima di inziare: ATTENTI ALLE FEE! Ricordatevi di settare i limiti nel file joinmarket.cfg (come spiegato all’inzio) e valutate di far girare il programma solo quando le fee onchain sono relativamente basse (sotto i 10 sats/vB).
Per lanciare il tumbler é necessario aver fermato lo script da maker (se era attivo), dopo potremo far partire il comando:

python tumbler.py *nome del wallet* *indirizzo1 su cui ricevere* *indirizzo2 su cui ricevere* *indirizzo3 su cui ricevere*

É fondamentale inserire ALMENO 3 indirizzi di output per il tumbler: questo serve a garantire una buona privacy e a non creare link evidenti tra gli UTXO durante tutto il processo. Come al solito aggiungendo –help al comando é possibile andare a vedere tutti i dettagli aggiuntivi. Andiamo a visionare un esempio piú complesso con regole avanzate:

pyhton tumbler.py TestWallet.jmdat -N 7 2 -c 3 1 bc1qz3f80rtv0ux85d7rc06ldtvmpqyfx6ly48c9pa bc1qf3wljw44utyv7qd0z57zvdkfl20y470mva0nes bc1qw48asjpkwm3k2w8cketqhrre0uwq9f7ypwzmxl

In questo caso abbiamo lanciato uno script di tumbling che non userà il numero di controparti di default (il parametro -N indica che richiediamo 7 controparti con una varianza massima di 2, quindi un numero di maker random da 5 a 9) e con un numero maggiore di coinjoin per mixdepth (di default questo script effettua un numero random di coinjoin per sezione del wallet che va da 1 a 3, usando il comando -c 3 1 invece sará da 2 A 4).In questo modo spenderemo piú sats in fee ma avremo un anonimity set maggiore.

É possibile anche aggiungere quanti indirizzi di output si vogliono (minimo 3, non cé un massimo se non il buon senso). Non é invece possibile, per questioni di privacy, decidere come saranno distribuiti i satoshi tra gli indirizzi specificati come output.

Il tumbler é un processo volutamente lungo, occasionalmente potrebbe capitare che qualcosa smetta di funzionare, nella maggior parte dei casi questo si risolverà in autonomia nel giro di poche ore. In caso di crash totale potremo tentare di riavviarlo con il comando:

python tumbler.py --restart

oppure basterá far ripartire un nuovo comando di tumbling. Questo non avvierà lo scheduling del tumbler precedente ma inizierá un nuovo ciclo di mixing.
In caso chiudendo il terminale SSH al vostro nodo si interrompa anche lo script potrete sfruttare il programma ‘TMUX’ installabile con il comando:

sudo apt install tmux

Lanciandolo da shell digitando ’tmux’ vi si aprirá un terminale che rimarrá attivo in background anche chiudendo la connessione remota. Quando vi ri-connetterete al vostro nodo con il comando: ’tmux attach’ ri-aprirete la shell lasciata aperta.

Conclusioni
#

JoinMarket é un software sconfinato e personalizzabile. In questa guida abbiamo scoperto le funzioni principali in modo da rendere possibile per chiunque (o almeno ci ho provato, mi rendo conto che usare questo software non é una passeggiata) l’utilizzo di questo programma. Uno dei maggiori problemi di JM é proprio questo: il numero di persone che lo usano e che fanno da maker. Se pochi utenti sfruttano questo software, la privacy generale (anon-set) si abbassa. Ecco perché spero che questa guida possa incentivare l’uso e vi convinca a scaricare e installare il mio software preferito per fare coinjoin. In caso vogliate approfondire ancora di piú alcuni aspetti vi consiglio di dare una lettura ai vari docs di approfondimento presenti su github, sono vermanete ben fatti e li potete reperire qui.

Buon mixing tartarughe!🐢 💚

Related

Tutorial per il setup di una VPN self-hosted con filtro AdBlock
10 minuti
Guida al De-Google e privacy su android
14 minuti
Tutorial all'utilizzo di bitcoin tutelando la propria privacy
14 minuti