Monero
blockchain.h
Go to the documentation of this file.
1 // Copyright (c) 2014-2022, The Monero Project
2 //
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification, are
6 // permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice, this list of
9 // conditions and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice, this list
12 // of conditions and the following disclaimer in the documentation and/or other
13 // materials provided with the distribution.
14 //
15 // 3. Neither the name of the copyright holder nor the names of its contributors may be
16 // used to endorse or promote products derived from this software without specific
17 // prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22 // THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
26 // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
27 // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 //
29 // Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
30 
31 #pragma once
32 #include <boost/asio/executor_work_guard.hpp>
33 #include <boost/asio/io_context.hpp>
34 #include <boost/function/function_fwd.hpp>
35 #if BOOST_VERSION >= 107400
36 #include <boost/serialization/library_version_type.hpp>
37 #endif
38 #include <boost/serialization/serialization.hpp>
39 #include <boost/serialization/version.hpp>
40 #include <boost/serialization/list.hpp>
41 #include <boost/multi_index_container.hpp>
42 #include <boost/multi_index/global_fun.hpp>
43 #include <boost/multi_index/hashed_index.hpp>
44 #include <boost/multi_index/member.hpp>
45 #include <atomic>
46 #include <functional>
47 #include <unordered_map>
48 #include <unordered_set>
49 
50 #include "span.h"
51 #include "syncobj.h"
52 #include "string_tools.h"
53 #include "rolling_median.h"
55 #include "common/powerof.h"
56 #include "common/util.h"
60 #include "cryptonote_tx_utils.h"
61 #include "tx_verification_utils.h"
63 #include "crypto/hash.h"
67 
68 namespace tools { class Notify; }
69 
70 namespace cryptonote
71 {
72  class tx_memory_pool;
73  struct test_options;
74 
79  {
84  };
85 
93  typedef std::function<const epee::span<const unsigned char>(cryptonote::network_type network)> GetCheckpointsCallback;
94 
95  typedef boost::function<void(std::vector<txpool_event>)> TxpoolNotifyCallback;
96  typedef boost::function<void(uint64_t /* height */, epee::span<const block> /* blocks */)> BlockNotifyCallback;
97  typedef boost::function<void(uint8_t /* major_version */, uint64_t /* height */, const crypto::hash& /* prev_id */, const crypto::hash& /* seed_hash */, difficulty_type /* diff */, uint64_t /* median_weight */, uint64_t /* already_generated_coins */, const std::vector<tx_block_template_backlog_entry>& /* tx_backlog */)> MinerNotifyCallback;
98 
99  /************************************************************************/
100  /* */
101  /************************************************************************/
103  {
104  public:
109  {
115  };
116 
122  Blockchain(tx_memory_pool& tx_pool);
123 
127  ~Blockchain();
128 
141  bool init(BlockchainDB* db, const network_type nettype = MAINNET, bool offline = false, const cryptonote::test_options *test_options = NULL, difficulty_type fixed_difficulty = 0, const GetCheckpointsCallback& get_checkpoints = nullptr);
142 
153  bool init(BlockchainDB* db, HardFork*& hf, const network_type nettype = MAINNET, bool offline = false);
154 
162  bool deinit();
163 
169  const checkpoints& get_checkpoints() const { return m_checkpoints; }
170 
176  void set_checkpoints(checkpoints&& chk_pts) { m_checkpoints = chk_pts; }
177 
188  bool get_blocks(uint64_t start_offset, size_t count, std::vector<std::pair<cryptonote::blobdata,block>>& blocks, std::vector<cryptonote::blobdata>& txs) const;
189 
199  bool get_blocks(uint64_t start_offset, size_t count, std::vector<std::pair<cryptonote::blobdata,block>>& blocks) const;
200 
208  bool get_alternative_blocks(std::vector<block>& blocks) const;
209 
215  size_t get_alternative_blocks_count() const;
216 
225 
237 
247  bool get_block_by_hash(const crypto::hash &h, block &blk, bool *orphan = NULL) const;
248 
257  bool prepare_handle_incoming_blocks(const std::vector<block_complete_entry> &blocks_entry, std::vector<block> &blocks);
258 
267  void prepare_handle_incoming_block_no_preprocess(const size_t block_byte_estimate);
268 
276  bool cleanup_handle_incoming_blocks(bool force_sync = false);
277 
285  bool have_tx(const crypto::hash &id) const;
286 
294  bool have_tx_keyimges_as_spent(const transaction &tx) const;
295 
308  bool have_tx_keyimg_as_spent(const crypto::key_image &key_im) const;
309 
316 
322  crypto::hash get_tail_id() const;
323 
331  crypto::hash get_tail_id(uint64_t& height) const;
332 
339 
345  std::pair<bool, uint64_t> check_difficulty_checkpoints() const;
346 
354  size_t recalculate_difficulties(boost::optional<uint64_t> start_height = boost::none);
355 
370  bool add_new_block(const block& bl_, block_verification_context& bvc);
371 
372  bool add_new_block(const block& bl_, block_verification_context& bvc,
373  pool_supplement& extra_block_txs);
374 
382  bool reset_and_set_genesis_block(const block& b);
383 
397  bool create_block_template(block& b, const account_public_address& miner_address, difficulty_type& di, uint64_t& height, uint64_t& expected_reward, const blobdata& ex_nonce, uint64_t &seed_height, crypto::hash &seed_hash);
398  bool create_block_template(block& b, const crypto::hash *from_block, const account_public_address& miner_address, difficulty_type& di, uint64_t& height, uint64_t& expected_reward, const blobdata& ex_nonce, uint64_t &seed_height, crypto::hash &seed_hash);
399 
414  bool get_miner_data(uint8_t& major_version, uint64_t& height, crypto::hash& prev_id, crypto::hash& seed_hash, difficulty_type& difficulty, uint64_t& median_weight, uint64_t& already_generated_coins, std::vector<tx_block_template_backlog_entry>& tx_backlog);
415 
427  bool have_block_unlocked(const crypto::hash& id, int *where = NULL) const;
428  bool have_block(const crypto::hash& id, int *where = NULL) const;
429 
435  size_t get_total_transactions() const;
436 
451  bool get_short_chain_history(std::list<crypto::hash>& ids) const;
452 
469  bool find_blockchain_supplement(const std::list<crypto::hash>& qblock_ids, std::vector<crypto::hash>& hashes, std::vector<uint64_t>* weights, uint64_t& start_height, uint64_t& current_height, bool clip_pruned) const;
470 
484  bool find_blockchain_supplement(const std::list<crypto::hash>& qblock_ids, bool clip_pruned, NOTIFY_RESPONSE_CHAIN_ENTRY::request& resp) const;
485 
498  bool find_blockchain_supplement(const std::list<crypto::hash>& qblock_ids, uint64_t& starter_offset) const;
499 
518  bool find_blockchain_supplement(const uint64_t req_start_block, const std::list<crypto::hash>& qblock_ids, std::vector<std::pair<std::pair<cryptonote::blobdata, crypto::hash>, std::vector<std::pair<crypto::hash, cryptonote::blobdata> > > >& blocks, uint64_t& total_height, uint64_t& start_height, bool pruned, bool get_miner_tx_hash, size_t max_block_count, size_t max_tx_count) const;
519 
533 
542 
551  crypto::public_key get_output_key(uint64_t amount, uint64_t global_index) const;
552 
567 
577  void get_output_key_mask_unlocked(const uint64_t& amount, const uint64_t& index, crypto::public_key& key, rct::key& mask, bool& unlocked) const;
578 
589  bool get_output_distribution(uint64_t amount, uint64_t from_height, uint64_t to_height, uint64_t &start_height, std::vector<uint64_t> &distribution, uint64_t &base) const;
590 
603  bool get_tx_outputs_gindexs(const crypto::hash& tx_id, std::vector<uint64_t>& indexs) const;
604  bool get_tx_outputs_gindexs(const crypto::hash& tx_id, size_t n_txes, std::vector<std::vector<uint64_t>>& indexs) const;
605 
614  bool store_blockchain();
615 
623  static bool expand_transaction_2(transaction &tx, const crypto::hash &tx_prefix_hash, const std::vector<std::vector<rct::ctkey>> &pubkeys);
624 
641  bool check_tx_inputs(transaction& tx, uint64_t& pmax_used_block_height, crypto::hash& max_used_block_id, tx_verification_context &tvc, bool kept_by_block = false) const;
642 
651  {
653  }
654 
668  static uint64_t get_dynamic_base_fee(uint64_t block_reward, size_t median_block_weight, uint8_t version);
669 
683  uint64_t get_dynamic_base_fee_estimate(uint64_t grace_blocks) const;
684  void get_dynamic_base_fee_estimate_2021_scaling(uint64_t grace_blocks, uint64_t base_reward, uint64_t Mnw, uint64_t Mlw, std::vector<uint64_t> &fees) const;
685 
699  void get_dynamic_base_fee_estimate_2021_scaling(uint64_t grace_blocks, std::vector<uint64_t> &fees) const;
700 
713  bool check_fee(size_t tx_weight, uint64_t fee) const;
714 
728  static bool check_tx_outputs(const transaction& tx,
730  std::uint8_t hf_version);
731 
738 
745 
752 
761 
774  template<class t_ids_container, class t_blocks_container, class t_missed_container>
775  bool get_blocks(const t_ids_container& block_ids, t_blocks_container& blocks, t_missed_container& missed_bs) const;
776 
790  bool get_transactions_blobs(const std::vector<crypto::hash>& txs_ids, std::vector<cryptonote::blobdata>& txs, std::vector<crypto::hash>& missed_txs, bool pruned = false) const;
791  bool get_transactions_blobs(const std::vector<crypto::hash>& txs_ids, std::vector<tx_blob_entry>& txs, std::vector<crypto::hash>& missed_txs, bool pruned = false) const;
792  template<class t_ids_container, class t_tx_container, class t_missed_container>
793  bool get_split_transactions_blobs(const t_ids_container& txs_ids, t_tx_container& txs, t_missed_container& missed_txs) const;
794  template<class t_ids_container, class t_tx_container, class t_missed_container>
795  bool get_transactions(const t_ids_container& txs_ids, t_tx_container& txs, t_missed_container& missed_txs, bool pruned = false) const;
796 
797  //debug functions
798 
810  void check_against_checkpoints(const checkpoints& points, bool enforce);
811 
817  void set_enforce_dns_checkpoints(bool enforce);
818 
827  bool update_checkpoints(const std::string& file_path, bool check_dns);
828 
829 
830  // user options, must be called before calling init()
831 
841  void set_user_options(uint64_t maxthreads, bool sync_on_blocks, uint64_t sync_threshold,
842  blockchain_db_sync_mode sync_mode, bool fast_sync);
843 
850 
856  void add_block_notify(BlockNotifyCallback&& notify);
857 
863  void add_miner_notify(MinerNotifyCallback&& notify);
864 
870  void set_reorg_notify(const std::shared_ptr<tools::Notify> &notify) { m_reorg_notify = notify; }
871 
875  void notify_txpool_event(std::vector<txpool_event>&& event) const;
876 
880  void safesyncmode(const bool onoff);
881 
887  void set_show_time_stats(bool stats) { m_show_time_stats = stats; }
888 
895 
902 
909 
916 
926 
934  uint8_t get_hard_fork_version(uint64_t height) const { return m_hardfork->get(height); }
935 
942 
948  const std::vector<hardfork_t>& get_hardforks() const { return m_hardfork->get_hardforks(); }
949 
962  bool get_hard_fork_voting_info(uint8_t version, uint32_t &window, uint32_t &votes, uint32_t &threshold, uint64_t &earliest_height, uint8_t &voting) const;
963 
970 
978  bool flush_txes_from_pool(const std::vector<crypto::hash> &txids);
979 
990  std::map<uint64_t, std::tuple<uint64_t, uint64_t, uint64_t>> get_output_histogram(const std::vector<uint64_t> &amounts, bool unlocked, uint64_t recent_cutoff, uint64_t min_count = 0) const;
991 
999  bool for_all_key_images(std::function<bool(const crypto::key_image&)>) const;
1000 
1010  bool for_blocks_range(const uint64_t& h1, const uint64_t& h2, std::function<bool(uint64_t, const crypto::hash&, const block&)>) const;
1011 
1020  bool for_all_transactions(std::function<bool(const crypto::hash&, const cryptonote::transaction&)>, bool pruned) const;
1021 
1029  bool for_all_outputs(std::function<bool(uint64_t amount, const crypto::hash &tx_hash, uint64_t height, size_t tx_idx)>) const;
1030 
1039  bool for_all_outputs(uint64_t amount, std::function<bool(uint64_t height)>) const;
1040 
1046  const BlockchainDB& get_db() const
1047  {
1048  return *m_db;
1049  }
1050 
1057  {
1058  return *m_db;
1059  }
1060 
1068  void output_scan_worker(const uint64_t amount,const std::vector<uint64_t> &offsets,
1069  std::vector<output_data_t> &outputs) const;
1070 
1079  std::unordered_map<crypto::hash, crypto::hash> &map) const;
1080 
1086  std::vector<std::pair<block_extended_info,std::vector<crypto::hash>>> get_alternative_chains() const;
1087 
1088  void add_txpool_tx(const crypto::hash &txid, const cryptonote::blobdata &blob, const txpool_tx_meta_t &meta);
1089  void update_txpool_tx(const crypto::hash &txid, const txpool_tx_meta_t &meta);
1090  void remove_txpool_tx(const crypto::hash &txid);
1091  uint64_t get_txpool_tx_count(bool include_sensitive = false) const;
1092  bool get_txpool_tx_meta(const crypto::hash& txid, txpool_tx_meta_t &meta) const;
1093  bool get_txpool_tx_blob(const crypto::hash& txid, cryptonote::blobdata &bd, relay_category tx_category) const;
1094  cryptonote::blobdata get_txpool_tx_blob(const crypto::hash& txid, relay_category tx_category) const;
1095  bool for_all_txpool_txes(std::function<bool(const crypto::hash&, const txpool_tx_meta_t&, const cryptonote::blobdata_ref*)>, bool include_blob = false, relay_category tx_category = relay_category::broadcasted) const;
1096  bool txpool_tx_matches_category(const crypto::hash& tx_hash, relay_category category);
1097 
1099  uint64_t prevalidate_block_hashes(uint64_t height, const std::vector<crypto::hash> &hashes, const std::vector<uint64_t> &weights);
1101  bool prune_blockchain(uint32_t pruning_seed = 0);
1103  bool check_blockchain_pruning();
1104 
1105  void lock();
1106  void unlock();
1107 
1108  void cancel();
1109 
1113  std::vector<time_t> get_last_block_timestamps(unsigned int blocks) const;
1114 
1120  void pop_blocks(uint64_t nblocks);
1121 
1127  bool is_within_compiled_block_hash_area(uint64_t height) const;
1128 
1135  bool has_block_weights(uint64_t height, uint64_t nblocks) const;
1136 
1140  void flush_invalid_blocks();
1141 
1155  uint64_t get_adjusted_time(uint64_t height) const;
1156 
1157 #ifndef IN_UNIT_TESTS
1158  private:
1159 #endif
1160 
1161  // TODO: evaluate whether or not each of these typedefs are left over from blockchain_storage
1162  typedef std::unordered_set<crypto::key_image> key_images_container;
1163 
1164  typedef std::vector<block_extended_info> blocks_container;
1165 
1166  typedef std::unordered_map<crypto::hash, block_extended_info> blocks_ext_by_hash;
1167 
1168 
1170 
1172 
1173  mutable epee::critical_section m_blockchain_lock; // TODO: add here reader/writer lock
1174 
1175  // main chain
1178 
1179  // metadata containers
1180  std::unordered_map<crypto::hash, std::unordered_map<crypto::key_image, std::vector<output_data_t>>> m_scan_table;
1181  std::unordered_map<crypto::hash, crypto::hash> m_blocks_longhash_table;
1182 
1183  // Keccak hashes for each block and for fast pow checking
1184  std::vector<std::pair<crypto::hash, crypto::hash>> m_blocks_hash_of_hashes;
1185  std::vector<std::pair<crypto::hash, uint64_t>> m_blocks_hash_check;
1186 
1198  std::vector<uint64_t> m_timestamps;
1199  std::vector<difficulty_type> m_difficulties;
1206 
1210 
1211  boost::asio::io_context m_async_service;
1212  boost::thread_group m_async_pool;
1213  std::unique_ptr<boost::asio::executor_work_guard<boost::asio::io_context::executor_type>> m_async_work_idle;
1214 
1215  // some invalid blocks
1216  blocks_ext_by_hash m_invalid_blocks; // crypto::hash -> block_extended_info
1217 
1218 
1221 
1223 
1227 
1228  std::atomic<bool> m_cancel;
1229 
1230  // block template cache
1241 
1242 
1244 
1246  mutable std::mutex m_txpool_notifier_mutex;
1247 
1248  /* `boost::function` is used because the implementation never allocates if
1249  the callable object has a single `std::shared_ptr` or `std::weap_ptr`
1250  internally. Whereas, the libstdc++ `std::function` will allocate. */
1251 
1252  std::vector<BlockNotifyCallback> m_block_notifiers;
1253  std::vector<MinerNotifyCallback> m_miner_notifiers;
1254  std::shared_ptr<tools::Notify> m_reorg_notify;
1255 
1256  // for prepare_handle_incoming_blocks
1259  std::vector<block> *m_prepare_blocks;
1260 
1261  // cache for verifying transaction RCT non semantics
1263 
1283  template<class visitor_t>
1284  inline bool scan_outputkeys_for_indexes(size_t tx_version, const txin_to_key& tx_in_to_key, visitor_t &vis, const crypto::hash &tx_prefix_hash, uint64_t* pmax_related_block_height = NULL) const;
1285 
1307  bool check_tx_input(size_t tx_version,const txin_to_key& txin, const crypto::hash& tx_prefix_hash, const std::vector<crypto::signature>& sig, const rct::rctSig &rct_signatures, std::vector<rct::ctkey> &output_keys, uint64_t* pmax_related_block_height, uint8_t hf_version) const;
1308 
1329  bool check_tx_inputs(transaction& tx, tx_verification_context &tvc, uint64_t* pmax_used_block_height = NULL) const;
1330 
1343  bool switch_to_alternative_blockchain(std::list<block_extended_info>& alt_chain, bool discard_disconnected_chain);
1344 
1351 
1365 
1380  bool handle_block_to_main_chain(const block& bl, const crypto::hash& id,
1381  block_verification_context& bvc, pool_supplement& extra_block_txs);
1382 
1397  bool handle_alternative_block(const block& b, const crypto::hash& id,
1398  block_verification_context& bvc, pool_supplement& extra_block_txs);
1399 
1410  bool build_alt_chain(const crypto::hash &prev_id, std::list<block_extended_info>& alt_chain, std::vector<uint64_t> &timestamps, block_verification_context& bvc) const;
1411 
1420  difficulty_type get_next_difficulty_for_alternative_chain(const std::list<block_extended_info>& alt_chain, block_extended_info& bei) const;
1421 
1434  bool prevalidate_miner_transaction(const block& b, uint64_t height, uint8_t hf_version);
1435 
1452  bool validate_miner_transaction(const block& b, size_t cumulative_block_weight, uint64_t fee, uint64_t& base_reward, uint64_t already_generated_coins, bool &partial_block_reward, uint8_t version);
1453 
1466  bool rollback_blockchain_switching(std::list<block>& original_chain, uint64_t rollback_height);
1467 
1476  void get_last_n_blocks_weights(std::vector<uint64_t>& weights, size_t count) const;
1477 
1488  uint64_t get_long_term_block_weight_median(uint64_t start_height, size_t count) const;
1489 
1501  bool is_tx_spendtime_unlocked(uint64_t unlock_time, uint8_t hf_version) const;
1502 
1514  bool add_block_as_invalid(const block& bl, const crypto::hash& h);
1515 
1527  bool add_block_as_invalid(const block_extended_info& bei, const crypto::hash& h);
1528 
1545  bool check_block_timestamp(const block& b, uint64_t& median_ts) const;
1546  bool check_block_timestamp(const block& b) const { uint64_t median_ts; return check_block_timestamp(b, median_ts); }
1547 
1559  bool check_block_timestamp(std::vector<uint64_t>& timestamps, const block& b, uint64_t& median_ts) const;
1560  bool check_block_timestamp(std::vector<uint64_t>& timestamps, const block& b) const { uint64_t median_ts; return check_block_timestamp(timestamps, b, median_ts); }
1561 
1573  bool complete_timestamps_vector(uint64_t start_height, std::vector<uint64_t>& timestamps) const;
1574 
1582  bool update_next_cumulative_weight_limit(uint64_t *long_term_effective_median_block_weight = NULL);
1583 
1592  bool check_for_double_spend(const transaction& tx, key_images_container& keys_this_block) const;
1593 
1603  void check_ring_signature(const crypto::hash &tx_prefix_hash, const crypto::key_image &key_image,
1604  const std::vector<rct::ctkey> &pubkeys, const std::vector<crypto::signature> &sig, uint64_t &result) const;
1605 
1616 
1621 
1627  void cache_block_template(const block &b, const cryptonote::account_public_address &address, const blobdata &nonce, const difficulty_type &diff, uint64_t height, uint64_t expected_reward, uint64_t seed_height, const crypto::hash &seed_hash, uint64_t pool_cookie);
1628 
1637  void send_miner_notifications(uint64_t height, const crypto::hash &seed_hash, const crypto::hash &prev_id, uint64_t already_generated_coins);
1638  };
1639 } // namespace cryptonote
const char * res
Definition: hmac_keccak.cpp:42
static uint64_t get_dynamic_base_fee(uint64_t block_reward, size_t median_block_weight, uint8_t version)
get dynamic per kB or byte fee for a given block weight
Definition: blockchain.cpp:3620
uint64_t get_txpool_tx_count(bool include_sensitive=false) const
Definition: blockchain.cpp:5417
def difficulty()
Definition: gen_wide_data.py:11
uint64_t m_max_prepare_blocks_threads
Definition: blockchain.h:1193
bool check_block_timestamp(std::vector< uint64_t > &timestamps, const block &b) const
Definition: blockchain.h:1560
bool m_db_default_sync
Definition: blockchain.h:1190
difficulty_type get_next_difficulty_for_alternative_chain(const std::list< block_extended_info > &alt_chain, block_extended_info &bei) const
gets the difficulty requirement for a new block on an alternate chain
Definition: blockchain.cpp:1223
static bool check_tx_outputs(const transaction &tx, tx_verification_context &tvc, std::uint8_t hf_version)
check that a transaction&#39;s outputs conform to current standards
Definition: blockchain.cpp:2983
std::unordered_map< crypto::hash, std::unordered_map< crypto::key_image, std::vector< output_data_t > > > m_scan_table
Definition: blockchain.h:1180
difficulty_type block_difficulty(uint64_t i) const
gets the difficulty of the block with a given height
Definition: blockchain.cpp:2435
std::vector< std::pair< crypto::hash, uint64_t > > m_blocks_hash_check
Definition: blockchain.h:1185
block pop_block_from_blockchain()
removes the most recent block from the blockchain
Definition: blockchain.cpp:596
crypto::hash m_difficulty_for_next_block_top_hash
Definition: blockchain.h:1208
checkpoints m_checkpoints
Definition: blockchain.h:1219
bool add_block_as_invalid(const block &bl, const crypto::hash &h)
stores an invalid block in a separate container
Definition: blockchain.cpp:2765
Definition: cryptonote_config.h:303
bool have_tx_keyimg_as_spent(const crypto::key_image &key_im) const
check if a key image is already spent on the blockchain
Definition: blockchain.cpp:126
uint64_t m_fake_pow_calc_time
Definition: blockchain.h:1194
block bl
the block
Definition: blockchain.h:110
handle syncing calls instead of the backing db, asynchronously
Definition: blockchain.h:82
int * count
Definition: gmock_stress_test.cc:176
std::vector< uint64_t > m_timestamps
Definition: blockchain.h:1198
bool check_for_double_spend(const transaction &tx, key_images_container &keys_this_block) const
make sure a transaction isn&#39;t attempting a double-spend
Definition: blockchain.cpp:2852
epee::misc_utils::rolling_median_t< uint64_t > m_long_term_block_weights_cache_rolling_median
Definition: blockchain.h:1205
const checkpoints & get_checkpoints() const
get a set of blockchain checkpoint hashes
Definition: blockchain.h:169
void set_user_options(uint64_t maxthreads, bool sync_on_blocks, uint64_t sync_threshold, blockchain_db_sync_mode sync_mode, bool fast_sync)
sets various performance options
Definition: blockchain.cpp:5447
bool m_reset_timestamps_and_difficulties_height
Definition: blockchain.h:1201
uint64_t m_btc_height
Definition: blockchain.h:1235
uint64_t get_dynamic_base_fee_estimate(uint64_t grace_blocks) const
get dynamic per kB or byte fee estimate for the next few blocks
Definition: blockchain.cpp:3796
bool handle_alternative_block(const block &b, const crypto::hash &id, block_verification_context &bvc, pool_supplement &extra_block_txs)
validate and add a new block to an alternate blockchain
Definition: blockchain.cpp:1860
bool create_block_template(block &b, const account_public_address &miner_address, difficulty_type &di, uint64_t &height, uint64_t &expected_reward, const blobdata &ex_nonce, uint64_t &seed_height, crypto::hash &seed_hash)
creates a new block to mine against
Definition: blockchain.cpp:1748
BlockchainDB & get_db()
get a reference to the BlockchainDB in use by Blockchain
Definition: blockchain.h:1056
int i
Definition: pymoduletest.py:23
std::unique_ptr< boost::asio::executor_work_guard< boost::asio::io_context::executor_type > > m_async_work_idle
Definition: blockchain.h:1213
bool m_offline
Definition: blockchain.h:1225
static bool expand_transaction_2(transaction &tx, const crypto::hash &tx_prefix_hash, const std::vector< std::vector< rct::ctkey >> &pubkeys)
expands v2 transaction data from blockchain
Definition: blockchain.cpp:3145
#define CRYPTONOTE_DISPLAY_DECIMAL_POINT
Definition: cryptonote_config.h:65
::std::string string
Definition: gtest-port.h:1097
uint64_t get_current_cumulative_block_weight_limit() const
gets the block weight limit based on recent blocks
Definition: blockchain.cpp:1456
std::pair< bool, uint64_t > check_difficulty_checkpoints() const
check currently stored difficulties against difficulty checkpoints
Definition: blockchain.cpp:935
std::unordered_set< crypto::key_image > key_images_container
Definition: blockchain.h:1162
difficulty_type m_difficulty_for_next_block
Definition: blockchain.h:1209
bool m_fast_sync
Definition: blockchain.h:1188
Definition: cryptonote_basic.h:474
std::vector< block > * m_prepare_blocks
Definition: blockchain.h:1259
bool prepare_handle_incoming_blocks(const std::vector< block_complete_entry > &blocks_entry, std::vector< block > &blocks)
performs some preprocessing on a group of incoming blocks to speed up verification ...
Definition: blockchain.cpp:5033
blocks_ext_by_hash m_invalid_blocks
Definition: blockchain.h:1216
uint64_t m_db_sync_threshold
Definition: blockchain.h:1192
uint64_t get_earliest_ideal_height_for_version(uint8_t version) const
returns the earliest block a given version may activate
Definition: blockchain.h:941
uint64_t m_prepare_height
Definition: blockchain.h:1257
bool validate_miner_transaction(const block &b, size_t cumulative_block_weight, uint64_t fee, uint64_t &base_reward, uint64_t already_generated_coins, bool &partial_block_reward, uint8_t version)
validates a miner (coinbase) transaction
Definition: blockchain.cpp:1331
uint64_t m_fake_scan_time
Definition: blockchain.h:1195
user didn&#39;t specify, use db_async
Definition: blockchain.h:80
rct_ver_cache_t m_rct_ver_cache
Definition: blockchain.h:1262
crypto::public_key get_output_key(uint64_t amount, uint64_t global_index) const
get the public key for an output
Definition: blockchain.cpp:2274
void output_scan_worker(const uint64_t amount, const std::vector< uint64_t > &offsets, std::vector< output_data_t > &outputs) const
get a number of outputs of a specific amount
Definition: blockchain.cpp:4878
bool have_tx(const crypto::hash &id) const
search the blockchain for a transaction by hash
Definition: blockchain.cpp:116
uint64_t get_difficulty_target() const
get difficulty target based on chain and hardfork version
Definition: blockchain.cpp:5523
bool is_tx_spendtime_unlocked(uint64_t unlock_time, uint8_t hf_version) const
checks if a transaction is unlocked (its outputs spendable)
Definition: blockchain.cpp:3844
std::mutex m_txpool_notifier_mutex
Definition: blockchain.h:1246
crypto::hash m_btc_seed_hash
Definition: blockchain.h:1238
void get_dynamic_base_fee_estimate_2021_scaling(uint64_t grace_blocks, uint64_t base_reward, uint64_t Mnw, uint64_t Mlw, std::vector< uint64_t > &fees) const
Definition: blockchain.cpp:3720
void send_miner_notifications(uint64_t height, const crypto::hash &seed_hash, const crypto::hash &prev_id, uint64_t already_generated_coins)
sends new block notifications to ZMQ miner_data subscribers
Definition: blockchain.cpp:5753
void cache_block_template(const block &b, const cryptonote::account_public_address &address, const blobdata &nonce, const difficulty_type &diff, uint64_t height, uint64_t expected_reward, uint64_t seed_height, const crypto::hash &seed_hash, uint64_t pool_cookie)
stores a new cached block template
Definition: blockchain.cpp:5738
bool update_blockchain_pruning()
Definition: blockchain.cpp:4546
const char * key
Definition: hmac_keccak.cpp:40
bool has_block_weights(uint64_t height, uint64_t nblocks) const
checks whether we have known weights for the given block heights
Definition: blockchain.cpp:5014
bool m_db_sync_on_blocks
Definition: blockchain.h:1191
bool get_outs(const COMMAND_RPC_GET_OUTPUTS_BIN::request &req, COMMAND_RPC_GET_OUTPUTS_BIN::response &res) const
gets specific outputs to mix with
Definition: blockchain.cpp:2281
void invalidate_block_template_cache()
invalidates any cached block template
Definition: blockchain.cpp:5732
handle syncing calls instead of the backing db, synchronously
Definition: blockchain.h:81
std::function< const epee::span< const unsigned char >cryptonote::network_type network)> GetCheckpointsCallback
Callback routine that returns checkpoints data for specific network type.
Definition: blockchain.h:93
Definition: minixmlvalid.c:15
virtual uint32_t get_blockchain_pruning_seed() const =0
get the blockchain pruning seed
Definition: hardfork.h:39
std::map< uint64_t, std::tuple< uint64_t, uint64_t, uint64_t > > get_output_histogram(const std::vector< uint64_t > &amounts, bool unlocked, uint64_t recent_cutoff, uint64_t min_count=0) const
return a histogram of outputs on the blockchain
Definition: blockchain.cpp:5528
uint8_t get_next_hard_fork_version() const
returns the next hardfork version
Definition: blockchain.h:915
uint64_t m_btc_expected_reward
Definition: blockchain.h:1237
bool check_blockchain_pruning()
Definition: blockchain.cpp:4555
uint64_t get_earliest_ideal_height_for_version(uint8_t version) const
returns the earliest block a given version may activate
Definition: hardfork.cpp:383
Non-owning sequence of data. Does not deep copy.
Definition: span.h:54
std::tuple< uint64_t, uint64_t, std::vector< tools::wallet2::transfer_details > > outputs
Definition: cold-outputs.cpp:53
uint64_t get_num_mature_outputs(uint64_t amount) const
get number of outputs of an amount past the minimum spendable age
Definition: blockchain.cpp:2256
Definition: blocks.cpp:12
bool add_new_block(const block &bl_, block_verification_context &bvc)
adds a block to the blockchain
Definition: blockchain.cpp:4655
bool prune_blockchain(uint32_t pruning_seed=0)
Definition: blockchain.cpp:4537
Definition: verification_context.h:65
tools::wallet2::message_signature_result_t result
Definition: signature.cpp:62
unsigned char uint8_t
Definition: stdint.h:124
container for passing a block and metadata about it on the blockchain
Definition: blockchain.h:108
difficulty_type m_fixed_difficulty
Definition: blockchain.h:1226
bool m_show_time_stats
Definition: blockchain.h:1189
bool get_output_distribution(uint64_t amount, uint64_t from_height, uint64_t to_height, uint64_t &start_height, std::vector< uint64_t > &distribution, uint64_t &base) const
gets per block distribution of outputs of a given amount
Definition: blockchain.cpp:2336
std::vector< std::pair< crypto::hash, crypto::hash > > m_blocks_hash_of_hashes
Definition: blockchain.h:1184
bool get_short_chain_history(std::list< crypto::hash > &ids) const
gets the hashes for a subset of the blockchain
Definition: blockchain.cpp:731
struct hash_func hashes[]
uint64_t height
the height of the block in the blockchain
Definition: blockchain.h:111
void set_reorg_notify(const std::shared_ptr< tools::Notify > &notify)
sets a reorg notify object to call for every reorg
Definition: blockchain.h:870
void check_against_checkpoints(const checkpoints &points, bool enforce)
check the blockchain against a set of checkpoints
Definition: blockchain.cpp:4703
bool get_block_by_hash(const crypto::hash &h, block &blk, bool *orphan=NULL) const
gets the block with a given hash
Definition: blockchain.cpp:807
std::unordered_map< crypto::hash, crypto::hash > m_blocks_longhash_table
Definition: blockchain.h:1181
static uint64_t get_fee_quantization_mask()
get fee quantization mask
Definition: blockchain.h:650
std::shared_ptr< tools::Notify > m_reorg_notify
Definition: blockchain.h:1254
difficulty_type cumulative_difficulty
the accumulated difficulty after that block
Definition: blockchain.h:113
boost::string_ref blobdata_ref
Definition: blobdatatype.h:40
std::vector< difficulty_type > m_difficulties
Definition: blockchain.h:1199
bool update_checkpoints(const std::string &file_path, bool check_dns)
loads new checkpoints from a file and optionally from DNS
Definition: blockchain.cpp:4741
std::unordered_map< crypto::hash, block_extended_info > blocks_ext_by_hash
Definition: blockchain.h:1166
void remove_txpool_tx(const crypto::hash &txid)
Definition: blockchain.cpp:5412
void lock()
Definition: blockchain.cpp:5697
block m_btc
Definition: blockchain.h:1231
HardFork::State get_hard_fork_state() const
gets the hardfork voting state object
Definition: blockchain.cpp:5513
Holds cryptonote related classes and helpers.
Definition: blockchain_db.cpp:44
uint64_t m_sync_counter
Definition: blockchain.h:1196
Definition: verification_context.h:40
uint8_t get_next_version() const
returns the next version
Definition: hardfork.cpp:396
uint8_t get_hard_fork_version(uint64_t height) const
returns the actual hardfork version for a given block height
Definition: blockchain.h:934
bool m_batch_success
Definition: blockchain.h:1243
void update_txpool_tx(const crypto::hash &txid, const txpool_tx_meta_t &meta)
Definition: blockchain.cpp:5407
void get_last_n_blocks_weights(std::vector< uint64_t > &weights, size_t count) const
gets recent block weights for median calculation
Definition: blockchain.cpp:1393
uint64_t m_bytes_to_sync
Definition: blockchain.h:1197
size_t get_alternative_blocks_count() const
returns the number of alternative blocks stored
Definition: blockchain.cpp:2247
bool get_txpool_tx_blob(const crypto::hash &txid, cryptonote::blobdata &bd, relay_category tx_category) const
Definition: blockchain.cpp:5427
bool get_txpool_tx_meta(const crypto::hash &txid, txpool_tx_meta_t &meta) const
Definition: blockchain.cpp:5422
Definition: syncobj.h:81
#define PER_KB_FEE_QUANTIZATION_DECIMALS
Definition: cryptonote_config.h:196
std::atomic< bool > m_cancel
Definition: blockchain.h:1228
std::vector< MinerNotifyCallback > m_miner_notifiers
Definition: blockchain.h:1253
virtual uint64_t height() const =0
fetch the current blockchain height
bool get_hard_fork_voting_info(uint8_t version, uint32_t &window, uint32_t &votes, uint32_t &threshold, uint64_t &earliest_height, uint8_t &voting) const
get information about hardfork voting for a version
Definition: blockchain.cpp:5518
const std::vector< hardfork_t > & get_hardforks() const
returns info for all known hard forks
Definition: blockchain.h:948
GenericValue< UTF8<> > Value
GenericValue with UTF8 encoding.
Definition: document.h:2116
unsigned int uint32_t
Definition: stdint.h:126
bool get_miner_data(uint8_t &major_version, uint64_t &height, crypto::hash &prev_id, crypto::hash &seed_hash, difficulty_type &difficulty, uint64_t &median_weight, uint64_t &already_generated_coins, std::vector< tx_block_template_backlog_entry > &tx_backlog)
gets data required to create a block template and start mining on it
Definition: blockchain.cpp:1753
uint64_t get_next_long_term_block_weight(uint64_t block_weight) const
gets the long term block weight for a new block
Definition: blockchain.cpp:4565
Various Tools.
Definition: apply_permutation.h:39
uint64_t get_current_blockchain_height() const
get the current height of the blockchain
Definition: blockchain.cpp:271
bool build_alt_chain(const crypto::hash &prev_id, std::list< block_extended_info > &alt_chain, std::vector< uint64_t > &timestamps, block_verification_context &bvc) const
builds a list of blocks connecting a block to the main chain
Definition: blockchain.cpp:1799
HardFork * m_hardfork
Definition: blockchain.h:1222
bool m_btc_valid
Definition: blockchain.h:1240
bool deinit()
Uninitializes the blockchain state.
Definition: blockchain.cpp:514
difficulty_type get_difficulty_for_next_block()
returns the difficulty target the next block to be added must meet
Definition: blockchain.cpp:855
bool txpool_tx_matches_category(const crypto::hash &tx_hash, relay_category category)
Definition: blockchain.cpp:5442
uint64_t m_long_term_block_weights_window
Definition: blockchain.h:1202
std::vector< std::pair< block_extended_info, std::vector< crypto::hash > > > get_alternative_chains() const
returns a set of known alternate chains
Definition: blockchain.cpp:5533
uint8_t get_ideal_hard_fork_version() const
returns the newest hardfork version known to the blockchain
Definition: blockchain.h:908
blockchain_db_sync_mode
Definition: blockchain.h:78
void notify_txpool_event(std::vector< txpool_event > &&event) const
Notify this Blockchain&#39;s txpool notifier about a txpool event.
Definition: blockchain.cpp:5485
Definition: rctTypes.h:79
void cancel()
Definition: blockchain.cpp:5590
unsigned __int64 uint64_t
Definition: stdint.h:136
void pop_blocks(uint64_t nblocks)
removes blocks from the top of the blockchain
Definition: blockchain.cpp:554
Definition: cryptonote_basic.h:138
Definition: rctTypes.h:613
bool complete_timestamps_vector(uint64_t start_height, std::vector< uint64_t > &timestamps) const
finish an alternate chain&#39;s timestamp window from the main chain
Definition: blockchain.cpp:1779
Leave syncing up to the backing db (safest, but slowest because of disk I/O)
Definition: blockchain.h:83
void add_block_notify(BlockNotifyCallback &&notify)
sets a block notify object to call for every new block
Definition: blockchain.cpp:5467
bool init(BlockchainDB *db, const network_type nettype=MAINNET, bool offline=false, const cryptonote::test_options *test_options=NULL, difficulty_type fixed_difficulty=0, const GetCheckpointsCallback &get_checkpoints=nullptr)
Initialize the Blockchain state.
Definition: blockchain.cpp:283
bool handle_get_objects(NOTIFY_REQUEST_GET_OBJECTS::request &arg, NOTIFY_RESPONSE_GET_OBJECTS::request &rsp)
retrieves a set of blocks and their transactions, and possibly other transactions ...
Definition: blockchain.cpp:2176
void block_longhash_worker(uint64_t height, const epee::span< const block > &blocks, std::unordered_map< crypto::hash, crypto::hash > &map) const
computes the "short" and "long" hashes for a set of blocks
Definition: blockchain.cpp:4782
void prepare_handle_incoming_block_no_preprocess(const size_t block_byte_estimate)
prepare the blockchain for handling an incoming block, without performing preprocessing ...
Definition: blockchain.cpp:5381
bool m_enforce_dns_checkpoints
Definition: blockchain.h:1220
bool rollback_blockchain_switching(std::list< block > &original_chain, uint64_t rollback_height)
reverts the blockchain to its previous state following a failed switch
Definition: blockchain.cpp:1055
boost::function< void(uint64_t, epee::span< const block >)> BlockNotifyCallback
Definition: blockchain.h:96
void set_enforce_dns_checkpoints(bool enforce)
configure whether or not to enforce DNS-based checkpoints
Definition: blockchain.cpp:4776
void set_txpool_notify(TxpoolNotifyCallback &&notify)
sets a txpool notify object to call for every new tx used to add a new block
Definition: blockchain.cpp:5461
bool update_next_cumulative_weight_limit(uint64_t *long_term_effective_median_block_weight=NULL)
calculate the block weight limit for the next block to be added
Definition: blockchain.cpp:4596
boost::function< void(uint8_t, uint64_t, const crypto::hash &, const crypto::hash &, difficulty_type, uint64_t, uint64_t, const std::vector< tx_block_template_backlog_entry > &)> MinerNotifyCallback
Definition: blockchain.h:97
Definition: misc_language.h:103
POD_CLASS public_key
Definition: crypto.h:61
version
Supported socks variants.
Definition: socks.h:57
bool for_all_txpool_txes(std::function< bool(const crypto::hash &, const txpool_tx_meta_t &, const cryptonote::blobdata_ref *)>, bool include_blob=false, relay_category tx_category=relay_category::broadcasted) const
Definition: blockchain.cpp:5437
uint8_t get_ideal_hard_fork_version(uint64_t height) const
returns the newest hardfork version voted to be enabled as of a certain height
Definition: blockchain.h:925
bool for_all_outputs(std::function< bool(uint64_t amount, const crypto::hash &tx_hash, uint64_t height, size_t tx_idx)>) const
perform a check on all outputs in the blockchain
Definition: blockchain.cpp:5722
Definition: cryptonote_core.h:61
size_t recalculate_difficulties(boost::optional< uint64_t > start_height=boost::none)
recalculate difficulties for blocks after the last difficulty checkpoints to circumvent the annoying ...
Definition: blockchain.cpp:949
BlockchainDB * m_db
Definition: blockchain.h:1169
bool check_block_timestamp(const block &b) const
Definition: blockchain.h:1546
diff
Definition: gen_wide_data.py:42
bool switch_to_alternative_blockchain(std::list< block_extended_info > &alt_chain, bool discard_disconnected_chain)
performs a blockchain reorganization according to the longest chain rule
Definition: blockchain.cpp:1099
TxpoolNotifyCallback m_txpool_notifier
Definition: blockchain.h:1245
bool reset_and_set_genesis_block(const block &b)
clears the blockchain and starts a new one
Definition: blockchain.cpp:683
Transaction pool, handles transactions which are not part of a block.
Definition: tx_pool.h:98
std::string blobdata
Definition: blobdatatype.h:39
boost::function< void(std::vector< txpool_event >)> TxpoolNotifyCallback
Definition: blockchain.h:95
bool store_blockchain()
stores the blockchain
Definition: blockchain.cpp:484
Definition: base.py:1
Definition: block_weight.py:1
uint64_t block_cumulative_weight
the weight of the block
Definition: blockchain.h:112
Blockchain(tx_memory_pool &tx_pool)
Blockchain constructor.
Definition: blockchain.cpp:93
tx_memory_pool & m_tx_pool
Definition: blockchain.h:1171
bool get_transactions_blobs(const std::vector< crypto::hash > &txs_ids, std::vector< cryptonote::blobdata > &txs, std::vector< crypto::hash > &missed_txs, bool pruned=false) const
gets transactions based on a list of transaction hashes
Definition: blockchain.cpp:2544
crypto::hash get_block_id_by_height(uint64_t height) const
gets a block&#39;s hash given a height
Definition: blockchain.cpp:773
network_type
Definition: cryptonote_config.h:301
bool handle_block_to_main_chain(const block &bl, block_verification_context &bvc)
validate and add a new block to the end of the blockchain
Definition: blockchain.cpp:2828
uint32_t address
Definition: getifaddr.c:269
blobdata m_btc_nonce
Definition: blockchain.h:1233
~Blockchain()
Blockchain destructor.
Definition: blockchain.cpp:110
Definition: cryptonote_basic.h:511
bool check_tx_input(size_t tx_version, const txin_to_key &txin, const crypto::hash &tx_prefix_hash, const std::vector< crypto::signature > &sig, const rct::rctSig &rct_signatures, std::vector< rct::ctkey > &output_keys, uint64_t *pmax_related_block_height, uint8_t hf_version) const
collect output public keys of a transaction input set
Definition: blockchain.cpp:3871
uint32_t get_blockchain_pruning_seed() const
Definition: blockchain.h:1100
boost::thread_group m_async_pool
Definition: blockchain.h:1212
void set_show_time_stats(bool stats)
set whether or not to show/print time statistics
Definition: blockchain.h:887
blockchain_db_sync_mode m_db_sync_mode
Definition: blockchain.h:1187
size_t m_current_block_cumul_weight_median
Definition: blockchain.h:1177
epee::critical_section m_blockchain_lock
Definition: blockchain.h:1173
boost::multiprecision::uint128_t difficulty_type
Definition: difficulty.h:41
bool check_block_timestamp(const block &b, uint64_t &median_ts) const
checks a block&#39;s timestamp
Definition: blockchain.cpp:3987
crypto::hash m_long_term_block_weights_cache_tip_hash
Definition: blockchain.h:1204
uint64_t already_generated_coins
the total coins minted after that block
Definition: blockchain.h:114
POD_CLASS key_image
Definition: crypto.h:92
const BlockchainDB & get_db() const
get a reference to the BlockchainDB in use by Blockchain
Definition: blockchain.h:1046
a struct containing txpool per transaction metadata
Definition: blockchain_db.h:154
void safesyncmode(const bool onoff)
Put DB in safe sync mode.
Definition: blockchain.cpp:5501
Used to provide transaction info that skips the mempool to block handling code.
Definition: tx_verification_utils.h:100
network_type m_nettype
Definition: blockchain.h:1224
bool for_all_transactions(std::function< bool(const crypto::hash &, const cryptonote::transaction &)>, bool pruned) const
perform a check on all transactions in the blockchain
Definition: blockchain.cpp:5717
std::vector< BlockNotifyCallback > m_block_notifiers
Definition: blockchain.h:1252
uint64_t get_long_term_block_weight_median(uint64_t start_height, size_t count) const
gets block long term weight median
Definition: blockchain.cpp:1408
bool is_within_compiled_block_hash_area() const
Definition: blockchain.h:1098
uint8_t get_current_hard_fork_version() const
gets the current hardfork version in use/voted for
Definition: blockchain.h:901
size_t m_current_block_cumul_weight_limit
Definition: blockchain.h:1176
bool get_tx_outputs_gindexs(const crypto::hash &tx_id, std::vector< uint64_t > &indexs) const
gets the global indices for outputs from a given transaction
Definition: blockchain.cpp:2928
std::vector< block_extended_info > blocks_container
Definition: blockchain.h:1164
void add_miner_notify(MinerNotifyCallback &&notify)
sets a miner notify object to call for every new block
Definition: blockchain.cpp:5476
size_t get_total_transactions() const
gets the total number of transactions on the main chain
Definition: blockchain.cpp:2836
cryptonote::transaction tx
Definition: transaction.cpp:40
uint64_t m_btc_seed_height
Definition: blockchain.h:1239
The BlockchainDB backing store interface declaration/contract.
Definition: blockchain_db.h:378
bool get_split_transactions_blobs(const t_ids_container &txs_ids, t_tx_container &txs, t_missed_container &missed_txs) const
Definition: blockchain.cpp:2604
bool for_blocks_range(const uint64_t &h1, const uint64_t &h2, std::function< bool(uint64_t, const crypto::hash &, const block &)>) const
perform a check on all blocks in the blockchain in the given range
Definition: blockchain.cpp:5712
bool get_transactions(const t_ids_container &txs_ids, t_tx_container &txs, t_missed_container &missed_txs, bool pruned=false) const
Definition: blockchain.cpp:2638
void get_output_key_mask_unlocked(const uint64_t &amount, const uint64_t &index, crypto::public_key &key, rct::key &mask, bool &unlocked) const
gets an output&#39;s key and unlocked state
Definition: blockchain.cpp:2326
void add_txpool_tx(const crypto::hash &txid, const cryptonote::blobdata &blob, const txpool_tx_meta_t &meta)
Definition: blockchain.cpp:5402
Received via RPC with do_not_relay set.
static boost::multiprecision::uint128_t fees
Definition: blockchain_stats.cpp:58
crypto::hash get_tail_id() const
get the hash of the most recent block on the blockchain
Definition: blockchain.cpp:709
bool get_blocks(uint64_t start_offset, size_t count, std::vector< std::pair< cryptonote::blobdata, block >> &blocks, std::vector< cryptonote::blobdata > &txs) const
get blocks and transactions from blocks based on start height and count
Definition: blockchain.cpp:2126
void load_compiled_in_block_hashes(const GetCheckpointsCallback &get_checkpoints)
loads block hashes from compiled-in data set
uint64_t prevalidate_block_hashes(uint64_t height, const std::vector< crypto::hash > &hashes, const std::vector< uint64_t > &weights)
Definition: blockchain.cpp:4894
POD_CLASS hash
Definition: hash.h:49
std::vector< time_t > get_last_block_timestamps(unsigned int blocks) const
returns the timestamps of the last N blocks
Definition: blockchain.cpp:1040
difficulty_type m_btc_difficulty
Definition: blockchain.h:1234
A container for blockchain checkpoints.
Definition: checkpoints.h:52
uint64_t get_current_cumulative_block_weight_median() const
gets the block weight median based on recent blocks (same window as for the limit) ...
Definition: blockchain.cpp:1462
State
Definition: hardfork.h:42
crypto::hash get_pending_block_id_by_height(uint64_t height) const
gets a block&#39;s hash given a height
Definition: blockchain.cpp:800
bool cleanup_handle_incoming_blocks(bool force_sync=false)
incoming blocks post-processing, cleanup, and disk sync
Definition: blockchain.cpp:4801
bool have_tx_keyimges_as_spent(const transaction &tx) const
check if any key image in a transaction has already been spent
Definition: blockchain.cpp:3134
uint64_t m_prepare_nblocks
Definition: blockchain.h:1258
void flush_invalid_blocks()
flush the invalid blocks set
Definition: blockchain.cpp:2783
major_version
Definition: versiongenerate.py:78
bool scan_outputkeys_for_indexes(size_t tx_version, const txin_to_key &tx_in_to_key, visitor_t &vis, const crypto::hash &tx_prefix_hash, uint64_t *pmax_related_block_height=NULL) const
collects the keys for all outputs being "spent" as an input
Definition: blockchain.cpp:140
bool flush_txes_from_pool(const std::vector< crypto::hash > &txids)
remove transactions from the transaction pool (if present)
Definition: blockchain.cpp:4017
relay_category
Definition: blockchain_db.h:109
void unlock()
Definition: blockchain.cpp:5702
uint64_t m_long_term_effective_median_block_weight
Definition: blockchain.h:1203
Definition: powerof.h:8
epee::critical_section m_difficulty_lock
Definition: blockchain.h:1207
uint8_t get_current_version() const
returns the current version
Definition: hardfork.cpp:360
bool have_block_unlocked(const crypto::hash &id, int *where=NULL) const
checks if a block is known about with a given hash
Definition: blockchain.cpp:2790
bool have_block(const crypto::hash &id, int *where=NULL) const
Definition: blockchain.cpp:2822
account_public_address m_btc_address
Definition: blockchain.h:1232
bool check_tx_inputs(transaction &tx, uint64_t &pmax_used_block_height, crypto::hash &max_used_block_id, tx_verification_context &tvc, bool kept_by_block=false) const
validates a transaction&#39;s inputs
Definition: blockchain.cpp:2952
boost::asio::io_context m_async_service
Definition: blockchain.h:1211
static uint64_t h
Definition: blockchain_stats.cpp:55
Definition: cryptonote_basic.h:204
Public txes received via block/fluff.
uint8_t get_ideal_version() const
returns the latest "ideal" version
Definition: hardfork.cpp:366
uint64_t m_timestamps_and_difficulties_height
Definition: blockchain.h:1200
void check_ring_signature(const crypto::hash &tx_prefix_hash, const crypto::key_image &key_image, const std::vector< rct::ctkey > &pubkeys, const std::vector< crypto::signature > &sig, uint64_t &result) const
validates a transaction input&#39;s ring signature
Definition: blockchain.cpp:3606
bool for_all_key_images(std::function< bool(const crypto::key_image &)>) const
perform a check on all key images in the blockchain
Definition: blockchain.cpp:5707
bool prevalidate_miner_transaction(const block &b, uint64_t height, uint8_t hf_version)
sanity checks a miner transaction before validating an entire block
Definition: blockchain.cpp:1297
cryptonote::block b
Definition: block.cpp:40
bool find_blockchain_supplement(const std::list< crypto::hash > &qblock_ids, std::vector< crypto::hash > &hashes, std::vector< uint64_t > *weights, uint64_t &start_height, uint64_t &current_height, bool clip_pruned) const
get recent block hashes for a foreign chain
Definition: blockchain.cpp:2674
uint64_t get_adjusted_time(uint64_t height) const
get the "adjusted time"
Definition: blockchain.cpp:3932
void set_checkpoints(checkpoints &&chk_pts)
assign a set of blockchain checkpoint hashes
Definition: blockchain.h:176
const std::vector< hardfork_t > & get_hardforks() const
returns info for all known hard forks
Definition: hardfork.h:237
uint8_t get(uint64_t height) const
returns the hard fork version for the given block height
Definition: hardfork.cpp:347
bool check_fee(size_t tx_weight, uint64_t fee) const
validate a transaction&#39;s fee
Definition: blockchain.cpp:3666
bool get_alternative_blocks(std::vector< block > &blocks) const
compiles a list of all blocks stored as alternative chains
Definition: blockchain.cpp:2225
Definition: blockchain.h:102
weights
Definition: block_weight.py:18
uint64_t m_btc_pool_cookie
Definition: blockchain.h:1236