~ What is an xpub? ~ 
An xpub ("extended public key") along with an xprv ("extended private key") allows you to generate a nearly endless number of bitcoin addresses without having to store and protect the individual private keys for every single one
 https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten"> Time for a thread
https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten"> Time for a thread  https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten">
https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten">
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    An xpub ("extended public key") along with an xprv ("extended private key") allows you to generate a nearly endless number of bitcoin addresses without having to store and protect the individual private keys for every single one
                        
                        
                        1/ To protect your privacy, it& #39;s good practice to use a new bitcoin address for every transaction
But each new address requires its own private key...
Back in the old days (pre-2013), bitcoin wallets would generate and store a new private key for every new address
                    
                                    
                    But each new address requires its own private key...
Back in the old days (pre-2013), bitcoin wallets would generate and store a new private key for every new address
                        
                        
                        2/ Imagine running a popular exchange that uses millions of addresses... 
You would be forced to store and protect millions of individual private keys
What a headache! There had to be a better way...
                    
                                    
                    You would be forced to store and protect millions of individual private keys
What a headache! There had to be a better way...
                        
                        
                        3/ In 2013  @pwuille authored BIP-32, which specified a standard for Hierarchical Deterministic Wallets
This type of wallet allows you to generate a ton of addresses using only a single seed
That single seed is called an xprv ("extended private key") https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki">https://github.com/bitcoin/b...
                    
                                    
                    This type of wallet allows you to generate a ton of addresses using only a single seed
That single seed is called an xprv ("extended private key") https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki">https://github.com/bitcoin/b...
                        
                        
                        4/ If the concepts of private keys and public keys are confusing, now would be a good time to check out my previous thread that goes into more detail: https://twitter.com/dannydiekroeger/status/1283928379201212416?s=20">https://twitter.com/dannydiek...
                        
                            
                            
                            
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        5/ Essentially an xprv is a private key, and an xpub is its public key, and each one is extended with additional data
This extra data (called the "chain code") helps you generate a nearly endless number of additional keys
                    
                                    
                    This extra data (called the "chain code") helps you generate a nearly endless number of additional keys
                        
                        
                        6/ All these additional keys are generated using a standard pattern, so they can be re-calculated at any time!
Why is this useful?
Say you had a wallet with millions of addresses in it, and tragically all the data got destroyed...
                    
                                    
                    Why is this useful?
Say you had a wallet with millions of addresses in it, and tragically all the data got destroyed...
                        
                        
                        7/ As long as you still had your original seed (xprv), you would be able to re-generate all your addresses by following the standard pattern, and you& #39;d be able to recover your whole wallet!
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        8/ So what is this special pattern that allows you to generate so many addresses from a single seed?
The math involves some hashing which I won& #39;t go into detail about here...
But one concept you should be familiar with is a "Derivation Path"
                    
                                    
                    The math involves some hashing which I won& #39;t go into detail about here...
But one concept you should be familiar with is a "Derivation Path"
                        
                        
                        9/ Derivation Paths are like instructions that tell you how to generate an address, and they look something like this:
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        10/ Each Derivation Path provides all the instructions needed to calculate the address and its corresponding private key
By applying the Derivation Path to the xpub, you get the address
And by applying the Derivation Path to the xprv, you get the private key
                    
                                    
                    By applying the Derivation Path to the xpub, you get the address
And by applying the Derivation Path to the xprv, you get the private key
                        
                        
                        11/ Note, I& #39;m skipping over the concept of "Hardened Derivation", in which the xprv is also used to generate the addresses
But let& #39;s keep it simple for now...
Just think:
Xpub generates Addresses
Xprv generates Private Keys
                    
                                    
                    But let& #39;s keep it simple for now...
Just think:
Xpub generates Addresses
Xprv generates Private Keys
                        
                        
                        12/ Using HD wallets is a nice way to organize your addresses, as the different numbers in the Path allow you to organize your addresses in a tree-like structure...
A common use case is to put all Receiving addresses on one branch, and all Change addresses on another branch
                    
                                    
                    A common use case is to put all Receiving addresses on one branch, and all Change addresses on another branch
                        
                        
                        13/ A note of caution though - it& #39;s a good idea to keep your xpub private! 
If somebody has your xpub, and you& #39;re using normal derivation paths, then they& #39;ll be able to calculate all your addresses and see the entire contents of your wallet!
                    
                                    
                    If somebody has your xpub, and you& #39;re using normal derivation paths, then they& #39;ll be able to calculate all your addresses and see the entire contents of your wallet!
                        
                        
                        14/ This is why auditors might ask for your wallet& #39;s xpub
Without the xpub, they& #39;d have no way of knowing that all your different addresses are connected (assuming you don& #39;t send transactions between them)
                    
                                    
                    Without the xpub, they& #39;d have no way of knowing that all your different addresses are connected (assuming you don& #39;t send transactions between them)
                        
                        
                        15/ So to recap:
- An xpub is public key with some additional data that lets you generate a ton of addresses
- An xprv is the private key that lets you generate a ton of private keys that correspond to these addresses
                    
                                    
                    - An xpub is public key with some additional data that lets you generate a ton of addresses
- An xprv is the private key that lets you generate a ton of private keys that correspond to these addresses
                        
                        
                        16/ And together they are the foundation for HD wallets, which are a neat way to organize your wallet without having to store a bunch of individual private keys
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        17/ Hope this was helpful! Shoutout to  @PeterMcCormack for the original question
I hope that everyone feels comfortable asking questions, and I hope everyone can be more friendly about explaining complex topics to others
This stuff is complicated!
                    
                                    
                    I hope that everyone feels comfortable asking questions, and I hope everyone can be more friendly about explaining complex topics to others
This stuff is complicated!
                        
                        
                        18/ For more educational threads on all the basic technical concepts behind Bitcoin, check out this mega-thread where I& #39;ve linked all my previous ones: https://twitter.com/dannydiekroeger/status/1282000262782042117?s=20">https://twitter.com/dannydiek...
                        
                            
                            
                            
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        19/19 And check out my email list to stay connected with me http://dannydiekroeger.substack.com"> http://dannydiekroeger.substack.com 
                        
                                                
                        
                        
                        
                                                
                    
                    
                
                 
                         Read on Twitter
Read on Twitter Time for a thread https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten">" title="~ What is an xpub? ~ An xpub ("extended public key") along with an xprv ("extended private key") allows you to generate a nearly endless number of bitcoin addresses without having to store and protect the individual private keys for every single onehttps://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten"> Time for a thread https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten">" class="img-responsive" style="max-width:100%;"/>
 Time for a thread https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten">" title="~ What is an xpub? ~ An xpub ("extended public key") along with an xprv ("extended private key") allows you to generate a nearly endless number of bitcoin addresses without having to store and protect the individual private keys for every single onehttps://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten"> Time for a thread https://abs.twimg.com/emoji/v2/... draggable="false" alt="👇" title="Rückhand Zeigefinger nach unten" aria-label="Emoji: Rückhand Zeigefinger nach unten">" class="img-responsive" style="max-width:100%;"/>
                             
                             
                             
                             
                             
                                     
                                    