Merge pull request #3726

b5cb1bc blockchain: avoid exception if asked for a block we do not have (moneromooo-monero)
This commit is contained in:
luigi1111 2018-06-16 14:02:56 -05:00
commit b3363e8e0a
No known key found for this signature in database
GPG Key ID: F4ACA0183641E010
1 changed files with 11 additions and 8 deletions

View File

@ -2095,16 +2095,19 @@ bool Blockchain::get_blocks(const t_ids_container& block_ids, t_blocks_container
{
try
{
blocks.push_back(std::make_pair(m_db->get_block_blob(block_hash), block()));
if (!parse_and_validate_block_from_blob(blocks.back().first, blocks.back().second))
uint64_t height = 0;
if (m_db->block_exists(block_hash, &height))
{
LOG_ERROR("Invalid block");
return false;
blocks.push_back(std::make_pair(m_db->get_block_blob_from_height(height), block()));
if (!parse_and_validate_block_from_blob(blocks.back().first, blocks.back().second))
{
LOG_ERROR("Invalid block: " << block_hash);
blocks.pop_back();
missed_bs.push_back(block_hash);
}
}
}
catch (const BLOCK_DNE& e)
{
missed_bs.push_back(block_hash);
else
missed_bs.push_back(block_hash);
}
catch (const std::exception& e)
{