Author

Topic: Are Taproot addresses less secure than native Segwit? (Read 291 times)

copper member
Activity: 2156
Merit: 983
Part of AOBT - English Translator to Indonesia
The Ethereum ENS is a silly nonsense that "maps" human readable strings to actual addresses. It does not change the address format or anything under the hood. In other words it is creating an extra step when making payment since you'll have to first convert that string to an actual address then make the payment.
It doesn't need layer 2, it can be built in a side chain very easily.
Yeah hahaha but it's getting popular on EVM chains other than Ethereum Like Binance Smart Chain or Polygon but you know is like you said first convert that string to an actual address and then make the payment but I hear That some EVM wallet like trust wallet or safepal can transfer directly using an ENS

For starter, check https://en.bitcoin.it/wiki/Bech32_adoption#Exchanges under column "Receive to P2TR". But you also need to check whether they can generate new deposit address for existing user.

[1] https://rgb.info/
[2] https://docs.lightning.engineering/the-lightning-network/taproot-assets
[3] https://docs.satsnames.org/sats-names/about

Thanks again for the information @ETFbitcoin Im learning from you a lot  Cool

and it looks like that not much exchange that accept taproot but big cex accept lightning is already better
legendary
Activity: 2870
Merit: 7490
Crypto Swap Exchange
I am also a fool and want to ask and this could be more out of topic, so the question is there a possibility to change the current Bitcoin address format

It's definitely possible. In addition, Bech32/Bech32m makes it easier since which can be seen with SegWit (bc1q...) and Taproot (bc1p...).

and make it easier like happens on Ethereum chain with their ENS system so it can be like dansus021.btc or that gonna possible in layer 2

RGB[1] and Taproot Assets[2] which utilize Lighning Network might do the job, although i barely know how it works. But even though Bitcoin itself doesn't have name service system, people already attempt to do that on Bitcoin blockchain. For example, Sats Names[3] utilize Ordinals to do that.

and secondly is there any centralized exchange that accept taproot address because i saw binance has address for native segwit, lightning and regular address

For starter, check https://en.bitcoin.it/wiki/Bech32_adoption#Exchanges under column "Receive to P2TR". But you also need to check whether they can generate new deposit address for existing user.

[1] https://rgb.info/
[2] https://docs.lightning.engineering/the-lightning-network/taproot-assets
[3] https://docs.satsnames.org/sats-names/about
legendary
Activity: 3472
Merit: 10611
I am also a fool and want to ask and this could be more out of topic, so the question is there a possibility to change the current Bitcoin address format and make it easier like happens on Ethereum chain with their ENS system so it can be like dansus021.btc or that gonna possible in layer 2
The Ethereum ENS is a silly nonsense that "maps" human readable strings to actual addresses. It does not change the address format or anything under the hood. In other words it is creating an extra step when making payment since you'll have to first convert that string to an actual address then make the payment.
It doesn't need layer 2, it can be built in a side chain very easily.
copper member
Activity: 2156
Merit: 983
Part of AOBT - English Translator to Indonesia
I am also a fool and want to ask and this could be more out of topic, so the question is there a possibility to change the current Bitcoin address format and make it easier like happens on Ethereum chain with their ENS system so it can be like dansus021.btc or that gonna possible in layer 2

and secondly is there any centralized exchange that accept taproot address because i saw binance has address for native segwit, lightning and regular address
staff
Activity: 4284
Merit: 8808
1. Actually believe people who could break secp256k1
But also believe no one could attack ripemd160 AND believe that any break they had of secp256k1 wasn't fast enough for them to just steal your coins at the time you spend them (either by just double spending you with higher fee or doing a short reorg). ... and believe that the value of your bitcoin matters anymore when half of all coins in circulation get stolen. Tongue


I think this whole thing is an example of midwit optimization.  Technically adept enough to understand some details, but not enough to put them in a wider context that regards them as insignificant.
legendary
Activity: 2870
Merit: 7490
Crypto Swap Exchange
2. All hash-based addresses could be spent, if the public key is revealed (so if a transaction is in mempool, or if there were previous transactions in past blocks). If the public key is unknown, then those coins will be unaffected.

IMO it's also worth to mention that about half of top 100 richest Bitcoin address[1] have it's public key exposed (based on "Outs" amount). So there's no reason to target Taproot address specifically.


Quote
Are the assumptions correct or do I have a misconception somewhere?
Yes, they are correct.

So wouldn't it be smarter for me to use native Segwit addresses if I don't need any of the Taproot functionality (except for the future fee savings)?

Maybe yes if you,
1. Actually believe people who could break secp256k1 with intention to steal Bitcoin would after your coin first rather than other address which hold more coin[1].
2. Don't re-use SegWit address after it's public key exposed.
3. Care about few vB difference between SegWit and Taproot[2].

