make sure torrent_info::is_valid returns false when the file fails to load

This commit is contained in:
arvidn 2017-01-18 20:13:46 -05:00 committed by Arvid Norberg
parent a07ffe42f8
commit c7c204280a
4 changed files with 22 additions and 0 deletions

View File

@ -1,3 +1,4 @@
* make torrent_info::is_valid() return false if torrent failed to load
* fix per-torrent rate limits for >256 peer classes * fix per-torrent rate limits for >256 peer classes
* don't load user_agent and peer_fingerprint from session_state * don't load user_agent and peer_fingerprint from session_state
* fix file rename issue with name prefix matching torrent name * fix file rename issue with name prefix matching torrent name

View File

@ -388,6 +388,8 @@ namespace libtorrent
TORRENT_ASSERT(ti.num_files() > 0); TORRENT_ASSERT(ti.num_files() > 0);
TORRENT_ASSERT(ti.total_size() > 0); TORRENT_ASSERT(ti.total_size() > 0);
if (!ti.is_valid()) return;
if (ti.creation_date()) m_creation_date = *ti.creation_date(); if (ti.creation_date()) m_creation_date = *ti.creation_date();
if (!ti.creator().empty()) set_creator(ti.creator().c_str()); if (!ti.creator().empty()) set_creator(ti.creator().c_str());

View File

@ -1249,6 +1249,8 @@ namespace libtorrent
if (!name_ent) if (!name_ent)
{ {
ec = errors::torrent_missing_name; ec = errors::torrent_missing_name;
// mark the torrent as invalid
m_files.set_piece_length(0);
return false; return false;
} }
@ -1266,14 +1268,22 @@ namespace libtorrent
// this is the counter used to name pad files // this is the counter used to name pad files
int pad_file_cnt = 0; int pad_file_cnt = 0;
if (!extract_single_file(info, files, "", info_ptr_diff, true, pad_file_cnt, ec)) if (!extract_single_file(info, files, "", info_ptr_diff, true, pad_file_cnt, ec))
{
// mark the torrent as invalid
m_files.set_piece_length(0);
return false; return false;
}
m_multifile = false; m_multifile = false;
} }
else else
{ {
if (!extract_files(files_node, files, name, info_ptr_diff, ec)) if (!extract_files(files_node, files, name, info_ptr_diff, ec))
{
// mark the torrent as invalid
m_files.set_piece_length(0);
return false; return false;
}
m_multifile = true; m_multifile = true;
} }
TORRENT_ASSERT(!files.name().empty()); TORRENT_ASSERT(!files.name().empty());
@ -1290,6 +1300,8 @@ namespace libtorrent
if (!pieces && !root_hash) if (!pieces && !root_hash)
{ {
ec = errors::torrent_missing_pieces; ec = errors::torrent_missing_pieces;
// mark the torrent as invalid
m_files.set_piece_length(0);
return false; return false;
} }
@ -1298,6 +1310,8 @@ namespace libtorrent
if (pieces.string_length() != files.num_pieces() * 20) if (pieces.string_length() != files.num_pieces() * 20)
{ {
ec = errors::torrent_invalid_hashes; ec = errors::torrent_invalid_hashes;
// mark the torrent as invalid
m_files.set_piece_length(0);
return false; return false;
} }
@ -1311,6 +1325,8 @@ namespace libtorrent
if (root_hash.string_length() != 20) if (root_hash.string_length() != 20)
{ {
ec = errors::torrent_invalid_hashes; ec = errors::torrent_invalid_hashes;
// mark the torrent as invalid
m_files.set_piece_length(0);
return false; return false;
} }
int num_leafs = merkle_num_leafs(files.num_pieces()); int num_leafs = merkle_num_leafs(files.num_pieces());
@ -1318,6 +1334,8 @@ namespace libtorrent
if (num_nodes - num_leafs >= (2<<24)) if (num_nodes - num_leafs >= (2<<24))
{ {
ec = errors::too_many_pieces_in_torrent; ec = errors::too_many_pieces_in_torrent;
// mark the torrent as invalid
m_files.set_piece_length(0);
return false; return false;
} }
m_merkle_first_leaf = num_nodes - num_leafs; m_merkle_first_leaf = num_nodes - num_leafs;

View File

@ -775,6 +775,7 @@ TORRENT_TEST(parse_torrents)
fprintf(stdout, "E: \"%s\"\nexpected: \"%s\"\n", ec.message().c_str() fprintf(stdout, "E: \"%s\"\nexpected: \"%s\"\n", ec.message().c_str()
, test_error_torrents[i].error.message().c_str()); , test_error_torrents[i].error.message().c_str());
TEST_CHECK(ec.message() == test_error_torrents[i].error.message()); TEST_CHECK(ec.message() == test_error_torrents[i].error.message());
TEST_EQUAL(ti->is_valid(), false);
} }
} }