Merge pull request #8691

934b798 rpc: do not misidentify coinbase txes as pruned (moneromooo-monero)
This commit is contained in:
luigi1111 2023-02-06 12:24:17 -05:00
commit 672eedf9c2
No known key found for this signature in database
GPG key ID: F4ACA0183641E010

View file

@ -1009,7 +1009,17 @@ namespace cryptonote
CHECK_AND_ASSERT_MES(tx_hash == std::get<0>(tx), false, "mismatched tx hash"); CHECK_AND_ASSERT_MES(tx_hash == std::get<0>(tx), false, "mismatched tx hash");
e.tx_hash = *txhi++; e.tx_hash = *txhi++;
e.prunable_hash = epee::string_tools::pod_to_hex(std::get<2>(tx)); e.prunable_hash = epee::string_tools::pod_to_hex(std::get<2>(tx));
if (req.split || req.prune || std::get<3>(tx).empty())
// coinbase txes do not have signatures to prune, so they appear to be pruned if looking just at prunable data being empty
bool pruned = std::get<3>(tx).empty();
if (pruned)
{
cryptonote::transaction t;
if (cryptonote::parse_and_validate_tx_base_from_blob(std::get<1>(tx), t) && is_coinbase(t))
pruned = false;
}
if (req.split || req.prune || pruned)
{ {
// use splitted form with pruned and prunable (filled only when prune=false and the daemon has it), leaving as_hex as empty // use splitted form with pruned and prunable (filled only when prune=false and the daemon has it), leaving as_hex as empty
e.pruned_as_hex = string_tools::buff_to_hex_nodelimer(std::get<1>(tx)); e.pruned_as_hex = string_tools::buff_to_hex_nodelimer(std::get<1>(tx));