Check earlier for blocks with duplicate transactions. Fixes #1167
authorGavin Andresen <gavinandresen@gmail.com>
Mon, 30 Apr 2012 00:56:55 +0000 (20:56 -0400)
committerGavin Andresen <gavinandresen@gmail.com>
Mon, 30 Apr 2012 15:08:07 +0000 (11:08 -0400)
src/main.cpp

index e5d110d..427e435 100644 (file)
@@ -1652,6 +1652,16 @@ bool CBlock::CheckBlock() const
         if (!tx.CheckTransaction())
             return DoS(tx.nDoS, error("CheckBlock() : CheckTransaction failed"));
 
+    // Check for duplicate txids. This is caught by ConnectInputs(),
+    // but catching it earlier avoids a potential DoS attack:
+    set<uint256> uniqueTx;
+    BOOST_FOREACH(const CTransaction& tx, vtx)
+    {
+        uniqueTx.insert(tx.GetHash());
+    }
+    if (uniqueTx.size() != vtx.size())
+        return DoS(100, error("CheckBlock() : duplicate transaction"));
+
     unsigned int nSigOps = 0;
     BOOST_FOREACH(const CTransaction& tx, vtx)
     {