[1] https://bitinfocharts.com/top-100-richest-bitcoin-addresses.html[/url]
[2] https://bitcoinops.org/en/tools/calc-size/
staff
Activity: 4284
Merit: 8808
You can't use a coin without exposing its pubkey.  So in that sense hashed addresses are strictly less secure (because they can also be attacked through second pre-images and collisions).  One can argue that a race (or reorg) is required there and perhaps the mythical ECC cracker wouldn't quite be fast enough to win the race.  So then you're betting not just on there being an attack on the ECC but not the hash, but you're also betting that it will be slow.

But then you're left with the fact that at any given time half of all coins in circulation are stored in addresses with exposed pubkeys -- which means the system as a whole is already busted if there is even a slow way to crack pubkeys.  "I don't have to outrun the tiger, I only have to outrun you." only applies when its one victim vs another, but no one says "I don't have to outrun the nuclear bomb, I just have to outrun you". Smiley  It doesn't matter if *your* coins are secure when the economy is obliterated by half of everything else getting stolen. Smiley

And if you're imagining that the attack comes from future quantum computers there I haven't seen any argument as to how it could be slow: coherence time means that it will have to happen fast or not at all.  And that same device would also halve the number of bits of hash function security (e.g. from 160 to 80 bits) just via known generic attacks but it may allow finding better ones.

And at the same time the 160 bits of hashed addresses used in P2WPKH is actually security limiting: Their security against collisions is already only 80-bits which is at the uncomfortable fringe of tractable, this means that in usage models where collisions might apply (e.g. another party or less trusted device co-generates an address with you) the security of the 160-bit hashed addresses isn't just vulnerable to speculative attacks but real (if difficult) ones.

Of course, this design property wasn't chosen arbitrarily, not having to express a hash (which ought to be 256-bits because of the above issues with 160 bit) hashes in addition to the public key is a big space waste.  Even if you don't personally care about wasting resources or funds on fees, other people will-- an extra diversity in key types reduces privacy. (Which then ultimately undermines security since a lack of privacy makes it easier to target you for theft).

There were some cute proposals on ways to construct addresses such that there was a hidden hash inside the address, the knowledge of which could be ZK proven to provide a kind of rescue signature, but I think people haven't done much with that.  Alternatively, one could stick a QC safe public key in a taproot branch and then if this was widely done even if there was currently no consensus support for using those keys today, it could be softforked in if needed later (and the ability to spend via ECDSA softforked out) -- because the taproot commitments are still strongly binding against a quantum computer (well, at the same level a 256-bit hash is).  --- and I think these kind of moves would make a more meaningful difference in security than a blind gamble on an ecc break happening but not being fast enough to steal coins in realtime.

Progress on this though depends on having an environment where people with the ability to build this stuff want to participate.  I don't think that environment exists today.  I debated today if even giving this benefit-of-expirence reply was worth the cost to me, concluded it probably wasn't, but replied anyways for some reason: Mostly because I hate seeing people midwit themselves into bad positions,  that's how you ended up with people losing coins due to libbitcoin seed.  I'll probably regret commenting anyways.  But just making a comment on a thread is a much lower investment than actually designing and deploying something that people will use in production.
newbie
Activity: 8
Merit: 5

Quote
Are the assumptions correct or do I have a misconception somewhere?
Yes, they are correct.

So wouldn't it be smarter for me to use native Segwit addresses if I don't need any of the Taproot functionality (except for the future fee savings)?
legendary
Activity: 1974
Merit: 3049
I'm not aware of any serious opinion which thinks these things will be feasible in just a few years, however. We are decades away at least.

As far as I know, about two years ago a 127-qubit chip with a 0.001 error rate from IBM was most innovative, last year they produced 433-qubit 'Osprey' processor, this year they expect to have 1121-qubit 'Condor'. Of course, this is still several orders of magnitude less then needed to try to break bitcoin, but they are working good and any breakthrough can help them do it even faster. As far as I remember, several years ago even couple dozens of qubits was a wonder and now they expect to have 10x in just two years. If no unexpected breakthroughs then you are absolutely right, and we have decades. But what if there will be any?
legendary
Activity: 2268
Merit: 18775
Not exactly. If secp256k1 will be broken, then:
Add in almost all addresses ever synced via a light wallet which sends your xpub to the third party server to query your balances, which is probably the majority of addresses ever used. The only way to be sure your public key is actually private is to have it generated on an airgapped machine and never leave that machine.

Pessimistic researchers predict that in just several years a quantum computer with the Grover search or Shor’s algorithm help will be able to crack modern version of Bitcoin.
Note that Grover's algorithm and Shor's algorithm are two entirely different things which can be used to solve different problems. When it comes to bitcoin, the former would be used for SHA256 while the latter for the ECDLP. While Shor's can provide an exponential speed up in attacking the ECDLP (and therefore make it possible to solve), Grover's can only provide a quadratic speed up in attacking SHA256 (which would still require 2128 operations and therefore incredibly unlikely to ever be broken), which is why many people (mistakenly) think that keeping public keys private provides more security.

