Monero
blockchain_db.h
Go to the documentation of this file.
1 // Copyright (c) 2014-2018, 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 #ifndef BLOCKCHAIN_DB_H
29 #define BLOCKCHAIN_DB_H
30 
31 #pragma once
32 
33 #include <list>
34 #include <string>
35 #include <exception>
36 #include <boost/program_options.hpp>
37 #include "common/command_line.h"
38 #include "crypto/hash.h"
43 
100 namespace cryptonote
101 {
102 
104 typedef std::pair<crypto::hash, uint64_t> tx_out_index;
105 
109 
110 #pragma pack(push, 1)
111 
116 {
118  uint64_t unlock_time;
119  uint64_t height;
121 };
122 #pragma pack(pop)
123 
124 #pragma pack(push, 1)
125 struct tx_data_t
126 {
127  uint64_t tx_id;
128  uint64_t unlock_time;
129  uint64_t block_id;
130 };
131 #pragma pack(pop)
132 
137 {
140  uint64_t weight;
141  uint64_t fee;
144  uint64_t receive_time;
146  // 112 bytes
147  uint8_t kept_by_block;
148  uint8_t relayed;
149  uint8_t do_not_relay;
150  uint8_t double_spend_seen: 1;
151  uint8_t bf_padding: 7;
152 
153  uint8_t padding[76]; // till 192 bytes
154 };
155 
156 #define DBF_SAFE 1
157 #define DBF_FAST 2
158 #define DBF_FASTEST 4
159 #define DBF_RDONLY 8
160 #define DBF_SALVAGE 0x10
161 
162 /***********************************
163  * Exception Definitions
164  ***********************************/
165 
169 class DB_EXCEPTION : public std::exception
170 {
171  private:
172  std::string m;
173 
174  protected:
175  DB_EXCEPTION(const char *s) : m(s) { }
176 
177  public:
178  virtual ~DB_EXCEPTION() { }
179 
180  const char* what() const throw()
181  {
182  return m.c_str();
183  }
184 };
185 
189 class DB_ERROR : public DB_EXCEPTION
190 {
191  public:
192  DB_ERROR() : DB_EXCEPTION("Generic DB Error") { }
193  DB_ERROR(const char* s) : DB_EXCEPTION(s) { }
194 };
195 
200 {
201  public:
202  DB_ERROR_TXN_START() : DB_EXCEPTION("DB Error in starting txn") { }
203  DB_ERROR_TXN_START(const char* s) : DB_EXCEPTION(s) { }
204 };
205 
210 {
211  public:
212  DB_OPEN_FAILURE() : DB_EXCEPTION("Failed to open the db") { }
213  DB_OPEN_FAILURE(const char* s) : DB_EXCEPTION(s) { }
214 };
215 
220 {
221  public:
222  DB_CREATE_FAILURE() : DB_EXCEPTION("Failed to create the db") { }
223  DB_CREATE_FAILURE(const char* s) : DB_EXCEPTION(s) { }
224 };
225 
230 {
231  public:
232  DB_SYNC_FAILURE() : DB_EXCEPTION("Failed to sync the db") { }
233  DB_SYNC_FAILURE(const char* s) : DB_EXCEPTION(s) { }
234 };
235 
239 class BLOCK_DNE : public DB_EXCEPTION
240 {
241  public:
242  BLOCK_DNE() : DB_EXCEPTION("The block requested does not exist") { }
243  BLOCK_DNE(const char* s) : DB_EXCEPTION(s) { }
244 };
245 
250 {
251  public:
252  BLOCK_PARENT_DNE() : DB_EXCEPTION("The parent of the block does not exist") { }
253  BLOCK_PARENT_DNE(const char* s) : DB_EXCEPTION(s) { }
254 };
255 
260 {
261  public:
262  BLOCK_EXISTS() : DB_EXCEPTION("The block to be added already exists!") { }
263  BLOCK_EXISTS(const char* s) : DB_EXCEPTION(s) { }
264 };
265 
270 {
271  public:
272  BLOCK_INVALID() : DB_EXCEPTION("The block to be added did not pass validation!") { }
273  BLOCK_INVALID(const char* s) : DB_EXCEPTION(s) { }
274 };
275 
279 class TX_DNE : public DB_EXCEPTION
280 {
281  public:
282  TX_DNE() : DB_EXCEPTION("The transaction requested does not exist") { }
283  TX_DNE(const char* s) : DB_EXCEPTION(s) { }
284 };
285 
289 class TX_EXISTS : public DB_EXCEPTION
290 {
291  public:
292  TX_EXISTS() : DB_EXCEPTION("The transaction to be added already exists!") { }
293  TX_EXISTS(const char* s) : DB_EXCEPTION(s) { }
294 };
295 
299 class OUTPUT_DNE : public DB_EXCEPTION
300 {
301  public:
302  OUTPUT_DNE() : DB_EXCEPTION("The output requested does not exist!") { }
303  OUTPUT_DNE(const char* s) : DB_EXCEPTION(s) { }
304 };
305 
310 {
311  public:
312  OUTPUT_EXISTS() : DB_EXCEPTION("The output to be added already exists!") { }
313  OUTPUT_EXISTS(const char* s) : DB_EXCEPTION(s) { }
314 };
315 
320 {
321  public:
322  KEY_IMAGE_EXISTS() : DB_EXCEPTION("The spent key image to be added already exists!") { }
323  KEY_IMAGE_EXISTS(const char* s) : DB_EXCEPTION(s) { }
324 };
325 
326 /***********************************
327  * End of Exception Definitions
328  ***********************************/
329 
330 
344 {
345 private:
346  /*********************************************************************
347  * private virtual members
348  *********************************************************************/
349 
366  virtual void add_block( const block& blk
367  , size_t block_weight
368  , const difficulty_type& cumulative_difficulty
369  , const uint64_t& coins_generated
370  , uint64_t num_rct_outs
371  , const crypto::hash& blk_hash
372  ) = 0;
373 
384  virtual void remove_block() = 0;
385 
406  virtual uint64_t add_transaction_data(const crypto::hash& blk_hash, const transaction& tx, const crypto::hash& tx_hash, const crypto::hash& tx_prunable_hash) = 0;
407 
424  virtual void remove_transaction_data(const crypto::hash& tx_hash, const transaction& tx) = 0;
425 
452  virtual uint64_t add_output(const crypto::hash& tx_hash, const tx_out& tx_output, const uint64_t& local_index, const uint64_t unlock_time, const rct::key *commitment) = 0;
453 
467  virtual void add_tx_amount_output_indices(const uint64_t tx_id, const std::vector<uint64_t>& amount_output_indices) = 0;
468 
479  virtual void add_spent_key(const crypto::key_image& k_image) = 0;
480 
491  virtual void remove_spent_key(const crypto::key_image& k_image) = 0;
492 
493 
494  /*********************************************************************
495  * private concrete members
496  *********************************************************************/
503  void pop_block();
504 
505  // helper function to remove transaction from blockchain
513  void remove_transaction(const crypto::hash& tx_hash);
514 
515  uint64_t num_calls = 0;
516  uint64_t time_blk_hash = 0;
517  uint64_t time_add_block1 = 0;
518  uint64_t time_add_transaction = 0;
519 
520 
521 protected:
522 
534  void add_transaction(const crypto::hash& blk_hash, const transaction& tx, const crypto::hash* tx_hash_ptr = NULL, const crypto::hash* tx_prunable_hash_ptr = NULL);
535 
536  mutable uint64_t time_tx_exists = 0;
537  uint64_t time_commit1 = 0;
538  bool m_auto_remove_logs = true;
539 
541 
542 public:
543 
548 
552  virtual ~BlockchainDB() { };
553 
557  static void init_options(boost::program_options::options_description& desc);
558 
562  void reset_stats();
563 
570  void show_stats();
571 
595  virtual void open(const std::string& filename, const int db_flags = 0) = 0;
596 
602  bool is_open() const;
603 
614  virtual void close() = 0;
615 
627  virtual void sync() = 0;
628 
634  virtual void safesyncmode(const bool onoff) = 0;
635 
646  virtual void reset() = 0;
647 
657  virtual std::vector<std::string> get_filenames() const = 0;
658 
671  virtual bool remove_data_file(const std::string& folder) const = 0;
672 
673  // return the name of the folder the db's file(s) should reside in
682  virtual std::string get_db_name() const = 0;
683 
684 
685  // FIXME: these are just for functionality mocking, need to implement
686  // RAII-friendly and multi-read one-write friendly locking mechanism
687  //
688  // acquire db lock
704  virtual bool lock() = 0;
705 
706  // release db lock
717  virtual void unlock() = 0;
718 
738  virtual bool batch_start(uint64_t batch_num_blocks=0, uint64_t batch_bytes=0) = 0;
739 
753  virtual void batch_stop() = 0;
754 
770  virtual void set_batch_transactions(bool) = 0;
771 
772  virtual void block_txn_start(bool readonly=false) = 0;
773  virtual void block_txn_stop() = 0;
774  virtual void block_txn_abort() = 0;
775 
776  virtual void set_hard_fork(HardFork* hf);
777 
778  // adds a block with the given metadata to the top of the blockchain, returns the new height
799  virtual uint64_t add_block( const block& blk
800  , size_t block_weight
801  , const difficulty_type& cumulative_difficulty
802  , const uint64_t& coins_generated
803  , const std::vector<transaction>& txs
804  );
805 
814  virtual bool block_exists(const crypto::hash& h, uint64_t *height = NULL) const = 0;
815 
827  virtual cryptonote::blobdata get_block_blob(const crypto::hash& h) const = 0;
828 
840  virtual block get_block(const crypto::hash& h) const;
841 
853  virtual uint64_t get_block_height(const crypto::hash& h) const = 0;
854 
867  virtual block_header get_block_header(const crypto::hash& h) const = 0;
868 
881  virtual cryptonote::blobdata get_block_blob_from_height(const uint64_t& height) const = 0;
882 
893  virtual block get_block_from_height(const uint64_t& height) const;
894 
907  virtual uint64_t get_block_timestamp(const uint64_t& height) const = 0;
908 
921  virtual std::vector<uint64_t> get_block_cumulative_rct_outputs(const std::vector<uint64_t> &heights) const = 0;
922 
930  virtual uint64_t get_top_block_timestamp() const = 0;
931 
944  virtual size_t get_block_weight(const uint64_t& height) const = 0;
945 
958  virtual difficulty_type get_block_cumulative_difficulty(const uint64_t& height) const = 0;
959 
972  virtual difficulty_type get_block_difficulty(const uint64_t& height) const = 0;
973 
986  virtual uint64_t get_block_already_generated_coins(const uint64_t& height) const = 0;
987 
1000  virtual crypto::hash get_block_hash_from_height(const uint64_t& height) const = 0;
1001 
1017  virtual std::vector<block> get_blocks_range(const uint64_t& h1, const uint64_t& h2) const = 0;
1018 
1034  virtual std::vector<crypto::hash> get_hashes_range(const uint64_t& h1, const uint64_t& h2) const = 0;
1035 
1043  virtual crypto::hash top_block_hash() const = 0;
1044 
1052  virtual block get_top_block() const = 0;
1053 
1061  virtual uint64_t height() const = 0;
1062 
1063 
1084  virtual void pop_block(block& blk, std::vector<transaction>& txs);
1085 
1086 
1098  virtual bool tx_exists(const crypto::hash& h) const = 0;
1099  virtual bool tx_exists(const crypto::hash& h, uint64_t& tx_id) const = 0;
1100 
1101  // return unlock time of tx with hash <h>
1114  virtual uint64_t get_tx_unlock_time(const crypto::hash& h) const = 0;
1115 
1116  // return tx with hash <h>
1117  // throw if no such tx exists
1127  virtual transaction get_tx(const crypto::hash& h) const;
1128 
1138  virtual bool get_tx(const crypto::hash& h, transaction &tx) const;
1139 
1152  virtual bool get_tx_blob(const crypto::hash& h, cryptonote::blobdata &tx) const = 0;
1153 
1166  virtual bool get_pruned_tx_blob(const crypto::hash& h, cryptonote::blobdata &tx) const = 0;
1167 
1179  virtual bool get_prunable_tx_hash(const crypto::hash& tx_hash, crypto::hash &prunable_hash) const = 0;
1180 
1189  virtual uint64_t get_tx_count() const = 0;
1190 
1206  virtual std::vector<transaction> get_tx_list(const std::vector<crypto::hash>& hlist) const = 0;
1207 
1208  // returns height of block that contains transaction with hash <h>
1221  virtual uint64_t get_tx_block_height(const crypto::hash& h) const = 0;
1222 
1223  // returns the total number of outputs of amount <amount>
1237  virtual uint64_t get_num_outputs(const uint64_t& amount) const = 0;
1238 
1244  virtual uint64_t get_indexing_base() const { return 0; }
1245 
1262  virtual output_data_t get_output_key(const uint64_t& amount, const uint64_t& index) = 0;
1263 
1274  virtual tx_out_index get_output_tx_and_index_from_global(const uint64_t& index) const = 0;
1275 
1288  virtual tx_out_index get_output_tx_and_index(const uint64_t& amount, const uint64_t& index) const = 0;
1289 
1301  virtual void get_output_tx_and_index(const uint64_t& amount, const std::vector<uint64_t> &offsets, std::vector<tx_out_index> &indices) const = 0;
1302 
1314  virtual void get_output_key(const uint64_t &amount, const std::vector<uint64_t> &offsets, std::vector<output_data_t> &outputs, bool allow_partial = false) = 0;
1315 
1316  /*
1317  * FIXME: Need to check with git blame and ask what this does to
1318  * document it
1319  */
1320  virtual bool can_thread_bulk_indices() const = 0;
1321 
1336  virtual std::vector<uint64_t> get_tx_amount_output_indices(const uint64_t tx_id) const = 0;
1337 
1345  virtual bool has_key_image(const crypto::key_image& img) const = 0;
1346 
1352  virtual void add_txpool_tx(const transaction &tx, const txpool_tx_meta_t& details) = 0;
1353 
1360  virtual void update_txpool_tx(const crypto::hash &txid, const txpool_tx_meta_t& details) = 0;
1361 
1365  virtual uint64_t get_txpool_tx_count(bool include_unrelayed_txes = true) const = 0;
1366 
1370  virtual bool txpool_has_tx(const crypto::hash &txid) const = 0;
1371 
1377  virtual void remove_txpool_tx(const crypto::hash& txid) = 0;
1378 
1387  virtual bool get_txpool_tx_meta(const crypto::hash& txid, txpool_tx_meta_t &meta) const = 0;
1388 
1397  virtual bool get_txpool_tx_blob(const crypto::hash& txid, cryptonote::blobdata &bd) const = 0;
1398 
1406  virtual cryptonote::blobdata get_txpool_tx_blob(const crypto::hash& txid) const = 0;
1407 
1421  virtual bool for_all_txpool_txes(std::function<bool(const crypto::hash&, const txpool_tx_meta_t&, const cryptonote::blobdata*)>, bool include_blob = false, bool include_unrelayed_txes = true) const = 0;
1422 
1436  virtual bool for_all_key_images(std::function<bool(const crypto::key_image&)>) const = 0;
1437 
1456  virtual bool for_blocks_range(const uint64_t& h1, const uint64_t& h2, std::function<bool(uint64_t, const crypto::hash&, const cryptonote::block&)>) const = 0;
1457 
1475  virtual bool for_all_transactions(std::function<bool(const crypto::hash&, const cryptonote::transaction&)>, bool pruned) const = 0;
1476 
1494  virtual bool for_all_outputs(std::function<bool(uint64_t amount, const crypto::hash &tx_hash, uint64_t height, size_t tx_idx)> f) const = 0;
1495  virtual bool for_all_outputs(uint64_t amount, const std::function<bool(uint64_t height)> &f) const = 0;
1496 
1497 
1498 
1499  //
1500  // Hard fork related storage
1501  //
1502 
1509  virtual void set_hard_fork_version(uint64_t height, uint8_t version) = 0;
1510 
1518  virtual uint8_t get_hard_fork_version(uint64_t height) const = 0;
1519 
1523  virtual void check_hard_fork_info() = 0;
1524 
1528  virtual void drop_hard_fork_info() = 0;
1529 
1540  virtual 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) const = 0;
1541 
1542  virtual bool get_output_distribution(uint64_t amount, uint64_t from_height, uint64_t to_height, std::vector<uint64_t> &distribution, uint64_t &base) const = 0;
1543 
1549  virtual bool is_read_only() const = 0;
1550 
1556  virtual uint64_t get_database_size() const = 0;
1557 
1558  // TODO: this should perhaps be (or call) a series of functions which
1559  // progressively update through version updates
1563  virtual void fixup();
1564 
1573  void set_auto_remove_logs(bool auto_remove) { m_auto_remove_logs = auto_remove; }
1574 
1575  bool m_open;
1576  mutable epee::critical_section m_synchronization_lock;
1577 
1578 }; // class BlockchainDB
1579 
1580 BlockchainDB *new_db(const std::string& db_type);
1581 
1582 } // namespace cryptonote
1583 
1584 #endif // BLOCKCHAIN_DB_H
DB_SYNC_FAILURE(const char *s)
Definition: blockchain_db.h:233
thrown when creating the BlockchainDB fails
Definition: blockchain_db.h:219
uint64_t tx_id
Definition: blockchain_db.h:127
DB_CREATE_FAILURE(const char *s)
Definition: blockchain_db.h:223
virtual void reset()=0
Remove everything from the BlockchainDB.
virtual std::string get_db_name() const =0
gets the name of the folder the BlockchainDB&#39;s file(s) should be in
Definition: blockchain_db.h:125
void reset_stats()
reset profiling stats
Definition: blockchain_db.cpp:336
OUTPUT_EXISTS(const char *s)
Definition: blockchain_db.h:313
virtual uint64_t get_indexing_base() const
return index of the first element (should be hidden, but isn&#39;t)
Definition: blockchain_db.h:1244
const char * what() const
Definition: blockchain_db.h:180
virtual uint64_t add_output(const crypto::hash &tx_hash, const tx_out &tx_output, const uint64_t &local_index, const uint64_t unlock_time, const rct::key *commitment)=0
store an output
void pop_block()
private version of pop_block, for undoing if an add_block fails
Definition: blockchain_db.cpp:117
thrown when a transaction exists, but shouldn&#39;t, namely when adding a block
Definition: blockchain_db.h:289
virtual bool has_key_image(const crypto::key_image &img) const =0
check if a key image is stored as spent
virtual std::vector< uint64_t > get_tx_amount_output_indices(const uint64_t tx_id) const =0
gets output indices (amount-specific) for a transaction&#39;s outputs
uint8_t padding[76]
Definition: blockchain_db.h:153
thrown when opening the BlockchainDB fails
Definition: blockchain_db.h:209
virtual void drop_hard_fork_info()=0
delete hard fork info from database
DB_ERROR()
Definition: blockchain_db.h:192
thrown when a spent key image exists, but shouldn&#39;t, namely when adding a block
Definition: blockchain_db.h:319
virtual crypto::hash get_block_hash_from_height(const uint64_t &height) const =0
fetch a block&#39;s hash
crypto::hash max_used_block_id
Definition: blockchain_db.h:138
virtual bool get_output_distribution(uint64_t amount, uint64_t from_height, uint64_t to_height, std::vector< uint64_t > &distribution, uint64_t &base) const =0
DB_ERROR(const char *s)
Definition: blockchain_db.h:193
virtual uint64_t get_tx_count() const =0
fetches the total number of transactions ever
virtual uint64_t get_tx_block_height(const crypto::hash &h) const =0
fetches the height of a transaction&#39;s block
virtual uint64_t get_block_height(const crypto::hash &h) const =0
gets the height of the block with a given hash
Definition: cryptonote_basic.h:366
Definition: cryptonote_basic.h:349
virtual void add_tx_amount_output_indices(const uint64_t tx_id, const std::vector< uint64_t > &amount_output_indices)=0
store amount output indices for a tx&#39;s outputs
A base class for BlockchainDB exceptions.
Definition: blockchain_db.h:169
virtual std::vector< transaction > get_tx_list(const std::vector< crypto::hash > &hlist) const =0
fetches a list of transactions based on their hashes
virtual difficulty_type get_block_cumulative_difficulty(const uint64_t &height) const =0
fetch a block&#39;s cumulative difficulty
virtual void safesyncmode(const bool onoff)=0
toggle safe syncs for the DB
thrown when a requested block does not exist
Definition: blockchain_db.h:239
const command_line::arg_descriptor< std::string > arg_db_sync_mode
Definition: blockchain_db.cpp:88
uint8_t do_not_relay
Definition: blockchain_db.h:149
virtual void unlock()=0
This function releases the BlockchainDB lock.
Definition: hardfork.h:38
DB_ERROR_TXN_START(const char *s)
Definition: blockchain_db.h:203
BLOCK_EXISTS(const char *s)
Definition: blockchain_db.h:263
virtual void set_hard_fork_version(uint64_t height, uint8_t version)=0
sets which hardfork version a height is on
virtual void add_spent_key(const crypto::key_image &k_image)=0
store a spent key
thrown when an output exists, but shouldn&#39;t, namely when adding a block
Definition: blockchain_db.h:309
virtual void remove_transaction_data(const crypto::hash &tx_hash, const transaction &tx)=0
remove data about a transaction
BLOCK_DNE()
Definition: blockchain_db.h:242
virtual transaction get_tx(const crypto::hash &h) const
fetches the transaction with the given hash
Definition: blockchain_db.cpp:328
virtual std::vector< uint64_t > get_block_cumulative_rct_outputs(const std::vector< uint64_t > &heights) const =0
fetch a block&#39;s cumulative number of rct outputs
virtual bool batch_start(uint64_t batch_num_blocks=0, uint64_t batch_bytes=0)=0
tells the BlockchainDB to start a new "batch" of blocks
uint64_t block_id
Definition: blockchain_db.h:129
virtual void sync()=0
sync the BlockchainDB with disk
virtual void remove_spent_key(const crypto::key_image &k_image)=0
remove a spent key
BLOCK_PARENT_DNE()
Definition: blockchain_db.h:252
virtual bool for_all_transactions(std::function< bool(const crypto::hash &, const cryptonote::transaction &)>, bool pruned) const =0
runs a function over all transactions stored
A generic BlockchainDB exception.
Definition: blockchain_db.h:189
virtual bool get_txpool_tx_blob(const crypto::hash &txid, cryptonote::blobdata &bd) const =0
get a txpool transaction&#39;s blob
uint64_t receive_time
Definition: blockchain_db.h:144
virtual crypto::hash top_block_hash() const =0
fetch the top block&#39;s hash
virtual std::vector< crypto::hash > get_hashes_range(const uint64_t &h1, const uint64_t &h2) const =0
fetch a list of block hashes
uint64_t num_calls
a performance metric
Definition: blockchain_db.h:515
virtual uint64_t add_transaction_data(const crypto::hash &blk_hash, const transaction &tx, const crypto::hash &tx_hash, const crypto::hash &tx_prunable_hash)=0
store the transaction and its metadata
virtual void fixup()
fix up anything that may be wrong due to past bugs
Definition: blockchain_db.cpp:368
virtual bool lock()=0
acquires the BlockchainDB lock
KEY_IMAGE_EXISTS()
Definition: blockchain_db.h:322
TX_EXISTS()
Definition: blockchain_db.h:292
void add_transaction(const crypto::hash &blk_hash, const transaction &tx, const crypto::hash *tx_hash_ptr=NULL, const crypto::hash *tx_prunable_hash_ptr=NULL)
helper function for add_transactions, to add each individual transaction
Definition: blockchain_db.cpp:124
Holds cryptonote related classes and helpers.
Definition: db_bdb.cpp:224
virtual uint64_t get_block_already_generated_coins(const uint64_t &height) const =0
fetch a block&#39;s already generated coins
uint64_t fee
Definition: blockchain_db.h:141
virtual bool get_pruned_tx_blob(const crypto::hash &h, cryptonote::blobdata &tx) const =0
fetches the pruned transaction blob with the given hash
virtual bool remove_data_file(const std::string &folder) const =0
remove file(s) storing the database
virtual void block_txn_abort()=0
virtual void set_hard_fork(HardFork *hf)
Definition: blockchain_db.cpp:257
BLOCK_INVALID()
Definition: blockchain_db.h:272
virtual uint64_t get_top_block_timestamp() const =0
fetch the top block&#39;s timestamp
BlockchainDB * new_db(const std::string &db_type)
Definition: blockchain_db.cpp:99
virtual uint64_t height() const =0
fetch the current blockchain height
virtual ~BlockchainDB()
An empty destructor.
Definition: blockchain_db.h:552
virtual void close()=0
close the BlockchainDB
virtual void remove_txpool_tx(const crypto::hash &txid)=0
remove a txpool transaction
uint64_t time_add_transaction
a performance metric
Definition: blockchain_db.h:518
virtual bool tx_exists(const crypto::hash &h) const =0
check if a transaction with a given hash exists
uint64_t weight
Definition: blockchain_db.h:140
virtual cryptonote::blobdata get_block_blob(const crypto::hash &h) const =0
fetches the block with the given hash
DB_OPEN_FAILURE(const char *s)
Definition: blockchain_db.h:213
virtual void set_batch_transactions(bool)=0
sets whether or not to batch transactions
bool is_open() const
Gets the current open/ready state of the BlockchainDB.
Definition: blockchain_db.cpp:276
crypto::public_key pubkey
the output&#39;s public key (for spend verification)
Definition: blockchain_db.h:117
uint64_t last_failed_height
Definition: blockchain_db.h:143
void set_auto_remove_logs(bool auto_remove)
set whether or not to automatically remove logs
Definition: blockchain_db.h:1573
Definition: rctTypes.h:78
virtual bool get_prunable_tx_hash(const crypto::hash &tx_hash, crypto::hash &prunable_hash) const =0
fetches the prunable transaction hash
uint64_t last_relayed_time
Definition: blockchain_db.h:145
uint64_t unlock_time
Definition: blockchain_db.h:128
uint64_t height
the height of the block which created the output
Definition: blockchain_db.h:119
std::string m
Definition: blockchain_db.h:172
virtual uint64_t get_block_timestamp(const uint64_t &height) const =0
fetch a block&#39;s timestamp
thrown when there is an error starting a DB transaction
Definition: blockchain_db.h:199
virtual void block_txn_start(bool readonly=false)=0
virtual block get_block_from_height(const uint64_t &height) const
fetch a block by height
Definition: blockchain_db.cpp:297
#define false
Definition: stdbool.h:37
virtual bool for_all_outputs(std::function< bool(uint64_t amount, const crypto::hash &tx_hash, uint64_t height, size_t tx_idx)> f) const =0
runs a function over all outputs stored
virtual bool txpool_has_tx(const crypto::hash &txid) const =0
check whether a txid is in the txpool
const command_line::arg_descriptor< std::string > arg_db_type
Definition: blockchain_db.cpp:83
POD_CLASS public_key
Definition: crypto.h:63
virtual uint64_t get_tx_unlock_time(const crypto::hash &h) const =0
fetch a transaction&#39;s unlock time/height
virtual uint64_t get_num_outputs(const uint64_t &amount) const =0
fetches the number of outputs of a given amount
rct::key commitment
the output&#39;s amount commitment (for spend verification)
Definition: blockchain_db.h:120
virtual void batch_stop()=0
ends a batch transaction
DB_OPEN_FAILURE()
Definition: blockchain_db.h:212
virtual void add_block(const block &blk, size_t block_weight, const difficulty_type &cumulative_difficulty, const uint64_t &coins_generated, uint64_t num_rct_outs, const crypto::hash &blk_hash)=0
add the block and metadata to the db
virtual output_data_t get_output_key(const uint64_t &amount, const uint64_t &index)=0
get some of an output&#39;s data
uint8_t bf_padding
Definition: blockchain_db.h:151
virtual bool for_blocks_range(const uint64_t &h1, const uint64_t &h2, std::function< bool(uint64_t, const crypto::hash &, const cryptonote::block &)>) const =0
runs a function over a range of blocks
virtual size_t get_block_weight(const uint64_t &height) const =0
fetch a block&#39;s weight
uint8_t version
Definition: blockchain.cpp:87
BlockchainDB()
An empty constructor.
Definition: blockchain_db.h:547
virtual ~DB_EXCEPTION()
Definition: blockchain_db.h:178
std::string blobdata
Definition: blobdatatype.h:35
thrown when a requested transaction does not exist
Definition: blockchain_db.h:279
uint64_t max_used_block_height
Definition: blockchain_db.h:142
BLOCK_DNE(const char *s)
Definition: blockchain_db.h:243
Definition: base.py:1
OUTPUT_EXISTS()
Definition: blockchain_db.h:312
virtual bool can_thread_bulk_indices() const =0
OUTPUT_DNE(const char *s)
Definition: blockchain_db.h:303
DB_EXCEPTION(const char *s)
Definition: blockchain_db.h:175
virtual void open(const std::string &filename, const int db_flags=0)=0
open a db, or create it if necessary.
KEY_IMAGE_EXISTS(const char *s)
Definition: blockchain_db.h:323
virtual void remove_block()=0
remove data about the top block
BLOCK_INVALID(const char *s)
Definition: blockchain_db.h:273
std::uint64_t difficulty_type
Definition: difficulty.h:40
void remove_transaction(const crypto::hash &tx_hash)
helper function to remove transaction from the blockchain
Definition: blockchain_db.cpp:281
static void init_options(boost::program_options::options_description &desc)
init command line options
Definition: blockchain_db.cpp:110
uint8_t double_spend_seen
Definition: blockchain_db.h:150
virtual bool for_all_txpool_txes(std::function< bool(const crypto::hash &, const txpool_tx_meta_t &, const cryptonote::blobdata *)>, bool include_blob=false, bool include_unrelayed_txes=true) const =0
runs a function over all txpool transactions
virtual uint64_t get_txpool_tx_count(bool include_unrelayed_txes=true) const =0
get the number of transactions in the txpool
virtual bool get_tx_blob(const crypto::hash &h, cryptonote::blobdata &tx) const =0
fetches the transaction blob with the given hash
POD_CLASS key_image
Definition: crypto.h:89
a struct containing txpool per transaction metadata
Definition: blockchain_db.h:136
DB_SYNC_FAILURE()
Definition: blockchain_db.h:232
TX_DNE(const char *s)
Definition: blockchain_db.h:283
TX_DNE()
Definition: blockchain_db.h:282
thrown when a block&#39;s parent does not exist (and it needed to)
Definition: blockchain_db.h:249
crypto::hash last_failed_id
Definition: blockchain_db.h:139
void show_stats()
show profiling stats
Definition: blockchain_db.cpp:346
bool m_auto_remove_logs
whether or not to automatically remove old logs
Definition: blockchain_db.h:538
DB_CREATE_FAILURE()
Definition: blockchain_db.h:222
virtual void add_txpool_tx(const transaction &tx, const txpool_tx_meta_t &details)=0
add a txpool transaction
static uint64_t db_flags
Definition: blockchain_blackball.cpp:57
TX_EXISTS(const char *s)
Definition: blockchain_db.h:293
const command_line::arg_descriptor< bool > arg_db_salvage
Definition: blockchain_db.cpp:93
virtual void check_hard_fork_info()=0
verify hard fork info in database
epee::critical_section m_synchronization_lock
A lock, currently for when BlockchainLMDB needs to resize the backing db file.
Definition: blockchain_db.h:1576
The BlockchainDB backing store interface declaration/contract.
Definition: blockchain_db.h:343
virtual bool for_all_key_images(std::function< bool(const crypto::key_image &)>) const =0
runs a function over all key images stored
virtual block_header get_block_header(const crypto::hash &h) const =0
fetch a block header
HardFork * m_hardfork
Definition: blockchain_db.h:540
virtual bool get_txpool_tx_meta(const crypto::hash &txid, txpool_tx_meta_t &meta) const =0
get a txpool transaction&#39;s metadata
virtual 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) const =0
return a histogram of outputs on the blockchain
uint64_t time_tx_exists
a performance metric
Definition: blockchain_db.h:536
uint8_t kept_by_block
Definition: blockchain_db.h:147
virtual difficulty_type get_block_difficulty(const uint64_t &height) const =0
fetch a block&#39;s difficulty
uint64_t time_blk_hash
a performance metric
Definition: blockchain_db.h:516
POD_CLASS hash
Definition: hash.h:49
virtual block get_block(const crypto::hash &h) const
fetches the block with the given hash
Definition: blockchain_db.cpp:307
virtual cryptonote::blobdata get_block_blob_from_height(const uint64_t &height) const =0
fetch a block blob by height
std::pair< crypto::hash, uint64_t > tx_out_index
Definition: blockchain_db.h:104
virtual bool block_exists(const crypto::hash &h, uint64_t *height=NULL) const =0
checks if a block exists
uint64_t time_add_block1
a performance metric
Definition: blockchain_db.h:517
uint8_t relayed
Definition: blockchain_db.h:148
virtual void update_txpool_tx(const crypto::hash &txid, const txpool_tx_meta_t &details)=0
update a txpool transaction&#39;s metadata
virtual std::vector< std::string > get_filenames() const =0
get all files used by the BlockchainDB (if any)
OUTPUT_DNE()
Definition: blockchain_db.h:302
Definition: cryptonote_basic.h:143
BLOCK_PARENT_DNE(const char *s)
Definition: blockchain_db.h:253
uint64_t unlock_time
the output&#39;s unlock time (or height)
Definition: blockchain_db.h:118
virtual uint64_t get_database_size() const =0
get disk space requirements
thrown when a requested output does not exist
Definition: blockchain_db.h:299
thrown when a block exists, but shouldn&#39;t, namely when adding a block
Definition: blockchain_db.h:259
thrown when something is wrong with the block to be added
Definition: blockchain_db.h:269
virtual tx_out_index get_output_tx_and_index_from_global(const uint64_t &index) const =0
gets an output&#39;s tx hash and index
thrown when synchronizing the BlockchainDB to disk fails
Definition: blockchain_db.h:229
virtual block get_top_block() const =0
fetch the top block
a struct containing output metadata
Definition: blockchain_db.h:115
Definition: cryptonote_basic.h:182
virtual bool is_read_only() const =0
is BlockchainDB in read-only mode?
virtual std::vector< block > get_blocks_range(const uint64_t &h1, const uint64_t &h2) const =0
fetch a list of blocks
#define s(x, c)
Definition: aesb.c:46
virtual tx_out_index get_output_tx_and_index(const uint64_t &amount, const uint64_t &index) const =0
gets an output&#39;s tx hash and index
bool m_open
Whether or not the BlockchainDB is open/ready for use.
Definition: blockchain_db.h:1575
BLOCK_EXISTS()
Definition: blockchain_db.h:262
virtual void block_txn_stop()=0
uint64_t time_commit1
a performance metric
Definition: blockchain_db.h:537
virtual uint8_t get_hard_fork_version(uint64_t height) const =0
checks which hardfork version a height is on
DB_ERROR_TXN_START()
Definition: blockchain_db.h:202