diff --git a/docs/Sign-PSBT-with-sparrow-wallet.md b/docs/Sign-PSBT-with-sparrow-wallet.md new file mode 100644 index 0000000000..db1990b525 --- /dev/null +++ b/docs/Sign-PSBT-with-sparrow-wallet.md @@ -0,0 +1,80 @@ +# Sending a transaction from BTCPay Server using PSBT to sign with Sparrow wallet + +This guide explains how you can create a partially signed bitcoin transaction (PSBT) on BTCPay Server and sign and broadcast it with Sparrow wallet. This can be useful if you have an airgapped setup or persons creating the transaction and signing it are different people. + +## 1. Creating a transaction (on BTCPay Server): + +* Log into your BTCPay Server and select the store you want to sent from +* Under "Wallets" select "Bitcoin" +* Click on button “Send” + +**On send screen:** + +![BTCPay: Create transaction on BTCPay Server](./img/psbt-send-sparrow/btcpay-1-send.png "Create a transaction") + +* Input the receiving bitcoin address +* Enter the amount +* Change fee rate (get the current fee rate on [mempool.space](https://mempool.space) depending on how fast you want the transaction to be confirmed) +* **Important**: click on “Advanced Settings” so it expands and check “**Always include non-witness UTXO if available**” (this is needed so hardware wallets like BitBox02 can sign the transaction) +* Optional: on “Allow fee increase (RBF)”, set to “Yes” (this is useful if you select a too low fee you can bump the fee so your transaction is not stuck and get’s confirmed) +* Click “Sign transaction” button + +**On choosing signing method screen:** + +![BTCPay: Choose signing method: Partially Signed Bitcoin Transaction](./img/psbt-send-sparrow/btcpay-2-choose-signing-method.png "Select Partially Signed Bitcoin Transaction") + +* Select “Partially Signed Bitcoin Transaction” + +**On PSBT screen:** + +![BTCPay: Download the PSBT file](./img/psbt-send-sparrow/btcpay-3-download-psbt.png "PSBT screen overview, download PSBT") + +* Open the accordion of “Export PSBT for signing” click on button “Download PSBT file” +* Store the file on hard-drive (you can use it to sign the PSBT yourself or you can send it to somebody doing the signing on Sparrow wallet, see below) example file name psbt-export.psbt + + +## 2. Signing and sending the PSBT on Sparrow wallet + +* Open your Sparrow Wallet with the wallet holding the data for the xpubs used in your store +* In menu: File -> Open Transaction -> File… +* Select the file you stored (or got sent from accounting) e.g. psbt-export.psbt + +**On showing the imported PSBT transaction:** + +![Sparrow wallet: Load the PSBT file](./img/psbt-send-sparrow/sparrow-1-loaded-psbt-for-signing.png "Sparrow wallet, loaded PSBT for signing") + +* Make sure under headline “Signatures:” the “signing wallet” matches the wallet you want to sent from +* Click on “Finalize Transaction for Signing” + +**Signing the transaction:** + +![Sparrow wallet: PSBT loaded, ready for signing](./img/psbt-send-sparrow/sparrow-2-loaded-psbt-sign.png) + +* Click on “Sign” + +**Connect Hardware wallet popup:** + +![Sparrow wallet: connect to hardware wallet (e.g. in our case BitBox02)](./img/psbt-send-sparrow/sparrow-3-scan-for-hww.png "Connect your hardware wallet") + +* Plug-in your hardware wallet (BitBox02 in our case) +* Enter your hardware wallet pin (for BitBox02 it shows on screen open BitBox app but you do not need to, wait until you can enter the pin) +* After BitBox02 unlocked, click “Scan…”, your hardware wallet will show up + +**Wallet connected successfully:** + +![Sparrow wallet: hardware wallet successfully connected](./img/psbt-send-sparrow/sparrow-4-unlocked-hww.png "BitBox02 successfully connected") + +* Click “Sign” +* A summary of the transaction will be shown on the BitBox02 device, you need to confirm it there + +**Broadcasting the transaction:** + +![Sparrow wallet: broadcast the transaction](./img/psbt-send-sparrow/sparrow-5-broadcast-transaction.png "Broadcast the transaction") + +* After signing was successful you need to broadcast the transaction to the Bitcoin network +* Click “Broadcast Transaction” + +Note: Alternatively, instead of broadcasting the transaction from Sparrow wallet (e.g. if you have an airgapped setup) you could also copy and paste the signed transaction PSBT from the textbox and upload it to your BTCPay Server and let it broadcast the transaction to the network. + +**Congrats, done!** + diff --git a/docs/img/psbt-send-sparrow/btcpay-1-send.png b/docs/img/psbt-send-sparrow/btcpay-1-send.png new file mode 100644 index 0000000000..582e4b3195 Binary files /dev/null and b/docs/img/psbt-send-sparrow/btcpay-1-send.png differ diff --git a/docs/img/psbt-send-sparrow/btcpay-2-choose-signing-method.png b/docs/img/psbt-send-sparrow/btcpay-2-choose-signing-method.png new file mode 100644 index 0000000000..0ecc1c9892 Binary files /dev/null and b/docs/img/psbt-send-sparrow/btcpay-2-choose-signing-method.png differ diff --git a/docs/img/psbt-send-sparrow/btcpay-3-download-psbt.png b/docs/img/psbt-send-sparrow/btcpay-3-download-psbt.png new file mode 100644 index 0000000000..ae930f15b0 Binary files /dev/null and b/docs/img/psbt-send-sparrow/btcpay-3-download-psbt.png differ diff --git a/docs/img/psbt-send-sparrow/sparrow-1-loaded-psbt-for-signing.png b/docs/img/psbt-send-sparrow/sparrow-1-loaded-psbt-for-signing.png new file mode 100644 index 0000000000..9b3d36f6b1 Binary files /dev/null and b/docs/img/psbt-send-sparrow/sparrow-1-loaded-psbt-for-signing.png differ diff --git a/docs/img/psbt-send-sparrow/sparrow-2-loaded-psbt-sign.png b/docs/img/psbt-send-sparrow/sparrow-2-loaded-psbt-sign.png new file mode 100644 index 0000000000..6ca7f2a2f3 Binary files /dev/null and b/docs/img/psbt-send-sparrow/sparrow-2-loaded-psbt-sign.png differ diff --git a/docs/img/psbt-send-sparrow/sparrow-3-scan-for-hww.png b/docs/img/psbt-send-sparrow/sparrow-3-scan-for-hww.png new file mode 100644 index 0000000000..bb651a079d Binary files /dev/null and b/docs/img/psbt-send-sparrow/sparrow-3-scan-for-hww.png differ diff --git a/docs/img/psbt-send-sparrow/sparrow-4-unlocked-hww.png b/docs/img/psbt-send-sparrow/sparrow-4-unlocked-hww.png new file mode 100644 index 0000000000..bfaf66eeae Binary files /dev/null and b/docs/img/psbt-send-sparrow/sparrow-4-unlocked-hww.png differ diff --git a/docs/img/psbt-send-sparrow/sparrow-5-broadcast-transaction.png b/docs/img/psbt-send-sparrow/sparrow-5-broadcast-transaction.png new file mode 100644 index 0000000000..b52de1f8e1 Binary files /dev/null and b/docs/img/psbt-send-sparrow/sparrow-5-broadcast-transaction.png differ