36#include <unordered_set>
37#include <boost/thread/recursive_mutex.hpp>
38#include <boost/uuid/uuid.hpp>
41#undef MONERO_DEFAULT_LOG_CATEGORY
42#define MONERO_DEFAULT_LOG_CATEGORY "cn.block_queue"
46 struct block_complete_entry;
55 std::vector<cryptonote::block_complete_entry>
blocks;
60 boost::posix_time::ptime
time;
75 void flush_spans(
const boost::uuids::uuid &connection_id,
bool all =
false);
77 bool remove_span(uint64_t start_block_height, std::vector<crypto::hash> *
hashes = NULL);
78 void remove_spans(
const boost::uuids::uuid &connection_id, uint64_t start_block_height);
81 std::string
get_overview(uint64_t blockchain_height)
const;
83 std::pair<uint64_t, uint64_t>
reserve_span(uint64_t first_block_height, uint64_t last_block_height, uint64_t max_blocks,
const boost::uuids::uuid &connection_id,
const epee::net_utils::network_address &addr,
bool sync_pruned_blocks,
uint32_t local_pruning_seed,
uint32_t pruning_seed, uint64_t blockchain_height,
const std::vector<std::pair<crypto::hash, uint64_t>> &block_hashes, boost::posix_time::ptime time = boost::posix_time::microsec_clock::universal_time());
85 std::pair<uint64_t, uint64_t>
get_next_span_if_scheduled(std::vector<crypto::hash> &
hashes, boost::uuids::uuid &connection_id, boost::posix_time::ptime &time)
const;
86 void reset_next_span_time(boost::posix_time::ptime t = boost::posix_time::microsec_clock::universal_time());
87 void set_span_hashes(uint64_t start_height,
const boost::uuids::uuid &connection_id, std::vector<crypto::hash>
hashes);
89 bool has_next_span(
const boost::uuids::uuid &connection_id,
bool &filled, boost::posix_time::ptime &time)
const;
90 bool has_next_span(uint64_t height,
bool &filled, boost::posix_time::ptime &time, boost::uuids::uuid &connection_id)
const;
95 bool has_spans(
const boost::uuids::uuid &connection_id)
const;
96 float get_speed(
const boost::uuids::uuid &connection_id)
const;
98 bool foreach(std::function<
bool(
const span&)> f)
const;
108 mutable boost::recursive_mutex
mutex;
#define s(x, c)
Definition: aesb.c:47
Definition: block_queue.h:49
float get_download_rate(const boost::uuids::uuid &connection_id) const
Definition: block_queue.cpp:508
void erase_block(block_map::iterator j)
Definition: block_queue.cpp:93
std::unordered_set< crypto::hash > requested_hashes
Definition: block_queue.h:109
std::set< span > block_map
Definition: block_queue.h:70
void remove_spans(const boost::uuids::uuid &connection_id, uint64_t start_block_height)
Definition: block_queue.cpp:134
void flush_stale_spans(const std::set< boost::uuids::uuid > &live_connections)
Definition: block_queue.cpp:104
bool requested(const crypto::hash &hash) const
Definition: block_queue.cpp:219
block_map blocks
Definition: block_queue.h:107
std::unordered_set< crypto::hash > have_blocks
Definition: block_queue.h:110
void print() const
Definition: block_queue.cpp:179
bool get_next_span(uint64_t &height, std::vector< cryptonote::block_complete_entry > &bcel, boost::uuids::uuid &connection_id, epee::net_utils::network_address &addr, bool filled=true) const
Definition: block_queue.cpp:357
std::pair< uint64_t, uint64_t > reserve_span(uint64_t first_block_height, uint64_t last_block_height, uint64_t max_blocks, const boost::uuids::uuid &connection_id, const epee::net_utils::network_address &addr, bool sync_pruned_blocks, uint32_t local_pruning_seed, uint32_t pruning_seed, uint64_t blockchain_height, const std::vector< std::pair< crypto::hash, uint64_t > > &block_hashes, boost::posix_time::ptime time=boost::posix_time::microsec_clock::universal_time())
Definition: block_queue.cpp:231
float get_speed(const boost::uuids::uuid &connection_id) const
Definition: block_queue.cpp:472
void set_span_hashes(uint64_t start_height, const boost::uuids::uuid &connection_id, std::vector< crypto::hash > hashes)
Definition: block_queue.cpp:339
size_t get_num_filled_spans() const
Definition: block_queue.cpp:433
bool remove_span(uint64_t start_block_height, std::vector< crypto::hash > *hashes=NULL)
Definition: block_queue.cpp:118
crypto::hash get_last_known_hash(const boost::uuids::uuid &connection_id) const
Definition: block_queue.cpp:443
void flush_spans(const boost::uuids::uuid &connection_id, bool all=false)
Definition: block_queue.cpp:79
void add_blocks(uint64_t height, std::vector< cryptonote::block_complete_entry > bcel, const boost::uuids::uuid &connection_id, const epee::net_utils::network_address &addr, float rate, size_t size)
Definition: block_queue.cpp:55
bool has_spans(const boost::uuids::uuid &connection_id) const
Definition: block_queue.cpp:462
bool has_next_span(const boost::uuids::uuid &connection_id, bool &filled, boost::posix_time::ptime &time) const
Definition: block_queue.cpp:377
size_t get_num_filled_spans_prefix() const
Definition: block_queue.cpp:417
boost::recursive_mutex mutex
Definition: block_queue.h:108
std::string get_overview(uint64_t blockchain_height) const
Definition: block_queue.cpp:187
bool has_unpruned_height(uint64_t block_height, uint64_t blockchain_height, uint32_t pruning_seed) const
std::pair< uint64_t, uint64_t > get_next_span_if_scheduled(std::vector< crypto::hash > &hashes, boost::uuids::uuid &connection_id, boost::posix_time::ptime &time) const
Definition: block_queue.cpp:313
bool requested_internal(const crypto::hash &hash) const
Definition: block_queue.cpp:214
uint64_t get_next_needed_height(uint64_t blockchain_height) const
Definition: block_queue.cpp:160
uint64_t get_max_block_height() const
Definition: block_queue.cpp:147
size_t get_data_size() const
Definition: block_queue.cpp:408
void reset_next_span_time(boost::posix_time::ptime t=boost::posix_time::microsec_clock::universal_time())
Definition: block_queue.cpp:329
bool have(const crypto::hash &hash) const
Definition: block_queue.cpp:225
Definition: net_utils_base.h:223
Definition: blocks.cpp:13
Definition: portable_binary_archive.hpp:29
POD_CLASS hash
Definition: hash.h:48
Holds cryptonote related classes and helpers.
Definition: blockchain_db.cpp:45
@ all
Everything in the db.
unsigned int uint32_t
Definition: stdint.h:126
unsigned __int64 uint64_t
Definition: stdint.h:136
Definition: block_queue.h:52
std::vector< crypto::hash > hashes
Definition: block_queue.h:54
boost::uuids::uuid connection_id
Definition: block_queue.h:56
std::vector< cryptonote::block_complete_entry > blocks
Definition: block_queue.h:55
bool operator<(const span &s) const
Definition: block_queue.h:68
boost::posix_time::ptime time
Definition: block_queue.h:60
epee::net_utils::network_address origin
Definition: block_queue.h:61
span(uint64_t start_block_height, std::vector< cryptonote::block_complete_entry > blocks, const boost::uuids::uuid &connection_id, const epee::net_utils::network_address &addr, float rate, size_t size)
Definition: block_queue.h:63
float rate
Definition: block_queue.h:58
size_t size
Definition: block_queue.h:59
uint64_t nblocks
Definition: block_queue.h:57
uint64_t start_block_height
Definition: block_queue.h:53
span(uint64_t start_block_height, uint64_t nblocks, const boost::uuids::uuid &connection_id, const epee::net_utils::network_address &addr, boost::posix_time::ptime time)
Definition: block_queue.h:65
struct hash_func hashes[]