Common Vulnerabilities and Exposures: Difference between revisions
An actually useful description |
No edit summary |
||
Line 49: | Line 49: | ||
|bgcolor=lime| Hard | |bgcolor=lime| Hard | ||
| Wallet non-encryption | | Wallet non-encryption | ||
|bgcolor=lime| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2011-4447.html | |bgcolor=lime| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2011-4447.html 98%] | ||
|- | |- | ||
| [[#CVE-2012-1909|CVE-2012-1909]] | | [[#CVE-2012-1909|CVE-2012-1909]] | ||
Line 57: | Line 57: | ||
|bgcolor=lime| Very hard | |bgcolor=lime| Very hard | ||
| Transaction overwriting | | Transaction overwriting | ||
|bgcolor=yellow| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-1909.html | |bgcolor=yellow| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-1909.html 92%] | ||
|- | |- | ||
| [[#CVE-2012-1910|CVE-2012-1910]] | | [[#CVE-2012-1910|CVE-2012-1910]] | ||
Line 73: | Line 73: | ||
|bgcolor=yellow| Miners<ref name="MinerEasy">Attacking requires mining block(s)</ref> | |bgcolor=yellow| Miners<ref name="MinerEasy">Attacking requires mining block(s)</ref> | ||
| Mandatory P2SH protocol update | | Mandatory P2SH protocol update | ||
|bgcolor=yellow| [http://luke.dashjr.org/programs/bitcoin/files/charts/BIP-0016.html | |bgcolor=yellow| [http://luke.dashjr.org/programs/bitcoin/files/charts/BIP-0016.html 92%] | ||
|- | |- | ||
| [[#CVE-2012-2459|CVE-2012-2459]] | | [[#CVE-2012-2459|CVE-2012-2459]] | ||
Line 81: | Line 81: | ||
|bgcolor=pink| Easy | |bgcolor=pink| Easy | ||
| Block hash collision (via merkle root) | | Block hash collision (via merkle root) | ||
|bgcolor=yellow| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-2459.html | |bgcolor=yellow| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-2459.html 92%] | ||
<!-- | <!-- | ||
|- | |- | ||
Line 99: | Line 99: | ||
|bgcolor=pink| Easy | |bgcolor=pink| Easy | ||
| (Lack of) orphan txn resource limits | | (Lack of) orphan txn resource limits | ||
|bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-3789 | |bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-3789 83%] | ||
|- | |- | ||
| [[#BIP-0034|BIP 0034]] | | [[#BIP-0034|BIP 0034]] | ||
Line 107: | Line 107: | ||
|bgcolor=yellow| Miners<ref name="MinerEasy">Attacking requires mining block(s)</ref> | |bgcolor=yellow| Miners<ref name="MinerEasy">Attacking requires mining block(s)</ref> | ||
| Mandatory block protocol update | | Mandatory block protocol update | ||
|bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/BIP-0034.html | |bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/BIP-0034.html 66%] | ||
|- | |- | ||
| [[#CVE-2012-4682|CVE-2012-4682]] | | [[#CVE-2012-4682|CVE-2012-4682]] | ||
Line 115: | Line 115: | ||
| | | | ||
| | | | ||
|bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-4682.html | |bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-4682.html 66%] | ||
|- | |- | ||
| [[#CVE-2012-4683|CVE-2012-4683]] | | [[#CVE-2012-4683|CVE-2012-4683]] | ||
Line 123: | Line 123: | ||
| | | | ||
| | | | ||
|bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-4683.html | |bgcolor=pink| [http://luke.dashjr.org/programs/bitcoin/files/charts/CVE-2012-4683.html 66%] | ||
|} | |} | ||
Line 242: | Line 242: | ||
<b>Date:</b> 2011-11-11 | <b>Date:</b> 2011-11-11 | ||
<b>Summary:</b> Wallet non-encryption | <b>Summary:</b> Wallet non-encryption | ||
<b>Fix Deployment:</b> | <b>Fix Deployment:</b> 98% | ||
{| class='wikitable' | {| class='wikitable' | ||
!colspan='2'| Affected !! Fix | !colspan='2'| Affected !! Fix | ||
Line 260: | Line 260: | ||
<b>Date:</b> 2012-03-07 | <b>Date:</b> 2012-03-07 | ||
<b>Summary:</b> Transaction overwriting | <b>Summary:</b> Transaction overwriting | ||
<b>Fix Deployment:</b> | <b>Fix Deployment:</b> 92% | ||
{| class='wikitable' | {| class='wikitable' | ||
!colspan='2'| Affected !! Fix | !colspan='2'| Affected !! Fix | ||
Line 296: | Line 296: | ||
<b>Date:</b> 2012-04-01 | <b>Date:</b> 2012-04-01 | ||
<b>Summary:</b> Mandatory P2SH protocol update | <b>Summary:</b> Mandatory P2SH protocol update | ||
<b>Deployment:</b> | <b>Deployment:</b> 92% | ||
{| class='wikitable' | {| class='wikitable' | ||
!colspan='2'| Affected !! Fix | !colspan='2'| Affected !! Fix | ||
Line 312: | Line 312: | ||
<b>Date:</b> 2012-05-14 | <b>Date:</b> 2012-05-14 | ||
<b>Summary:</b> Block hash collision (via merkle tree) | <b>Summary:</b> Block hash collision (via merkle tree) | ||
<b>Fix Deployment:</b> | <b>Fix Deployment:</b> 92% | ||
{| class='wikitable' | {| class='wikitable' | ||
!colspan='2'| Affected !! Fix | !colspan='2'| Affected !! Fix | ||
Line 333: | Line 333: | ||
<b>Date:</b> 2012-06-20 | <b>Date:</b> 2012-06-20 | ||
<b>Summary:</b> (Lack of) orphan txn resource limits | <b>Summary:</b> (Lack of) orphan txn resource limits | ||
<b>Fix Deployment:</b> | <b>Fix Deployment:</b> 83% | ||
{| class='wikitable' | {| class='wikitable' | ||
!colspan='2'| Affected !! Fix | !colspan='2'| Affected !! Fix | ||
Line 349: | Line 349: | ||
<b>Date:</b> Future | <b>Date:</b> Future | ||
<b>Summary:</b> Mandatory block protocol update | <b>Summary:</b> Mandatory block protocol update | ||
<b>Deployment:</b> | <b>Deployment:</b> 66% | ||
{| class='wikitable' | {| class='wikitable' | ||
!colspan='2'| Affected !! Fix | !colspan='2'| Affected !! Fix |
Revision as of 21:24, 8 January 2013
CVE | Announced | Affects | Severity | Attack is... | Flaw | Net |
---|---|---|---|---|---|---|
CVE-2010-5137 | 2010-07-28 | wxBitcoin and bitcoind | DoS[1] | Easy | OP_LSHIFT crash | 100% |
CVE-2010-5141 | 2010-07-28 | wxBitcoin and bitcoind | Theft[2] | Easy | 100% | |
CVE-2010-5138 | 2010-07-29 | wxBitcoin and bitcoind | DoS[1] | Easy | Unlimited SigOp DoS | 100% |
CVE-2010-5139 | 2010-08-15 | wxBitcoin and bitcoind | Theft[2] | Easy | Combined output overflow | 100% |
CVE-2010-5140 | 2010-09-29 | wxBitcoin and bitcoind | DoS[1] | Easy | Never confirming transactions | 100% |
CVE-2011-4447 | 2011-11-11 | wxBitcoin and bitcoind | Exposure[3] | Hard | Wallet non-encryption | 98% |
CVE-2012-1909 | 2012-03-07 | Bitcoin protocol and all clients | Netsplit[4] | Very hard | Transaction overwriting | 92% |
CVE-2012-1910 | 2012-03-17 | Bitcoin-Qt for Windows | Unknown[5] | Hard | MingW non-multithreading | 99% |
BIP 0016 | 2012-04-01 | All Bitcoin clients | Fake Conf[6] | Miners[7] | Mandatory P2SH protocol update | 92% |
CVE-2012-2459 | 2012-05-14 | bitcoind and Bitcoin-Qt | Netsplit[4] | Easy | Block hash collision (via merkle root) | 92% |
CVE-2012-3789 | 2012-06-20 | bitcoind and Bitcoin-Qt | DoS[1] | Easy | (Lack of) orphan txn resource limits | 83% |
BIP 0034 | Future | All Bitcoin clients | Fake Conf[6] | Miners[7] | Mandatory block protocol update | 66% |
CVE-2012-4682 | bitcoind and Bitcoin-Qt | DoS[1] | 66% | |||
CVE-2012-4683 | bitcoind and Bitcoin-Qt | DoS[1] | 66% |
- ↑ 1.0 1.1 1.2 1.3 1.4 1.5 Attacker can disable some functionality, for example by crashing clients
- ↑ 2.0 2.1 Attacker can take or create money outside known network rules
- ↑ Attacker can access user data outside known acceptable methods
- ↑ 4.0 4.1 Attacker can create multiple views of the network, enabling double-spending with over 1 confirmation
- ↑ Extent of possible abuse is unknown
- ↑ 6.0 6.1 Attacker can double-spend with 1 confirmation
- ↑ 7.0 7.1 Attacking requires mining block(s)
CVE-2010-5137
Date: 2010-07-28 Summary: OP_LSHIFT crash Fix Deployment: 100%
Affected | Fix | |
---|---|---|
bitcoind wxBitcoin |
* - 0.3.4 | 0.3.5 |
On July 28 2010, two bugs were discovered and demonstrated on the test network. One caused bitcoin to crash on some machines when processing a transaction containing an OP_LSHIFT. This was never exploited on the main network, and was fixed by Bitcoin version 0.3.5.
After these bugs were discovered, many currently-unused script words were disabled for safety.
References
CVE-2010-5141
Date: 2010-07-28 Summary: ? Fix Deployment: 100%
Affected | Fix | |
---|---|---|
bitcoind wxBitcoin |
* - 0.3.4 | 0.3.5 |
On July 28 2010, two bugs were discovered and demonstrated on the test network. One exploited a bug in the transaction handling code and allowed an attacker to spend coins that they did not own. This was never exploited on the main network, and was fixed by Bitcoin version 0.3.5.
After these bugs were discovered, many currently-unused script words were disabled for safety.
References
CVE-2010-5138
Date: 2010-07-29 Summary: Unlimited SigOp DoS Fix Deployment: 100%
Affected | Fix | |
---|---|---|
bitcoind wxBitcoin |
* - 0.3.? | 0.3.? |
On July 29 2010, it was discovered that block 71036 contained several transactions with a ton of OP_CHECKSIG commands. There should only ever be one such command. This caused every node to do extra unnecessary work, and it could have been used as a denial-of-service attack. A new version of Bitcoin was quickly released. The new version did not cause a fork on the main network, though it did cause one on the test network (where someone had played around with the attack more).
References
CVE-2010-5139
Date: 2010-08-15 Summary: Combined output overflow Fix Deployment: 100%
Affected | Fix | |
---|---|---|
bitcoind wxBitcoin |
* - 0.3.10 | 0.3.11 |
On August 15 2010, it was discovered that block 74638 contained a transaction that created over 184 billion bitcoins for two different addresses. This was possible because the code used for checking transactions before including them in a block didn't account for the case of outputs so large that they overflowed when summed. A new version was published within a few hours of the discovery. The block chain had to be forked. Although many unpatched nodes continued to build on the "bad" block chain, the "good" block chain overtook it at a block height of 74691. The bad transaction no longer exists for people using the longest chain.
The block and transaction:
CBlock(hash=0000000000790ab3, ver=1, hashPrevBlock=0000000000606865, hashMerkleRoot=618eba, nTime=1281891957, nBits=1c00800e, nNonce=28192719, vtx=2) CTransaction(hash=012cd8, ver=1, vin.size=1, vout.size=1, nLockTime=0) CTxIn(COutPoint(000000, -1), coinbase 040e80001c028f00) CTxOut(nValue=50.51000000, scriptPubKey=0x4F4BA55D1580F8C3A8A2C7) CTransaction(hash=1d5e51, ver=1, vin.size=1, vout.size=2, nLockTime=0) CTxIn(COutPoint(237fe8, 0), scriptSig=0xA87C02384E1F184B79C6AC) CTxOut(nValue=92233720368.54275808, scriptPubKey=OP_DUP OP_HASH160 0xB7A7) CTxOut(nValue=92233720368.54275808, scriptPubKey=OP_DUP OP_HASH160 0x1512) vMerkleTree: 012cd8 1d5e51 618eba Block hash: 0000000000790ab3f22ec756ad43b6ab569abf0bddeb97c67a6f7b1470a7ec1c Transaction hash: 1d5e512a9723cbef373b970eb52f1e9598ad67e7408077a82fdac194b65333c9
References
CVE-2010-5140
Date: 2010-09-29 Summary: Never confirming transactions Fix Deployment: 100%
Affected | Fix | |
---|---|---|
bitcoind wxBitcoin |
* - 0.3.12 | 0.3.13 |
Around September 29, 2010, people started reporting that their sent transactions would not confirm. This happened because people modified Bitcoin to send sub-0.01 transactions without any fees. A 0.01 fee was at that time required by the network for such transactions (essentially prohibiting them), so the transactions remained at 0 confirmations forever. This became a more serious issue because Bitcoin would send transactions using bitcoins gotten from transactions with 0 confirmations, and these resulting transactions would also never confirm. Because Bitcoin tends to prefer sending smaller coins, these invalid transactions quickly multiplied, contaminating the wallets of everyone who received them.
Bitcoin was changed to only select coins with at least 1 confirmation. The remaining sub-0.01 transactions were cleared by generators who modified their version of Bitcoin to not require the micropayment fee. It took a while for everything to get cleared, though, because many of the intermediate transactions had been forgotten by the network by this point and had to be rebroadcast by the original senders.
References
CVE-2011-4447
Date: 2011-11-11 Summary: Wallet non-encryption Fix Deployment: 98%
Affected | Fix | |
---|---|---|
bitcoind wxBitcoin |
0.4.0 - 0.4.1rc6 | 0.4.1 0.5.0 |
References
CVE-2012-1909
Date: 2012-03-07 Summary: Transaction overwriting Fix Deployment: 92%
Affected | Fix | |
---|---|---|
Bitcoin protocol | Before March 15th, 2012 | BIP 30 |
Bitcoin-Qt bitcoind |
* - 0.4.4rc2 0.5.0rc1 - 0.5.0.4rc2 0.5.1rc1 - 0.5.3rc2 0.6.0rc1 - 0.6.0rc2 |
0.4.4 0.5.0.4 0.5.3 0.6.0rc3 |
wxBitcoin | ALL | NONE |
References
CVE-2012-1910
Date: 2012-03-17 Summary: MingW non-multithreading Fix Deployment: 99%
Affected | Fix | |
---|---|---|
Bitcoin-Qt for Windows | 0.5.0rc1 - 0.5.0.4 0.5.1rc1 - 0.5.3.0 0.6.0rc1 - 0.6.0rc3 |
0.5.0.5 0.5.3.1 0.5.4 0.6.0rc4 |
References
BIP-0016
Date: 2012-04-01 Summary: Mandatory P2SH protocol update Deployment: 92%
Affected | Fix | |
---|---|---|
Bitcoin-Qt bitcoind |
* - 0.4.4 0.5.0rc1 - 0.5.0.5 0.5.1rc1 - 0.5.3 0.6.0rc1 |
0.4.5 0.5.0.6 0.5.4rc1 0.6.0rc2 |
wxBitcoin | ALL | NONE |
References
CVE-2012-2459
Date: 2012-05-14 Summary: Block hash collision (via merkle tree) Fix Deployment: 92%
Affected | Fix | |
---|---|---|
Bitcoin-Qt bitcoind |
* - 0.4.6rc1 0.5.0rc1 - 0.5.5rc1 0.6.0rc1 - 0.6.0.7rc1 0.6.1rc1 - 0.6.1rc1 |
0.4.6 0.5.5 0.6.0.7 0.6.1rc2 |
Block hash collisions can easily be made by duplicating transactions in the merkle tree. Such a collision is invalid, but if recorded (as Bitcoin-Qt and bitcoind prior to 0.6.1 did) would prevent acceptance of the legitimate block with the same hash. This could be used to fork the blockchain, including deep double-spend attacks.
References
CVE-2012-3789
Date: 2012-06-20 Summary: (Lack of) orphan txn resource limits Fix Deployment: 83%
Affected | Fix | |
---|---|---|
Bitcoin-Qt bitcoind |
* - 0.4.7rc2 0.5.0rc1 - 0.5.6rc2 0.6.0rc1 - 0.6.0.8rc2 0.6.1rc1 - 0.6.2.2 |
0.4.7rc3 0.5.6rc3 0.6.0.9rc1 0.6.3rc1 |
References
BIP-0034
Date: Future Summary: Mandatory block protocol update Deployment: 66%
Affected | Fix | |
---|---|---|
Bitcoin-Qt bitcoind |
* - 0.4.7 0.5.0rc1 - 0.5.7 0.6.0rc1 - 0.6.0.9 0.6.1rc1 - 0.6.3 |
0.4.8rc1 0.5.7rc1 0.6.0.10rc1 0.6.4rc1 0.7.0rc1 |
wxBitcoin | ALL | NONE |
References
Definitions
A critical vulnerability is one that will have disastrous consequences if it is exploited. A serious vulnerability is one that will have serious consequences if it is exploited[1].