I'm not aware of any serious opinion which thinks these things will be feasible in just a few years, however. We are decades away at least.
legendary
Activity: 1974
Merit: 3049
but the truth is, that today, we are still far from that

Pessimistic researchers predict that in just several years a quantum computer with the Grover search or Shor’s algorithm help will be able to crack modern version of Bitcoin. Optimistic think that we still have time up to several decades. Both think about new quantum computer resistant solutions (so called post-quantum cryptography). I hope they know what they do as I understand all that just in very general words. Breakthrough discoveries in quantum computers is not what we need right now. Grin
copper member
Activity: 909
Merit: 2301
Quote
Is it true that Taproot addresses are just the Public Key encoded in bech32m?
Yes.

Quote
And native Segwit addresses are a hash of the Public Key encoded in bech32?
Yes.

Quote
Are the assumptions correct or do I have a misconception somewhere?
Yes, they are correct.

Quote
Taproot addresses are not just the public key encoded in bech32m; they are a combination of the public key and the Taproot script.
They don't have to be. You can spend by key, or spend by TapScript. Both paths are valid. There is always some public key, and if you know the private key, then you can entirely skip the script path, and always spend directly by key. Unless you have some invalid public key, where your x-coordinate does not correspond to any secp256k1 point. But in that case, it is simply unspendable, both by key, and by TapScript.

Quote
And Native Segregated Witness (SegWit) addresses are derived from the public key but are not a direct hash of the public key.
There is a direct hash. If you execute OP_HASH160 on some public key, you will get the hash, that corresponds to some P2WPKH address. If that key will be compressed, then for a given public key, that hash will be identical in P2WPKH and P2PKH addresses.

Quote
Anyway breaking in the elliptic curve would allow an attacker to get private keys either it's Taproot address or Segwit address
Not exactly. If secp256k1 will be broken, then:

1. All Taproot addresses could be spend by key.
2. All hash-based addresses could be spent, if the public key is revealed (so if a transaction is in mempool, or if there were previous transactions in past blocks). If the public key is unknown, then those coins will be unaffected.
3. All Lightning Network channels could be broken, as well as all other multi-party protocols, where you have any kind of multisig.
4. All signatures based on those public keys will be useless.

However, public key is called "public" for a reason. If it will be broken, then it should be replaced just by another address type, with another public key, on another curve, or completely different algorithm, for example lattice-based. Breaking public keys is just one-time-theft: when funds will move into another address type, then they will be safe again. Breaking hash functions could be more dangerous, because if you break SHA-256 on preimage level, then you can not only produce any hash, but also use hashing to produce any ECDSA-valid signature (just because message hash is signed, and if you can control that, then you can control ECDSA as well, you can easily confirm that, if you replace SHA-256 with some broken hash function, and try to produce a valid signature).

Quote
but the possibility of happening is not feasible even with the existing most powerful computer of this world
This is true as well. There are many topics, where people are worried "what could happen if ECDSA will be broken", or the same for SHA-256, but the truth is, that today, we are still far from that. We are not even close. In case of SHA-256, you can trace that by checking chainwork. In case of ECDSA, we have this famous puzzle, where 120-bit and 125-bit public keys were broken, and 130-bit key is still untouched (but as this puzzle is not provably fair, that proof is only useful to the puzzle creator, there are no proofs for other people that unsolved keys are in correct ranges, or that the creator didn't move the coins by himself).
legendary
Activity: 1512
Merit: 7340
Farewell, Leo
While with native Segwit you would also need to break the hashing algorithm.
It depends on how fast you can break the elliptic curve, for if you can do it relatively very quickly, then it won't matter if you're locking coins in hashes or public keys, because the attacker can work out the private key before the transaction confirms.

And we aren't capable to even do that within a year as far as I'm concerned. To break the curve within a reasonable time frame, like 1-2 years, you'd need more than ten thousand qubits, and our high score is how much? 127 qubits?

Public-key vulnerable outputs can wait. Puzzles have priority.  Tongue
sr. member
Activity: 910
Merit: 284
Taproot addresses are not just the public key encoded in bech32m; they are a combination of the public key and the Taproot script. And Native Segregated Witness (SegWit) addresses are derived from the public key but are not a direct hash of the public key.

Anyway breaking in the elliptic curve would allow an attacker to get private keys either it's Taproot address or Segwit address but the possibility of happening is not feasible even with the existing most powerful computer of this world.
newbie
Activity: 8
Merit: 5
Hey guys, I got a quick technical question...

Is it true that Taproot addresses are just the Public Key encoded in bech32m?

And native Segwit addresses are a hash of the Public Key encoded in bech32?

Because that would mean that in order to get from the Public Key to the Private Key of the address, you would "only" need to break the elliptic curve with Taproot.
While with native Segwit you would also need to break the hashing algorithm.

Are the assumptions correct or do I have a misconception somewhere?
Jump to: