-
Notifications
You must be signed in to change notification settings - Fork 116
Create transaction privacy page #175 #349
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 12 commits
84dd15e
03aed32
a2f4a5f
86598ec
d2a12c8
9e52968
c82a8af
c4d9765
c88fb1f
0399085
fc41d21
256cfd5
5e39d8b
2db226b
88e449b
19bba71
a4b6e3b
19db00f
49b2d1b
d6f437a
acf2a0e
b291d8b
210bec4
b036eb5
b967527
479c9f5
85c7c1d
8e0c2db
5e14a12
80fb9b7
d9b8210
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -944,3 +944,12 @@ assets/images/guide/getting-started/visual-language/[email protected] | |
| assets/images/guide/getting-started/visual-language/bitcoin-visual-language.jpg: bitcoin-visual-language.jpg | ||
| assets/images/guide/getting-started/visual-language/[email protected]: [email protected] | ||
| assets/images/guide/getting-started/visual-language/bitcoin-visual-language-mobile.jpg: bitcoin-visual-language-mobile.jpg | ||
| assets/images/guide/payments/privacy/header.jpg: header.jpg | ||
| assets/images/guide/payments/privacy/address-labeling.jpg: address-labeling.jpg | ||
| assets/images/guide/payments/privacy/[email protected]: [email protected] | ||
| assets/images/guide/payments/privacy/[email protected]: [email protected] | ||
| assets/images/guide/payments/privacy/privacy-header-mobile.jpg: privacy-header-mobile.jpg | ||
| assets/images/guide/payments/privacy/[email protected]: [email protected] | ||
| assets/images/guide/payments/privacy/coin-join.jpg: coin-join.jpg | ||
| assets/images/guide/payments/privacy/[email protected]: [email protected] | ||
| assets/images/guide/payments/privacy/privacy-preview.jpg: privacy-preview.jpg | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,139 @@ | ||
| --- | ||
johnsBeharry marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| layout: guide | ||
| title: Transaction privacy | ||
| description: An overview of how to help users maintain their financial privacy while using Bitcoin. | ||
| nav_order: 4 | ||
| parent: Payments | ||
| permalink: /guide/payments/privacy/ | ||
| main_classes: -no-top-padding | ||
| image: /assets/images/guide/payments/privacy/privacy-preview.jpg | ||
johnsBeharry marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| --- | ||
|
|
||
| {% include picture.html | ||
| image = "/assets/images/guide/payments/privacy/header.jpg" | ||
| retina = "/assets/images/guide/payments/privacy/[email protected]" | ||
johnsBeharry marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| mobile = "/assets/images/guide/payments/privacy/privacy-header-mobile.jpg" | ||
| mobileRetina = "/assets/images/guide/payments/privacy/privacy-[email protected]" | ||
| alt-text = "Illustration of an eye, with a cross on top of an ink blot background" | ||
| width = 1600 | ||
| height = 600 | ||
| layout = "full-width" | ||
| %} | ||
|
|
||
|
|
||
| # Transaction privacy | ||
|
|
||
| <!-- | ||
| This page should inform about what information is made public when sending or receiving, how the application can help minimize unnecessary privacy leaks, basic application functionality to help, and when we can, more advanced options. | ||
| - Single-use addresses (avoiding address reuse) | ||
| - Coin selection / labelling | ||
| - Coin join / Pay join | ||
| --> | ||
|
|
||
| It’s a common misconception that Bitcoin is anonymous. Instead, it is referred to as pseudonymous which means each address you generate is like a new identity. Unless you reveal that you are the owner whether directly or indirectly you are able to remain anonymous. | ||
danielnordh marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| When mined, transactions, their signatures, and addresses are public on the ledger, forever. However, there is no personally identifiable information attached to transactions on the blockchain. The transparent property of the blockchain allows anyone to easily verify the amount of bitcoin in existence which means it also makes looking up any address or transaction trivial. This can be demonstrated going back to the first block on [January 3, 2009](https://blockstream.info/tx/4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b). | ||
|
|
||
| > Each Bitcoin transaction contains at least one input and at least one output. This means that once a single address is known, there is a trail to follow the bitcoin. | ||
| > | ||
| > <cite>As documented by <a href="https://docs.wasabiwallet.io/FAQ/FAQ-GeneralBitcoinPrivacy.html#how-is-bitcoin-bad-in-terms-of-privacy">Wasabi Wallet</a></cite> | ||
| The key to keeping your transactions private is to prevent others from determining which addresses you own[^3]. Satoshi let others know that they mined the first block, which contained just one transaction, with the block reward getting sent to their address. This illustrates the permanence of the association to an address and an identity. That being said, the pseudonym “Satoshi Nakamoto” also contributes to further anonymity. While it's possible break asumptions of ownership going forward, the challenge is to recover privacy once an association is made public. | ||
johnsBeharry marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| <!-- TODO: add graphic and heading that demonstrate points of compromise when transacting with bitcoin --> | ||
|
|
||
| ## Methods to preserve privacy | ||
|
|
||
| Keeping private takes constant and diligent work but is not impossible to ensure an acceptable level of privacy[^1]. Let’s explore some methods and practices that can help preserve privacy on a transaction level. | ||
|
|
||
| <!-- talk about the problem as you are talking about the solution --> | ||
|
|
||
| ### Generate a new address for each payment | ||
|
|
||
| Creating new online personas is not the only way to preserve privacy. A new address can be generated by the wallet application used to receive bitcoin. This is achieved using [HD Wallets]({{ "/guide/glossary/#hd-wallet" | relative_url }}), a standard for how private keys get generated in modern bitcoin applications. This allows each transaction not to be tied to a single address, making it more difficult to make an association to the owner. | ||
|
|
||
| > If thieves can see your income, holdings, and spending, they can use this information to target and exploit you.[^2] | ||
pavlenex marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
| Using the same address multiple times does not only degrade the privacy of just one transacting party. Both the [sender](/guide/payments/receive) and [receiver](/guide/payments/receive) are put at risk. On the receiver’s side, by using a single address, senders, or anyone with whom the address is shared can see the previous activity and the amount of bitcoin controlled by the owner. | ||
|
|
||
| Assuming an adversary can uncover the identity behind the reused address there is now a single point for them to reach anyone else who has transacted with the owner. | ||
|
|
||
| <!-- | ||
| TODO: Link / mention gap limit | ||
| TODO: Graphic / consider how to get the ui generating multiple addresses. make it easy for the user to not fail | ||
| > ###### Worked Example 1 - Savings Revealed | ||
| > * You save in bitcoin, using a single-address paper wallet. | ||
| > * All your bitcoin savings to this same address, let's say it contains $1 million worth. | ||
| > * You buy a small amount of bitcoins to add to your savings, depositing in the paper wallet. | ||
| > * The person who sold you the bitcoins follows their trail on the blockchain and finds your paper wallet containing $1 million. | ||
| > * He mentions it to someone in a cafe or bar. | ||
| > * Word gets around. A burglar raids your home. Kidnappers capture your children and know exactly how much to demand in ransom. | ||
| --> | ||
|
|
||
|
|
||
| **Do's** | ||
danielnordh marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| - Show a new unused address when the receive screen is entered. | ||
danielnordh marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
| - Make it easy to generate as many addresses as the receiver needs at a time. | ||
danielnordh marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
| - Before broadcasting a transaction, inform senders if an address is already used. | ||
johnsBeharry marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
danielnordh marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| **Don'ts** | ||
|
|
||
| - Make it easy to reuse an address. | ||
johnsBeharry marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| ### Keep track of who knows about an address | ||
|
|
||
| <div class="center" markdown="1"> | ||
|
|
||
| {% include image.html | ||
| image = "/assets/images/guide/payments/privacy/address-labeling.jpg" | ||
| retina = "/assets/images/guide/payments/privacy/address-[email protected]" | ||
| alt-text = "A list of addresses with tags. Two are red, two are purple and one is blue" | ||
| width = 400 | ||
| height = 400 | ||
| layout = "float-right-desktop" | ||
danielnordh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| %} | ||
|
|
||
| When [receiving bitcoin]({{ "/guide/payments/receive/" | relative_url }}) we can [add additional details to a payment]({{ "/guide/payments/receive/#inputting-additional-payment-details" | relative_url }}). Not only does this help to contextualize payments, but it also enables preventative measures for preserving privacy. Labeling addresses with the counterparty's name involved in each transaction can inform decisions for which [UTXOs]({{ "/guide/glossary/#unspent-transaction-output-utxo" | relative_url }}) are selected in future transaction inputs. | ||
danielnordh marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| To make this UTXO selection easier, some interfaces make it possible to select/filter UTXOs that cluster under one label. | ||
|
||
|
|
||
| _Check out the glossary to learn more about [how coin control works]({{ "/guide/glossary/#coin-control" | relative_url }})._ | ||
danielnordh marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
| </div> | ||
|
|
||
| ### Increase anonymity by collaborating with others | ||
|
|
||
| <div class="center" markdown="1"> | ||
|
|
||
| {% include image.html | ||
| image = "/assets/images/guide/payments/privacy/coin-join.jpg" | ||
| retina = "/assets/images/guide/payments/privacy/coin-[email protected]" | ||
| alt-text = "Example CoinJoin transaction with 3 participants with 1 input each, which get broken up into 5 equal outputs." | ||
| width = 400 | ||
| height = 400 | ||
| layout = "float-right-desktop" | ||
danielnordh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| %} | ||
|
|
||
| The "common input ownership" heuristic[^4] assumes that in a transaction, it is most likely that all inputs belong to the same owner. [CoinJoins]({{ "/guide/glossary/#coinjoin" | relative_url }}) is a technique where multiple participants collaborate on a transaction to break this heuristic. It becomes more difficult (although not impossible) to determine who the individuals who own the outputs are since all the outputs typically have the same denomination. With CoinJoins, as with any other anonymity network, a large and diverse group of participants provides the best protection. | ||
|
|
||
| Users still have to be mindful of how the UTXOs they received from the CoinJoin are spent. For instance, spending them together in a single transaction would unravel the anonymity gains from participating in the CoinJoin. | ||
|
|
||
danielnordh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| </div> | ||
|
|
||
| ### Design with privacy in mind | ||
danielnordh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
|
||
| Thinking about privacy is critical to keep in mind during the design process. Your users will not have the same level of knowledge of how to use Bitcoin privately. It becomes especially critical to understand the implications of their privacy degrading actions at the point of creating a transaction or requesting a payment. | ||
|
|
||
| While there is no perfect solution that will guarantee 100% privacy, try always to minimize how much information gets shared to the most essential. Also, consider ways to inform and prevent users of actions that negatively impact their privacy as they use your product. | ||
|
|
||
| <!-- | ||
| There is no perfect solution to guarantee 100% privacy that lasts forever because things can be revealed over time. Since transactions are forever public, even if all precautions are taken at the time of payment to ensure the highest degree of anonymity, future behaviors of the wallet owner or transacting parties can still degrade previously attained privacy. A high amount of diligence is necessary whenever users are transacting with Bitcoin. The product should be able to guide, inform, and prevent them against privacy degrading actions. | ||
| --> | ||
|
|
||
| [^1]: [Bitcoin.org - Protecting your privacy](https://bitcoin.org/en/protect-your-privacy) | ||
| [^2]: [Wasabi Wallet Docs - Transaction Surveillance Companies](https://docs.wasabiwallet.io/why-wasabi/TransactionSurveillanceCompanies.html#attempt-to-invade-privacy) | ||
| [^3]: [Top Seven Ways Your Identity Can Be Linked to Your Bitcoin Address](https://99bitcoins.com/know-more-top-seven-ways-your-identity-can-be-linked-to-your-bitcoin-address/) | ||
| [^4]: [Bitcoin Wiki / Privacy](https://en.bitcoin.it/wiki/Privacy#Common-input-ownership_heuristic) | ||
Uh oh!
There was an error while loading. Please reload this page.