mirror of
https://github.com/twisterarmy/twister-core.git
synced 2025-01-09 14:28:22 +00:00
move spamuser key validation from CheckTransation to ConnectBlock.
reason: this is not context-independent validation.
This commit is contained in:
parent
fbc7d9a77a
commit
ba43f10e8f
71
src/main.cpp
71
src/main.cpp
@ -437,37 +437,8 @@ bool CheckTransaction(const CTransaction& tx, CValidationState &state, int maxHe
|
|||||||
return state.DoS(100, error("CheckTransaction() : spam message too big"));
|
return state.DoS(100, error("CheckTransaction() : spam message too big"));
|
||||||
|
|
||||||
string spamUser = tx.userName.ExtractPushDataString(0);
|
string spamUser = tx.userName.ExtractPushDataString(0);
|
||||||
if( spamUser != "nobody" ) {
|
if (!spamUser.size() || spamUser.size() > MAX_USERNAME_SIZE)
|
||||||
string strSign = tx.userName.ExtractPushDataString(1);
|
return state.DoS(100, error("CheckTransaction() : spam user size invalid"));
|
||||||
if (!strSign.size())
|
|
||||||
return state.DoS(100, error("CheckTransaction() : spam signature missing"));
|
|
||||||
vector<unsigned char> vchSig((const unsigned char*)strSign.data(),
|
|
||||||
(const unsigned char*)strSign.data() + strSign.size());
|
|
||||||
|
|
||||||
CPubKey pubkey;
|
|
||||||
CTransaction txPubKey;
|
|
||||||
uint256 hashBlock;
|
|
||||||
if( !GetTransaction(spamUser, txPubKey, hashBlock, maxHeight) )
|
|
||||||
return state.DoS(100, error("CheckTransaction() : spam signed by unknown user"));
|
|
||||||
|
|
||||||
std::vector< std::vector<unsigned char> > vData;
|
|
||||||
if( !txPubKey.pubKey.ExtractPushData(vData) || vData.size() < 1 )
|
|
||||||
return state.DoS(100, error("CheckTransaction() : spam signed with broken pubkey"));
|
|
||||||
|
|
||||||
pubkey = CPubKey(vData[0]);
|
|
||||||
|
|
||||||
// compute message hash for signature checking
|
|
||||||
CHashWriter ss(SER_GETHASH, PROTOCOL_VERSION);
|
|
||||||
ss << strMessageMagic;
|
|
||||||
ss << tx.message;
|
|
||||||
|
|
||||||
CPubKey pubkeyRec;
|
|
||||||
if (!pubkeyRec.RecoverCompact(ss.GetHash(), vchSig))
|
|
||||||
return state.DoS(100, error("CheckTransaction() : RecoverCompact failed for spammsg"));
|
|
||||||
|
|
||||||
if (pubkeyRec.GetID() != pubkey.GetID())
|
|
||||||
return state.DoS(100, error("CheckTransaction() : spam signature verification failed"));
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if (tx.userName.empty())
|
if (tx.userName.empty())
|
||||||
return state.DoS(10, error("CheckTransaction() : username empty"));
|
return state.DoS(10, error("CheckTransaction() : username empty"));
|
||||||
@ -1163,6 +1134,44 @@ bool ConnectBlock(CBlock& block, CValidationState& state, CBlockIndex* pindex, C
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check if spamuser is valid.
|
||||||
|
// this is not context-independent, so it can't be performed in CheckTransaction
|
||||||
|
{
|
||||||
|
CTransaction &tx = block.vtx[0];
|
||||||
|
string spamUser = tx.userName.ExtractPushDataString(0);
|
||||||
|
if( spamUser != "nobody" ) {
|
||||||
|
string strSign = tx.userName.ExtractPushDataString(1);
|
||||||
|
if (!strSign.size())
|
||||||
|
return state.DoS(100, error("ConnectBlock() : spam signature missing"));
|
||||||
|
vector<unsigned char> vchSig((const unsigned char*)strSign.data(),
|
||||||
|
(const unsigned char*)strSign.data() + strSign.size());
|
||||||
|
|
||||||
|
CPubKey pubkey;
|
||||||
|
CTransaction txPubKey;
|
||||||
|
uint256 hashBlock;
|
||||||
|
if( !GetTransaction(spamUser, txPubKey, hashBlock, block.nHeight) )
|
||||||
|
return state.DoS(100, error("ConnectBlock() : spam signed by unknown user"));
|
||||||
|
|
||||||
|
std::vector< std::vector<unsigned char> > vData;
|
||||||
|
if( !txPubKey.pubKey.ExtractPushData(vData) || vData.size() < 1 )
|
||||||
|
return state.DoS(100, error("ConnectBlock() : spam signed with broken pubkey"));
|
||||||
|
|
||||||
|
pubkey = CPubKey(vData[0]);
|
||||||
|
|
||||||
|
// compute message hash for signature checking
|
||||||
|
CHashWriter ss(SER_GETHASH, PROTOCOL_VERSION);
|
||||||
|
ss << strMessageMagic;
|
||||||
|
ss << tx.message;
|
||||||
|
|
||||||
|
CPubKey pubkeyRec;
|
||||||
|
if (!pubkeyRec.RecoverCompact(ss.GetHash(), vchSig))
|
||||||
|
return state.DoS(100, error("ConnectBlock() : RecoverCompact failed for spammsg"));
|
||||||
|
|
||||||
|
if (pubkeyRec.GetID() != pubkey.GetID())
|
||||||
|
return state.DoS(100, error("ConnectBlock() : spam signature verification failed"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Do not allow blocks that contain transactions which 'overwrite' older transactions,
|
// Do not allow blocks that contain transactions which 'overwrite' older transactions,
|
||||||
// except if they are signed by the older one (key replacement)
|
// except if they are signed by the older one (key replacement)
|
||||||
for (unsigned int i = 1; i < block.vtx.size(); i++) {
|
for (unsigned int i = 1; i < block.vtx.size(); i++) {
|
||||||
|
Loading…
Reference in New Issue
Block a user