Merge pull request #3357
4ef92a9
Refuse to retransmit transactions without vins (Wladimir J. van der Laan)
This commit is contained in:
commit
80ca273b7f
1 changed files with 4 additions and 1 deletions
|
@ -895,7 +895,10 @@ void CWalletTx::RelayWalletTransaction()
|
||||||
{
|
{
|
||||||
BOOST_FOREACH(const CMerkleTx& tx, vtxPrev)
|
BOOST_FOREACH(const CMerkleTx& tx, vtxPrev)
|
||||||
{
|
{
|
||||||
if (!tx.IsCoinBase())
|
// Important: versions of bitcoin before 0.8.6 had a bug that inserted
|
||||||
|
// empty transactions into the vtxPrev, which will cause the node to be
|
||||||
|
// banned when retransmitted, hence the check for !tx.vin.empty()
|
||||||
|
if (!tx.IsCoinBase() && !tx.vin.empty())
|
||||||
if (tx.GetDepthInMainChain() == 0)
|
if (tx.GetDepthInMainChain() == 0)
|
||||||
RelayTransaction((CTransaction)tx, tx.GetHash());
|
RelayTransaction((CTransaction)tx, tx.GetHash());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue