Bitcoin Kernel
C header for interacting with the Bitcoin Kernel library.
Loading...
Searching...
No Matches
bitcoinkernel.h
Go to the documentation of this file.
1// Copyright (c) 2024-present The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#ifndef BITCOIN_KERNEL_BITCOINKERNEL_H
6#define BITCOIN_KERNEL_BITCOINKERNEL_H
7
8#ifndef __cplusplus
9#include <stddef.h>
10#include <stdint.h>
11#else
12#include <cstddef>
13#include <cstdint>
14#endif // __cplusplus
15
16#ifndef BITCOINKERNEL_API
17 #ifdef BITCOINKERNEL_BUILD
18 #if defined(_WIN32)
19 #define BITCOINKERNEL_API __declspec(dllexport)
20 #else
21 #define BITCOINKERNEL_API __attribute__((visibility("default")))
22 #endif
23 #else
24 #if defined(_WIN32) && !defined(BITCOINKERNEL_STATIC)
25 #define BITCOINKERNEL_API __declspec(dllimport)
26 #else
27 #define BITCOINKERNEL_API
28 #endif
29 #endif
30#endif
31
32/* Warning attributes */
33#if defined(__GNUC__)
34 #define BITCOINKERNEL_WARN_UNUSED_RESULT __attribute__((__warn_unused_result__))
35#else
36 #define BITCOINKERNEL_WARN_UNUSED_RESULT
37#endif
38
49#if !defined(BITCOINKERNEL_BUILD) && defined(__GNUC__)
50 #define BITCOINKERNEL_ARG_NONNULL(...) __attribute__((__nonnull__(__VA_ARGS__)))
51#else
52 #define BITCOINKERNEL_ARG_NONNULL(...)
53#endif
54
55#ifdef __cplusplus
56extern "C" {
57#endif // __cplusplus
58
121
126
131
144
153
165
181
194
203
214
218typedef struct btck_Block btck_Block;
219
227
232typedef struct btck_Chain btck_Chain;
233
246
255
262typedef struct btck_Coin btck_Coin;
263
270
277
284
294
300typedef struct btck_Txid btck_Txid;
301
306
309#define btck_SynchronizationState_INIT_REINDEX ((btck_SynchronizationState)(0))
310#define btck_SynchronizationState_INIT_DOWNLOAD ((btck_SynchronizationState)(1))
311#define btck_SynchronizationState_POST_INIT ((btck_SynchronizationState)(2))
312
314typedef uint8_t btck_Warning;
315#define btck_Warning_UNKNOWN_NEW_RULES_ACTIVATED ((btck_Warning)(0))
316#define btck_Warning_LARGE_WORK_INVALID_CHAIN ((btck_Warning)(1))
317
324typedef void (*btck_LogCallback)(void* user_data, const char* message, size_t message_len);
325
329typedef void (*btck_DestroyCallback)(void* user_data);
330
334typedef void (*btck_NotifyBlockTip)(void* user_data, btck_SynchronizationState state, const btck_BlockTreeEntry* entry, double verification_progress);
335typedef void (*btck_NotifyHeaderTip)(void* user_data, btck_SynchronizationState state, int64_t height, int64_t timestamp, int presync);
336typedef void (*btck_NotifyProgress)(void* user_data, const char* title, size_t title_len, int progress_percent, int resume_possible);
337typedef void (*btck_NotifyWarningSet)(void* user_data, btck_Warning warning, const char* message, size_t message_len);
338typedef void (*btck_NotifyWarningUnset)(void* user_data, btck_Warning warning);
339typedef void (*btck_NotifyFlushError)(void* user_data, const char* message, size_t message_len);
340typedef void (*btck_NotifyFatalError)(void* user_data, const char* message, size_t message_len);
341
345typedef void (*btck_ValidationInterfaceBlockChecked)(void* user_data, btck_Block* block, const btck_BlockValidationState* state);
346typedef void (*btck_ValidationInterfacePoWValidBlock)(void* user_data, btck_Block* block, const btck_BlockTreeEntry* entry);
347typedef void (*btck_ValidationInterfaceBlockConnected)(void* user_data, btck_Block* block, const btck_BlockTreeEntry* entry);
348typedef void (*btck_ValidationInterfaceBlockDisconnected)(void* user_data, btck_Block* block, const btck_BlockTreeEntry* entry);
349
353typedef int (*btck_WriteBytes)(const void* bytes, size_t size, void* userdata);
354
359typedef uint8_t btck_ValidationMode;
360#define btck_ValidationMode_VALID ((btck_ValidationMode)(0))
361#define btck_ValidationMode_INVALID ((btck_ValidationMode)(1))
362#define btck_ValidationMode_INTERNAL_ERROR ((btck_ValidationMode)(2))
363
368#define btck_BlockValidationResult_UNSET ((btck_BlockValidationResult)(0))
369#define btck_BlockValidationResult_CONSENSUS ((btck_BlockValidationResult)(1))
370#define btck_BlockValidationResult_CACHED_INVALID ((btck_BlockValidationResult)(2))
371#define btck_BlockValidationResult_INVALID_HEADER ((btck_BlockValidationResult)(3))
372#define btck_BlockValidationResult_MUTATED ((btck_BlockValidationResult)(4))
373#define btck_BlockValidationResult_MISSING_PREV ((btck_BlockValidationResult)(5))
374#define btck_BlockValidationResult_INVALID_PREV ((btck_BlockValidationResult)(6))
375#define btck_BlockValidationResult_TIME_FUTURE ((btck_BlockValidationResult)(7))
376#define btck_BlockValidationResult_HEADER_LOW_WORK ((btck_BlockValidationResult)(8))
377
396
422
426typedef uint8_t btck_LogCategory;
427#define btck_LogCategory_ALL ((btck_LogCategory)(0))
428#define btck_LogCategory_BENCH ((btck_LogCategory)(1))
429#define btck_LogCategory_BLOCKSTORAGE ((btck_LogCategory)(2))
430#define btck_LogCategory_COINDB ((btck_LogCategory)(3))
431#define btck_LogCategory_LEVELDB ((btck_LogCategory)(4))
432#define btck_LogCategory_MEMPOOL ((btck_LogCategory)(5))
433#define btck_LogCategory_PRUNE ((btck_LogCategory)(6))
434#define btck_LogCategory_RAND ((btck_LogCategory)(7))
435#define btck_LogCategory_REINDEX ((btck_LogCategory)(8))
436#define btck_LogCategory_VALIDATION ((btck_LogCategory)(9))
437#define btck_LogCategory_KERNEL ((btck_LogCategory)(10))
438
442typedef uint8_t btck_LogLevel;
443#define btck_LogLevel_TRACE ((btck_LogLevel)(0))
444#define btck_LogLevel_DEBUG ((btck_LogLevel)(1))
445#define btck_LogLevel_INFO ((btck_LogLevel)(2))
446
459
464#define btck_ScriptVerifyStatus_OK ((btck_ScriptVerifyStatus)(0))
465#define btck_ScriptVerifyStatus_ERROR_INVALID_FLAGS_COMBINATION ((btck_ScriptVerifyStatus)(1))
466#define btck_ScriptVerifyStatus_ERROR_SPENT_OUTPUTS_REQUIRED ((btck_ScriptVerifyStatus)(2))
467
472#define btck_ScriptVerificationFlags_NONE ((btck_ScriptVerificationFlags)(0))
473#define btck_ScriptVerificationFlags_P2SH ((btck_ScriptVerificationFlags)(1U << 0))
474#define btck_ScriptVerificationFlags_DERSIG ((btck_ScriptVerificationFlags)(1U << 2))
475#define btck_ScriptVerificationFlags_NULLDUMMY ((btck_ScriptVerificationFlags)(1U << 4))
476#define btck_ScriptVerificationFlags_CHECKLOCKTIMEVERIFY ((btck_ScriptVerificationFlags)(1U << 9))
477#define btck_ScriptVerificationFlags_CHECKSEQUENCEVERIFY ((btck_ScriptVerificationFlags)(1U << 10))
478#define btck_ScriptVerificationFlags_WITNESS ((btck_ScriptVerificationFlags)(1U << 11))
479#define btck_ScriptVerificationFlags_TAPROOT ((btck_ScriptVerificationFlags)(1U << 17))
480#define btck_ScriptVerificationFlags_ALL ((btck_ScriptVerificationFlags)(btck_ScriptVerificationFlags_P2SH | \
481 btck_ScriptVerificationFlags_DERSIG | \
482 btck_ScriptVerificationFlags_NULLDUMMY | \
483 btck_ScriptVerificationFlags_CHECKLOCKTIMEVERIFY | \
484 btck_ScriptVerificationFlags_CHECKSEQUENCEVERIFY | \
485 btck_ScriptVerificationFlags_WITNESS | \
486 btck_ScriptVerificationFlags_TAPROOT))
487
488typedef uint8_t btck_ChainType;
489#define btck_ChainType_MAINNET ((btck_ChainType)(0))
490#define btck_ChainType_TESTNET ((btck_ChainType)(1))
491#define btck_ChainType_TESTNET_4 ((btck_ChainType)(2))
492#define btck_ChainType_SIGNET ((btck_ChainType)(3))
493#define btck_ChainType_REGTEST ((btck_ChainType)(4))
494
499
508 const void* raw_transaction, size_t raw_transaction_len);
509
518 const btck_Transaction* transaction) BITCOINKERNEL_ARG_NONNULL(1);
519
531 const btck_Transaction* transaction,
532 btck_WriteBytes writer,
533 void* user_data) BITCOINKERNEL_ARG_NONNULL(1, 2);
534
542 const btck_Transaction* transaction) BITCOINKERNEL_ARG_NONNULL(1);
543
554 const btck_Transaction* transaction, size_t output_index) BITCOINKERNEL_ARG_NONNULL(1);
555
566 const btck_Transaction* transaction, size_t input_index) BITCOINKERNEL_ARG_NONNULL(1);
567
575 const btck_Transaction* transaction) BITCOINKERNEL_ARG_NONNULL(1);
576
585 const btck_Transaction* transaction) BITCOINKERNEL_ARG_NONNULL(1);
586
591
593
598
609 const btck_Transaction* tx_to,
610 const btck_TransactionOutput** spent_outputs, size_t spent_outputs_len) BITCOINKERNEL_ARG_NONNULL(1);
611
620
625
627
632
640 const void* script_pubkey, size_t script_pubkey_len);
641
649 const btck_ScriptPubkey* script_pubkey) BITCOINKERNEL_ARG_NONNULL(1);
650
670 const btck_ScriptPubkey* script_pubkey,
671 int64_t amount,
672 const btck_Transaction* tx_to,
673 const btck_PrecomputedTransactionData* precomputed_txdata,
674 unsigned int input_index,
677
688 const btck_ScriptPubkey* script_pubkey,
689 btck_WriteBytes writer,
690 void* user_data) BITCOINKERNEL_ARG_NONNULL(1, 2);
691
696
698
703
712 const btck_ScriptPubkey* script_pubkey,
713 int64_t amount) BITCOINKERNEL_ARG_NONNULL(1);
714
724 const btck_TransactionOutput* transaction_output) BITCOINKERNEL_ARG_NONNULL(1);
725
733 const btck_TransactionOutput* transaction_output) BITCOINKERNEL_ARG_NONNULL(1);
734
742 const btck_TransactionOutput* transaction_output) BITCOINKERNEL_ARG_NONNULL(1);
743
748
750
755
765
774
791
800
809
824 btck_LogCallback log_callback,
825 void* user_data,
826 btck_DestroyCallback user_data_destroy_callback) BITCOINKERNEL_ARG_NONNULL(1);
827
832
834
839
848 btck_ChainType chain_type);
849
854 const btck_ChainParameters* chain_parameters) BITCOINKERNEL_ARG_NONNULL(1);
855
860
862
867
872
881 btck_ContextOptions* context_options,
882 const btck_ChainParameters* chain_parameters) BITCOINKERNEL_ARG_NONNULL(1, 2);
883
892 btck_ContextOptions* context_options,
894
906 btck_ContextOptions* context_options,
907 btck_ValidationInterfaceCallbacks validation_interface_callbacks) BITCOINKERNEL_ARG_NONNULL(1);
908
913
915
920
931 const btck_ContextOptions* context_options);
932
937 const btck_Context* context) BITCOINKERNEL_ARG_NONNULL(1);
938
948
953
955
960
969 const btck_BlockTreeEntry* block_tree_entry) BITCOINKERNEL_ARG_NONNULL(1);
970
978 const btck_BlockTreeEntry* block_tree_entry) BITCOINKERNEL_ARG_NONNULL(1);
979
987 const btck_BlockTreeEntry* block_tree_entry) BITCOINKERNEL_ARG_NONNULL(1);
988
996 const btck_BlockTreeEntry* block_tree_entry) BITCOINKERNEL_ARG_NONNULL(1);
997
1007 const btck_BlockTreeEntry* entry1, const btck_BlockTreeEntry* entry2) BITCOINKERNEL_ARG_NONNULL(1, 2);
1008
1010
1015
1029 const btck_Context* context,
1030 const char* data_directory,
1031 size_t data_directory_len,
1032 const char* blocks_directory,
1033 size_t blocks_directory_len) BITCOINKERNEL_ARG_NONNULL(1);
1034
1044 btck_ChainstateManagerOptions* chainstate_manager_options,
1045 int worker_threads) BITCOINKERNEL_ARG_NONNULL(1);
1046
1058 btck_ChainstateManagerOptions* chainstate_manager_options,
1059 int wipe_block_tree_db,
1060 int wipe_chainstate_db) BITCOINKERNEL_ARG_NONNULL(1);
1061
1069 btck_ChainstateManagerOptions* chainstate_manager_options,
1070 int block_tree_db_in_memory) BITCOINKERNEL_ARG_NONNULL(1);
1071
1079 btck_ChainstateManagerOptions* chainstate_manager_options,
1080 int chainstate_db_in_memory) BITCOINKERNEL_ARG_NONNULL(1);
1081
1086
1088
1093
1103 const btck_ChainstateManagerOptions* chainstate_manager_options) BITCOINKERNEL_ARG_NONNULL(1);
1104
1113 const btck_ChainstateManager* chainstate_manager) BITCOINKERNEL_ARG_NONNULL(1);
1114
1124 btck_ChainstateManager* chainstate_manager,
1125 const btck_BlockHeader* header,
1126 btck_BlockValidationState* block_validation_state) BITCOINKERNEL_ARG_NONNULL(1, 2, 3);
1127
1140 btck_ChainstateManager* chainstate_manager,
1141 const char** block_file_paths_data, size_t* block_file_paths_lens,
1142 size_t block_file_paths_data_len) BITCOINKERNEL_ARG_NONNULL(1);
1143
1162 btck_ChainstateManager* chainstate_manager,
1163 const btck_Block* block,
1164 int* new_block) BITCOINKERNEL_ARG_NONNULL(1, 2, 3);
1165
1181 const btck_ChainstateManager* chainstate_manager) BITCOINKERNEL_ARG_NONNULL(1);
1182
1192 const btck_ChainstateManager* chainstate_manager,
1193 const btck_BlockHash* block_hash) BITCOINKERNEL_ARG_NONNULL(1, 2);
1194
1199
1201
1206
1216 const btck_ChainstateManager* chainstate_manager,
1217 const btck_BlockTreeEntry* block_tree_entry) BITCOINKERNEL_ARG_NONNULL(1, 2);
1218
1227 const void* raw_block, size_t raw_block_len);
1228
1237 const btck_Block* block) BITCOINKERNEL_ARG_NONNULL(1);
1238
1246 const btck_Block* block) BITCOINKERNEL_ARG_NONNULL(1);
1247
1257 const btck_Block* block, size_t transaction_index) BITCOINKERNEL_ARG_NONNULL(1);
1258
1268 const btck_Block* block) BITCOINKERNEL_ARG_NONNULL(1);
1269
1277 const btck_Block* block) BITCOINKERNEL_ARG_NONNULL(1);
1278
1290 const btck_Block* block,
1291 btck_WriteBytes writer,
1292 void* user_data) BITCOINKERNEL_ARG_NONNULL(1, 2);
1293
1298
1300
1305
1310
1315 const btck_BlockValidationState* block_validation_state) BITCOINKERNEL_ARG_NONNULL(1);
1316
1321 const btck_BlockValidationState* block_validation_state) BITCOINKERNEL_ARG_NONNULL(1);
1322
1330 const btck_BlockValidationState* block_validation_state) BITCOINKERNEL_ARG_NONNULL(1);
1331
1336 btck_BlockValidationState* block_validation_state) BITCOINKERNEL_ARG_NONNULL(1);
1337
1339
1344
1352 const btck_Chain* chain) BITCOINKERNEL_ARG_NONNULL(1);
1353
1364 const btck_Chain* chain,
1365 int block_height) BITCOINKERNEL_ARG_NONNULL(1);
1366
1376 const btck_Chain* chain,
1377 const btck_BlockTreeEntry* block_tree_entry) BITCOINKERNEL_ARG_NONNULL(1, 2);
1378
1380
1385
1395 const btck_ChainstateManager* chainstate_manager,
1396 const btck_BlockTreeEntry* block_tree_entry) BITCOINKERNEL_ARG_NONNULL(1, 2);
1397
1405 const btck_BlockSpentOutputs* block_spent_outputs) BITCOINKERNEL_ARG_NONNULL(1);
1406
1415 const btck_BlockSpentOutputs* block_spent_outputs) BITCOINKERNEL_ARG_NONNULL(1);
1416
1427 const btck_BlockSpentOutputs* block_spent_outputs,
1428 size_t transaction_spent_outputs_index) BITCOINKERNEL_ARG_NONNULL(1);
1429
1434
1436
1441
1449 const btck_TransactionSpentOutputs* transaction_spent_outputs) BITCOINKERNEL_ARG_NONNULL(1);
1450
1459 const btck_TransactionSpentOutputs* transaction_spent_outputs) BITCOINKERNEL_ARG_NONNULL(1);
1460
1472 const btck_TransactionSpentOutputs* transaction_spent_outputs,
1473 size_t coin_index) BITCOINKERNEL_ARG_NONNULL(1);
1474
1479
1481
1486
1494 const btck_TransactionInput* transaction_input) BITCOINKERNEL_ARG_NONNULL(1);
1495
1504 const btck_TransactionInput* transaction_input) BITCOINKERNEL_ARG_NONNULL(1);
1505
1510
1512
1517
1525 const btck_TransactionOutPoint* transaction_out_point) BITCOINKERNEL_ARG_NONNULL(1);
1526
1534 const btck_TransactionOutPoint* transaction_out_point) BITCOINKERNEL_ARG_NONNULL(1);
1535
1544 const btck_TransactionOutPoint* transaction_out_point) BITCOINKERNEL_ARG_NONNULL(1);
1545
1550
1552
1557
1565 const btck_Txid* txid) BITCOINKERNEL_ARG_NONNULL(1);
1566
1575 const btck_Txid* txid1, const btck_Txid* txid2) BITCOINKERNEL_ARG_NONNULL(1, 2);
1576
1584 const btck_Txid* txid, unsigned char output[32]) BITCOINKERNEL_ARG_NONNULL(1, 2);
1585
1590
1592
1594
1599
1607 const btck_Coin* coin) BITCOINKERNEL_ARG_NONNULL(1);
1608
1617 const btck_Coin* coin) BITCOINKERNEL_ARG_NONNULL(1);
1618
1626 const btck_Coin* coin) BITCOINKERNEL_ARG_NONNULL(1);
1627
1636 const btck_Coin* coin) BITCOINKERNEL_ARG_NONNULL(1);
1637
1642
1644
1649
1654 const unsigned char block_hash[32]) BITCOINKERNEL_ARG_NONNULL(1);
1655
1664 const btck_BlockHash* hash1, const btck_BlockHash* hash2) BITCOINKERNEL_ARG_NONNULL(1, 2);
1665
1673 const btck_BlockHash* block_hash) BITCOINKERNEL_ARG_NONNULL(1);
1674
1682 const btck_BlockHash* block_hash, unsigned char output[32]) BITCOINKERNEL_ARG_NONNULL(1, 2);
1683
1688
1690
1696
1705 const void* raw_block_header, size_t raw_block_header_len);
1706
1715
1724
1734
1743
1752
1761
1770
1775
1777
1778#ifdef __cplusplus
1779} // extern "C"
1780#endif // __cplusplus
1781
1782#endif // BITCOIN_KERNEL_BITCOINKERNEL_H
#define BITCOINKERNEL_API
Definition bitcoinkernel.h:27
BITCOINKERNEL_API int btck_block_hash_equals(const btck_BlockHash *hash1, const btck_BlockHash *hash2) 2)
Check if two block hashes are equal.
BITCOINKERNEL_API int BITCOINKERNEL_API int btck_chainstate_manager_import_blocks(btck_ChainstateManager *chainstate_manager, const char **block_file_paths_data, size_t *block_file_paths_lens, size_t block_file_paths_data_len)
Triggers the start of a reindex if the wipe options were previously set for the chainstate manager....
BITCOINKERNEL_API btck_BlockSpentOutputs * btck_block_spent_outputs_copy(const btck_BlockSpentOutputs *block_spent_outputs)
Copy a block's spent outputs.
BITCOINKERNEL_API btck_TransactionOutput * btck_transaction_output_create(const btck_ScriptPubkey *script_pubkey, int64_t amount)
Create a transaction output from a script pubkey and an amount.
uint8_t btck_LogLevel
Definition bitcoinkernel.h:442
BITCOINKERNEL_API uint32_t btck_coin_confirmation_height(const btck_Coin *coin)
Returns the block height where the transaction that created this coin was included in.
BITCOINKERNEL_API const btck_Transaction * btck_block_get_transaction_at(const btck_Block *block, size_t transaction_index)
Get the transaction at the provided index. The returned transaction is not owned and depends on the l...
BITCOINKERNEL_API btck_ChainParameters * btck_chain_parameters_create(btck_ChainType chain_type)
Creates a chain parameters struct with default parameters based on the passed in chain type.
BITCOINKERNEL_API btck_TransactionOutPoint * btck_transaction_out_point_copy(const btck_TransactionOutPoint *transaction_out_point)
Copy a transaction out point.
struct btck_ContextOptions btck_ContextOptions
Definition bitcoinkernel.h:164
BITCOINKERNEL_API int btck_transaction_to_bytes(const btck_Transaction *transaction, btck_WriteBytes writer, void *user_data) 2)
Serializes the transaction through the passed in callback to bytes. This is consensus serialization t...
BITCOINKERNEL_API void btck_block_hash_to_bytes(const btck_BlockHash *block_hash, unsigned char output[32]) 2)
Serializes the block hash to bytes.
BITCOINKERNEL_API uint32_t btck_block_header_get_bits(const btck_BlockHeader *header)
Get the nBits difficulty target from btck_BlockHeader.
BITCOINKERNEL_API void btck_logging_connection_destroy(btck_LoggingConnection *logging_connection)
struct btck_Context btck_Context
Definition bitcoinkernel.h:180
BITCOINKERNEL_API size_t btck_transaction_spent_outputs_count(const btck_TransactionSpentOutputs *transaction_spent_outputs)
Returns the number of previous transaction outputs contained in the transaction spent outputs data.
BITCOINKERNEL_API btck_BlockSpentOutputs * btck_block_spent_outputs_read(const btck_ChainstateManager *chainstate_manager, const btck_BlockTreeEntry *block_tree_entry) 2)
Reads the block spent coins data the passed in block tree entry points to from disk and returns it.
BITCOINKERNEL_API btck_BlockHeader * btck_block_tree_entry_get_block_header(const btck_BlockTreeEntry *block_tree_entry)
Return the btck_BlockHeader associated with this entry.
int(* btck_WriteBytes)(const void *bytes, size_t size, void *userdata)
Definition bitcoinkernel.h:353
struct btck_BlockHash btck_BlockHash
Definition bitcoinkernel.h:269
#define BITCOINKERNEL_WARN_UNUSED_RESULT
Definition bitcoinkernel.h:36
BITCOINKERNEL_API void btck_chainstate_manager_destroy(btck_ChainstateManager *chainstate_manager)
BITCOINKERNEL_API size_t btck_block_count_transactions(const btck_Block *block)
Count the number of transactions contained in a block.
BITCOINKERNEL_API btck_Coin * btck_coin_copy(const btck_Coin *coin)
Copy a coin.
BITCOINKERNEL_API int btck_chainstate_manager_process_block_header(btck_ChainstateManager *chainstate_manager, const btck_BlockHeader *header, btck_BlockValidationState *block_validation_state) 2
Processes and validates the provided btck_BlockHeader.
BITCOINKERNEL_API void btck_transaction_destroy(btck_Transaction *transaction)
BITCOINKERNEL_API btck_Block * btck_block_copy(const btck_Block *block)
Copy a block. Blocks are reference counted, so this just increments the reference count.
BITCOINKERNEL_API btck_BlockValidationState * btck_block_validation_state_copy(const btck_BlockValidationState *block_validation_state)
Copies the btck_BlockValidationState.
BITCOINKERNEL_API const btck_BlockHash * btck_block_header_get_prev_hash(const btck_BlockHeader *header)
Get the previous btck_BlockHash from btck_BlockHeader. The returned hash is unowned and only valid fo...
BITCOINKERNEL_API const btck_BlockTreeEntry * btck_chainstate_manager_get_best_entry(const btck_ChainstateManager *chainstate_manager)
Get the btck_BlockTreeEntry whose associated btck_BlockHeader has the most known cumulative proof of ...
BITCOINKERNEL_API btck_ScriptPubkey * btck_script_pubkey_copy(const btck_ScriptPubkey *script_pubkey)
Copy a script pubkey.
uint8_t btck_ChainType
Definition bitcoinkernel.h:488
BITCOINKERNEL_API btck_LoggingConnection * btck_logging_connection_create(btck_LogCallback log_callback, void *user_data, btck_DestroyCallback user_data_destroy_callback)
Start logging messages through the provided callback. Log messages produced before this function is f...
BITCOINKERNEL_API void btck_chainstate_manager_options_set_worker_threads_num(btck_ChainstateManagerOptions *chainstate_manager_options, int worker_threads)
Set the number of available worker threads used during validation.
BITCOINKERNEL_API int btck_block_to_bytes(const btck_Block *block, btck_WriteBytes writer, void *user_data) 2)
Serializes the block through the passed in callback to bytes. This is consensus serialization that is...
BITCOINKERNEL_API btck_Context * btck_context_copy(const btck_Context *context)
void(* btck_LogCallback)(void *user_data, const char *message, size_t message_len)
Definition bitcoinkernel.h:324
void(* btck_ValidationInterfaceBlockChecked)(void *user_data, btck_Block *block, const btck_BlockValidationState *state)
Definition bitcoinkernel.h:345
struct btck_LoggingConnection btck_LoggingConnection
Definition bitcoinkernel.h:143
uint32_t btck_BlockValidationResult
Definition bitcoinkernel.h:367
BITCOINKERNEL_API btck_ValidationMode btck_block_validation_state_get_validation_mode(const btck_BlockValidationState *block_validation_state)
BITCOINKERNEL_API int32_t btck_chain_get_height(const btck_Chain *chain)
Return the height of the tip of the chain.
uint8_t btck_ValidationMode
Definition bitcoinkernel.h:359
BITCOINKERNEL_API int btck_txid_equals(const btck_Txid *txid1, const btck_Txid *txid2) 2)
Check if two txids are equal.
BITCOINKERNEL_API void btck_logging_disable_category(btck_LogCategory category)
Disable a specific log category for the global internal logger. This changes a global setting and wil...
void(* btck_ValidationInterfacePoWValidBlock)(void *user_data, btck_Block *block, const btck_BlockTreeEntry *entry)
Definition bitcoinkernel.h:346
BITCOINKERNEL_API btck_BlockValidationState * btck_block_validation_state_create()
BITCOINKERNEL_API btck_BlockHash * btck_block_get_hash(const btck_Block *block)
Calculate and return the hash of a block.
BITCOINKERNEL_API const btck_Txid * btck_transaction_get_txid(const btck_Transaction *transaction)
Get the txid of a transaction. The returned txid is not owned and depends on the lifetime of the tran...
uint8_t btck_SynchronizationState
Definition bitcoinkernel.h:308
BITCOINKERNEL_API void btck_context_options_destroy(btck_ContextOptions *context_options)
void(* btck_NotifyProgress)(void *user_data, const char *title, size_t title_len, int progress_percent, int resume_possible)
Definition bitcoinkernel.h:336
BITCOINKERNEL_API btck_TransactionSpentOutputs * btck_transaction_spent_outputs_copy(const btck_TransactionSpentOutputs *transaction_spent_outputs)
Copy a transaction's spent outputs.
struct btck_BlockTreeEntry btck_BlockTreeEntry
Definition bitcoinkernel.h:193
void(* btck_NotifyWarningUnset)(void *user_data, btck_Warning warning)
Definition bitcoinkernel.h:338
BITCOINKERNEL_API btck_ChainstateManagerOptions * btck_chainstate_manager_options_create(const btck_Context *context, const char *data_directory, size_t data_directory_len, const char *blocks_directory, size_t blocks_directory_len)
Create options for the chainstate manager.
BITCOINKERNEL_API btck_BlockHeader * btck_block_header_copy(const btck_BlockHeader *header)
Copy a btck_BlockHeader.
void(* btck_ValidationInterfaceBlockDisconnected)(void *user_data, btck_Block *block, const btck_BlockTreeEntry *entry)
Definition bitcoinkernel.h:348
BITCOINKERNEL_API btck_TransactionInput * btck_transaction_input_copy(const btck_TransactionInput *transaction_input)
Copy a transaction input.
BITCOINKERNEL_API void btck_chainstate_manager_options_destroy(btck_ChainstateManagerOptions *chainstate_manager_options)
BITCOINKERNEL_API const btck_TransactionSpentOutputs * btck_block_spent_outputs_get_transaction_spent_outputs_at(const btck_BlockSpentOutputs *block_spent_outputs, size_t transaction_spent_outputs_index)
Returns a transaction spent outputs contained in the block spent outputs at a certain index....
BITCOINKERNEL_API const btck_Txid * btck_transaction_out_point_get_txid(const btck_TransactionOutPoint *transaction_out_point)
Get the txid from the transaction out point. The returned txid is not owned and depends on the lifeti...
struct btck_TransactionSpentOutputs btck_TransactionSpentOutputs
Definition bitcoinkernel.h:254
struct btck_BlockSpentOutputs btck_BlockSpentOutputs
Definition bitcoinkernel.h:245
BITCOINKERNEL_API btck_BlockValidationResult btck_block_validation_state_get_block_validation_result(const btck_BlockValidationState *block_validation_state)
struct btck_Chain btck_Chain
Definition bitcoinkernel.h:232
#define BITCOINKERNEL_ARG_NONNULL(...)
Definition bitcoinkernel.h:52
void(* btck_DestroyCallback)(void *user_data)
Definition bitcoinkernel.h:329
BITCOINKERNEL_API void btck_precomputed_transaction_data_destroy(btck_PrecomputedTransactionData *precomputed_txdata)
BITCOINKERNEL_API void btck_chainstate_manager_options_update_chainstate_db_in_memory(btck_ChainstateManagerOptions *chainstate_manager_options, int chainstate_db_in_memory)
Sets chainstate db in memory in the options.
BITCOINKERNEL_API int btck_context_interrupt(btck_Context *context)
Interrupt can be used to halt long-running validation functions like when reindexing,...
BITCOINKERNEL_API const btck_ScriptPubkey * btck_transaction_output_get_script_pubkey(const btck_TransactionOutput *transaction_output)
Get the script pubkey of the output. The returned script pubkey is not owned and depends on the lifet...
uint32_t btck_ScriptVerificationFlags
Definition bitcoinkernel.h:471
BITCOINKERNEL_API void btck_block_hash_destroy(btck_BlockHash *block_hash)
BITCOINKERNEL_API int btck_block_tree_entry_equals(const btck_BlockTreeEntry *entry1, const btck_BlockTreeEntry *entry2) 2)
Check if two block tree entries are equal. Two block tree entries are equal when they point to the sa...
BITCOINKERNEL_API const btck_BlockTreeEntry * btck_chain_get_by_height(const btck_Chain *chain, int block_height)
Retrieve a block tree entry by its height in the currently active chain. Once retrieved there is no g...
BITCOINKERNEL_API btck_BlockHash * btck_block_hash_copy(const btck_BlockHash *block_hash)
Copy a block hash.
BITCOINKERNEL_API int64_t btck_transaction_output_get_amount(const btck_TransactionOutput *transaction_output)
Get the amount in the output.
BITCOINKERNEL_API const btck_TransactionOutput * btck_transaction_get_output_at(const btck_Transaction *transaction, size_t output_index)
Get the transaction outputs at the provided index. The returned transaction output is not owned and d...
struct btck_ScriptPubkey btck_ScriptPubkey
Definition bitcoinkernel.h:125
BITCOINKERNEL_API int32_t btck_block_header_get_version(const btck_BlockHeader *header)
Get the version from btck_BlockHeader.
BITCOINKERNEL_API size_t btck_block_spent_outputs_count(const btck_BlockSpentOutputs *block_spent_outputs)
Returns the number of transaction spent outputs whose data is contained in block spent outputs.
struct btck_Coin btck_Coin
Definition bitcoinkernel.h:262
BITCOINKERNEL_API const btck_TransactionInput * btck_transaction_get_input_at(const btck_Transaction *transaction, size_t input_index)
Get the transaction input at the provided index. The returned transaction input is not owned and depe...
BITCOINKERNEL_API int btck_chain_contains(const btck_Chain *chain, const btck_BlockTreeEntry *block_tree_entry) 2)
Return true if the passed in chain contains the block tree entry.
BITCOINKERNEL_API void btck_block_header_destroy(btck_BlockHeader *header)
BITCOINKERNEL_API btck_Block * btck_block_create(const void *raw_block, size_t raw_block_len)
Parse a serialized raw block into a new block object.
BITCOINKERNEL_API const btck_TransactionOutput * btck_coin_get_output(const btck_Coin *coin)
Return the transaction output of a coin. The returned pointer is unowned and only valid for the lifet...
struct btck_TransactionInput btck_TransactionInput
Definition bitcoinkernel.h:276
BITCOINKERNEL_API void btck_block_validation_state_destroy(btck_BlockValidationState *block_validation_state)
BITCOINKERNEL_API btck_Context * btck_context_create(const btck_ContextOptions *context_options)
Create a new kernel context. If the options have not been previously set, their corresponding fields ...
struct btck_TransactionOutPoint btck_TransactionOutPoint
Definition bitcoinkernel.h:283
BITCOINKERNEL_API btck_Transaction * btck_transaction_create(const void *raw_transaction, size_t raw_transaction_len)
Create a new transaction from the serialized data.
BITCOINKERNEL_API void btck_script_pubkey_destroy(btck_ScriptPubkey *script_pubkey)
BITCOINKERNEL_API void btck_transaction_output_destroy(btck_TransactionOutput *transaction_output)
BITCOINKERNEL_API btck_Transaction * btck_transaction_copy(const btck_Transaction *transaction)
Copy a transaction. Transactions are reference counted, so this just increments the reference count.
BITCOINKERNEL_API btck_TransactionOutput * btck_transaction_output_copy(const btck_TransactionOutput *transaction_output)
Copy a transaction output.
BITCOINKERNEL_API const btck_BlockHash * btck_block_tree_entry_get_block_hash(const btck_BlockTreeEntry *block_tree_entry)
Return the block hash associated with a block tree entry.
BITCOINKERNEL_API btck_BlockHeader * btck_block_get_header(const btck_Block *block)
Get the btck_BlockHeader from the block.
BITCOINKERNEL_API btck_ScriptPubkey * btck_script_pubkey_create(const void *script_pubkey, size_t script_pubkey_len)
Create a script pubkey from serialized data.
BITCOINKERNEL_API void btck_txid_destroy(btck_Txid *txid)
uint8_t btck_ScriptVerifyStatus
Definition bitcoinkernel.h:463
BITCOINKERNEL_API int btck_script_pubkey_to_bytes(const btck_ScriptPubkey *script_pubkey, btck_WriteBytes writer, void *user_data) 2)
Serializes the script pubkey through the passed in callback to bytes.
BITCOINKERNEL_API const btck_Coin * btck_transaction_spent_outputs_get_coin_at(const btck_TransactionSpentOutputs *transaction_spent_outputs, size_t coin_index)
Returns a coin contained in the transaction spent outputs at a certain index. The returned pointer is...
BITCOINKERNEL_API int32_t btck_block_tree_entry_get_height(const btck_BlockTreeEntry *block_tree_entry)
Return the height of a certain block tree entry.
BITCOINKERNEL_API btck_Txid * btck_txid_copy(const btck_Txid *txid)
Copy a txid.
BITCOINKERNEL_API void btck_transaction_out_point_destroy(btck_TransactionOutPoint *transaction_out_point)
BITCOINKERNEL_API btck_Block * btck_block_read(const btck_ChainstateManager *chainstate_manager, const btck_BlockTreeEntry *block_tree_entry) 2)
Reads the block the passed in block tree entry points to from disk and returns it.
BITCOINKERNEL_API btck_BlockHash * btck_block_hash_create(const unsigned char block_hash[32])
Create a block hash from its raw data.
void(* btck_NotifyBlockTip)(void *user_data, btck_SynchronizationState state, const btck_BlockTreeEntry *entry, double verification_progress)
Definition bitcoinkernel.h:334
uint8_t btck_LogCategory
Definition bitcoinkernel.h:426
BITCOINKERNEL_API void btck_context_options_set_validation_interface(btck_ContextOptions *context_options, btck_ValidationInterfaceCallbacks validation_interface_callbacks)
Set the validation interface callbacks for the context options. The context created with the options ...
void(* btck_ValidationInterfaceBlockConnected)(void *user_data, btck_Block *block, const btck_BlockTreeEntry *entry)
Definition bitcoinkernel.h:347
BITCOINKERNEL_API void btck_transaction_spent_outputs_destroy(btck_TransactionSpentOutputs *transaction_spent_outputs)
BITCOINKERNEL_API void btck_logging_set_options(btck_LoggingOptions options)
Set some options for the global internal logger. This changes global settings and will override setti...
BITCOINKERNEL_API btck_ChainParameters * btck_chain_parameters_copy(const btck_ChainParameters *chain_parameters)
struct btck_ChainstateManager btck_ChainstateManager
Definition bitcoinkernel.h:213
BITCOINKERNEL_API void btck_chain_parameters_destroy(btck_ChainParameters *chain_parameters)
struct btck_TransactionOutput btck_TransactionOutput
Definition bitcoinkernel.h:130
BITCOINKERNEL_API uint32_t btck_transaction_out_point_get_index(const btck_TransactionOutPoint *transaction_out_point)
Get the output position from the transaction out point.
BITCOINKERNEL_API int btck_chainstate_manager_process_block(btck_ChainstateManager *chainstate_manager, const btck_Block *block, int *new_block) 2
Process and validate the passed in block with the chainstate manager. Processing first does checks on...
BITCOINKERNEL_API btck_ChainstateManager * btck_chainstate_manager_create(const btck_ChainstateManagerOptions *chainstate_manager_options)
Create a chainstate manager. This is the main object for many validation tasks as well as for retriev...
struct btck_PrecomputedTransactionData btck_PrecomputedTransactionData
Definition bitcoinkernel.h:293
BITCOINKERNEL_API void btck_logging_enable_category(btck_LogCategory category)
Enable a specific log category for the global internal logger. This changes a global setting and will...
struct btck_BlockValidationState btck_BlockValidationState
Definition bitcoinkernel.h:226
BITCOINKERNEL_API const btck_TransactionOutPoint * btck_transaction_input_get_out_point(const btck_TransactionInput *transaction_input)
Get the transaction out point. The returned transaction out point is not owned and depends on the lif...
BITCOINKERNEL_API const btck_BlockTreeEntry * btck_block_tree_entry_get_previous(const btck_BlockTreeEntry *block_tree_entry)
Returns the previous block tree entry in the tree, or null if the current block tree entry is the gen...
BITCOINKERNEL_API void btck_block_destroy(btck_Block *block)
uint8_t btck_Warning
Definition bitcoinkernel.h:314
struct btck_ChainstateManagerOptions btck_ChainstateManagerOptions
Definition bitcoinkernel.h:202
BITCOINKERNEL_API void btck_coin_destroy(btck_Coin *coin)
void(* btck_NotifyHeaderTip)(void *user_data, btck_SynchronizationState state, int64_t height, int64_t timestamp, int presync)
Definition bitcoinkernel.h:335
BITCOINKERNEL_API void btck_chainstate_manager_options_update_block_tree_db_in_memory(btck_ChainstateManagerOptions *chainstate_manager_options, int block_tree_db_in_memory)
Sets block tree db in memory in the options.
BITCOINKERNEL_API btck_PrecomputedTransactionData * btck_precomputed_transaction_data_copy(const btck_PrecomputedTransactionData *precomputed_txdata)
Copy precomputed transaction data.
BITCOINKERNEL_API btck_PrecomputedTransactionData * btck_precomputed_transaction_data_create(const btck_Transaction *tx_to, const btck_TransactionOutput **spent_outputs, size_t spent_outputs_len)
Create precomputed transaction data for script verification.
BITCOINKERNEL_API int btck_script_pubkey_verify(const btck_ScriptPubkey *script_pubkey, int64_t amount, const btck_Transaction *tx_to, const btck_PrecomputedTransactionData *precomputed_txdata, unsigned int input_index, btck_ScriptVerificationFlags flags, btck_ScriptVerifyStatus *status) 3)
Verify if the input at input_index of tx_to spends the script pubkey under the constraints specified ...
BITCOINKERNEL_API btck_BlockHeader * btck_block_header_create(const void *raw_block_header, size_t raw_block_header_len)
Create a btck_BlockHeader from serialized data.
BITCOINKERNEL_API void btck_context_options_set_chainparams(btck_ContextOptions *context_options, const btck_ChainParameters *chain_parameters) 2)
Sets the chain params for the context options. The context created with the options will be configure...
BITCOINKERNEL_API void btck_block_spent_outputs_destroy(btck_BlockSpentOutputs *block_spent_outputs)
BITCOINKERNEL_API int BITCOINKERNEL_API const btck_Chain * btck_chainstate_manager_get_active_chain(const btck_ChainstateManager *chainstate_manager)
Returns the best known currently active chain. Its lifetime is dependent on the chainstate manager....
BITCOINKERNEL_API int btck_chainstate_manager_options_set_wipe_dbs(btck_ChainstateManagerOptions *chainstate_manager_options, int wipe_block_tree_db, int wipe_chainstate_db)
Sets wipe db in the options. In combination with calling btck_chainstate_manager_import_blocks this t...
struct btck_ChainParameters btck_ChainParameters
Definition bitcoinkernel.h:152
struct btck_Block btck_Block
Definition bitcoinkernel.h:218
BITCOINKERNEL_API void btck_logging_set_level_category(btck_LogCategory category, btck_LogLevel level)
Set the log level of the global internal logger. This does not enable the selected categories....
BITCOINKERNEL_API size_t btck_transaction_count_inputs(const btck_Transaction *transaction)
Get the number of inputs of a transaction.
BITCOINKERNEL_API int btck_coin_is_coinbase(const btck_Coin *coin)
Returns whether the containing transaction was a coinbase.
BITCOINKERNEL_API const btck_BlockTreeEntry * btck_chainstate_manager_get_block_tree_entry_by_hash(const btck_ChainstateManager *chainstate_manager, const btck_BlockHash *block_hash) 2)
Retrieve a block tree entry by its block hash.
BITCOINKERNEL_API void btck_logging_disable()
This disables the global internal logger. No log messages will be buffered internally anymore once th...
void(* btck_NotifyWarningSet)(void *user_data, btck_Warning warning, const char *message, size_t message_len)
Definition bitcoinkernel.h:337
BITCOINKERNEL_API void btck_transaction_input_destroy(btck_TransactionInput *transaction_input)
BITCOINKERNEL_API void btck_context_options_set_notifications(btck_ContextOptions *context_options, btck_NotificationInterfaceCallbacks notifications)
Set the kernel notifications for the context options. The context created with the options will be co...
BITCOINKERNEL_API void btck_context_destroy(btck_Context *context)
BITCOINKERNEL_API btck_ContextOptions * btck_context_options_create()
BITCOINKERNEL_API uint32_t btck_block_header_get_nonce(const btck_BlockHeader *header)
Get the nonce from btck_BlockHeader.
BITCOINKERNEL_API btck_BlockHash * btck_block_header_get_hash(const btck_BlockHeader *header)
Get the btck_BlockHash.
BITCOINKERNEL_API uint32_t btck_block_header_get_timestamp(const btck_BlockHeader *header)
Get the timestamp from btck_BlockHeader.
void(* btck_NotifyFatalError)(void *user_data, const char *message, size_t message_len)
Definition bitcoinkernel.h:340
void(* btck_NotifyFlushError)(void *user_data, const char *message, size_t message_len)
Definition bitcoinkernel.h:339
struct btck_BlockHeader btck_BlockHeader
Definition bitcoinkernel.h:305
struct btck_Txid btck_Txid
Definition bitcoinkernel.h:300
BITCOINKERNEL_API size_t btck_transaction_count_outputs(const btck_Transaction *transaction)
Get the number of outputs of a transaction.
BITCOINKERNEL_API void btck_txid_to_bytes(const btck_Txid *txid, unsigned char output[32]) 2)
Serializes the txid to bytes.
struct btck_Transaction btck_Transaction
Definition bitcoinkernel.h:120
Definition bitcoinkernel.h:452
int always_print_category_levels
Prepend the log category and level to log messages.
Definition bitcoinkernel.h:457
int log_time_micros
Log timestamps in microsecond precision.
Definition bitcoinkernel.h:454
int log_threadnames
Prepend the name of the thread to log messages.
Definition bitcoinkernel.h:455
int log_sourcelocations
Prepend the source location to log messages.
Definition bitcoinkernel.h:456
int log_timestamps
Prepend a timestamp to log messages.
Definition bitcoinkernel.h:453
Definition bitcoinkernel.h:409
btck_NotifyWarningUnset warning_unset
A previous condition leading to the issuance of a warning is no longer given.
Definition bitcoinkernel.h:418
btck_NotifyBlockTip block_tip
The chain's tip was updated to the provided block entry.
Definition bitcoinkernel.h:414
btck_NotifyWarningSet warning_set
A warning issued by the kernel library during validation.
Definition bitcoinkernel.h:417
btck_NotifyFlushError flush_error
An error encountered when flushing data to disk.
Definition bitcoinkernel.h:419
btck_NotifyProgress progress
Reports on current block synchronization progress.
Definition bitcoinkernel.h:416
btck_NotifyFatalError fatal_error
An unrecoverable system error encountered by the library.
Definition bitcoinkernel.h:420
btck_DestroyCallback user_data_destroy
Frees the provided user data structure.
Definition bitcoinkernel.h:413
void * user_data
Definition bitcoinkernel.h:410
btck_NotifyHeaderTip header_tip
A new best block header was added.
Definition bitcoinkernel.h:415
Definition bitcoinkernel.h:384
btck_DestroyCallback user_data_destroy
Frees the provided user data structure.
Definition bitcoinkernel.h:388
btck_ValidationInterfaceBlockConnected block_connected
Called when a block is valid and has now been connected to the best chain.
Definition bitcoinkernel.h:393
btck_ValidationInterfaceBlockChecked block_checked
Definition bitcoinkernel.h:389
btck_ValidationInterfaceBlockDisconnected block_disconnected
Called during a re-org when a block has been removed from the best chain.
Definition bitcoinkernel.h:394
void * user_data
Definition bitcoinkernel.h:385
btck_ValidationInterfacePoWValidBlock pow_valid_block
Definition bitcoinkernel.h:391