public class FullPrunedBlockChain extends AbstractBlockChain
A FullPrunedBlockChain works in conjunction with a FullPrunedBlockStore to verify all the rules of the
Bitcoin system, with the downside being a large cost in system resources. Fully verifying means all unspent
transaction outputs are stored. Once a transaction output is spent and that spend is buried deep enough, the data
related to it is deleted to ensure disk space usage doesn't grow forever. For this reason a pruning node cannot
serve the full block chain to other clients, but it nevertheless provides the same security guarantees as a regular
Satoshi client does.
AbstractBlockChain.NewBlockType| Modifier and Type | Field and Description |
|---|---|
protected FullPrunedBlockStore |
blockStore
Keeps a map of block hashes to StoredBlocks.
|
chainHead, FP_ESTIMATOR_ALPHA, FP_ESTIMATOR_BETA, lock, params| Constructor and Description |
|---|
FullPrunedBlockChain(Context context,
FullPrunedBlockStore blockStore)
Constructs a block chain connected to the given store.
|
FullPrunedBlockChain(Context context,
List<BlockChainListener> listeners,
FullPrunedBlockStore blockStore)
Constructs a block chain connected to the given list of wallets and a store.
|
FullPrunedBlockChain(Context context,
Wallet wallet,
FullPrunedBlockStore blockStore)
Constructs a block chain connected to the given wallet and store.
|
FullPrunedBlockChain(NetworkParameters params,
FullPrunedBlockStore blockStore)
|
FullPrunedBlockChain(NetworkParameters params,
List<BlockChainListener> listeners,
FullPrunedBlockStore blockStore)
|
FullPrunedBlockChain(NetworkParameters params,
Wallet wallet,
FullPrunedBlockStore blockStore)
Constructs a block chain connected to the given wallet and store.
|
| Modifier and Type | Method and Description |
|---|---|
protected StoredBlock |
addToBlockStore(StoredBlock storedPrev,
Block block)
Adds/updates the given
Block with the block store. |
protected StoredBlock |
addToBlockStore(StoredBlock storedPrev,
Block header,
TransactionOutputChanges txOutChanges)
Adds/updates the given
StoredBlock with the block store. |
protected TransactionOutputChanges |
connectTransactions(int height,
Block block)
Connect each transaction in block.transactions, verifying them as we go and removing spent outputs
If an error is encountered in a transaction, no changes should be made to the underlying BlockStore.
|
protected TransactionOutputChanges |
connectTransactions(StoredBlock newBlock)
Load newBlock from BlockStore and connect its transactions, returning changes to the set of unspent transactions.
|
protected void |
disconnectTransactions(StoredBlock oldBlock)
This is broken for blocks that do not pass BIP30, so all BIP30-failing blocks which are allowed to fail BIP30
must be checkpointed.
|
protected void |
doSetChainHead(StoredBlock chainHead)
Called before setting chain head in memory.
|
protected StoredBlock |
getStoredBlockInCurrentScope(Sha256Hash hash)
For a standard BlockChain, this should return blockStore.get(hash),
for a FullPrunedBlockChain blockStore.getOnceUndoableStoredBlock(hash)
|
protected void |
notSettingChainHead()
Called if we (possibly) previously called disconnectTransaction/connectTransactions,
but will not be calling preSetChainHead as a block failed verification.
|
protected void |
rollbackBlockStore(int height)
Rollback the block store to a given height.
|
void |
setRunScripts(boolean value)
Whether or not to run scripts whilst accepting blocks (i.e.
|
protected boolean |
shouldVerifyTransactions()
Whether or not we are maintaining a set of unspent outputs and are verifying all transactions.
|
add, add, addListener, addListener, addWallet, drainOrphanBlocks, estimateBlockTime, getBestChainHeight, getBlockStore, getChainHead, getFalsePositiveRate, getHeightFuture, getOrphanRoot, isOrphan, removeListener, removeWallet, resetFalsePositiveEstimate, setChainHead, trackFilteredTransactionsprotected final FullPrunedBlockStore blockStore
public FullPrunedBlockChain(Context context, Wallet wallet, FullPrunedBlockStore blockStore) throws BlockStoreException
Wallet you can construct
one from scratch, or you can deserialize a saved wallet from disk using
Wallet.loadFromFile(java.io.File, WalletExtension...)BlockStoreExceptionpublic FullPrunedBlockChain(NetworkParameters params, Wallet wallet, FullPrunedBlockStore blockStore) throws BlockStoreException
Wallet you can construct
one from scratch, or you can deserialize a saved wallet from disk using
Wallet.loadFromFile(java.io.File, WalletExtension...)BlockStoreExceptionpublic FullPrunedBlockChain(Context context, FullPrunedBlockStore blockStore) throws BlockStoreException
BlockStoreExceptionpublic FullPrunedBlockChain(NetworkParameters params, FullPrunedBlockStore blockStore) throws BlockStoreException
BlockStoreExceptionpublic FullPrunedBlockChain(Context context, List<BlockChainListener> listeners, FullPrunedBlockStore blockStore) throws BlockStoreException
BlockStoreExceptionpublic FullPrunedBlockChain(NetworkParameters params, List<BlockChainListener> listeners, FullPrunedBlockStore blockStore) throws BlockStoreException
BlockStoreExceptionprotected StoredBlock addToBlockStore(StoredBlock storedPrev, Block header, TransactionOutputChanges txOutChanges) throws BlockStoreException, VerificationException
AbstractBlockChainStoredBlock with the block store.
This version is used when the transactions have already been verified to properly spend txOutputChanges.addToBlockStore in class AbstractBlockChainstoredPrev - The StoredBlock which immediately precedes block.header - The StoredBlock to add/update.txOutChanges - The total sum of all changes made by this block to the set of open transaction outputs
(from a call to connectTransactions), if in fully verifying mode (null otherwise).StoredBlockBlockStoreExceptionVerificationExceptionprotected StoredBlock addToBlockStore(StoredBlock storedPrev, Block block) throws BlockStoreException, VerificationException
AbstractBlockChainBlock with the block store.
This version is used when the transactions have not been verified.addToBlockStore in class AbstractBlockChainstoredPrev - The StoredBlock which immediately precedes block.block - The Block to add/update.StoredBlockBlockStoreExceptionVerificationExceptionprotected void rollbackBlockStore(int height)
throws BlockStoreException
AbstractBlockChainBlockChain instances.rollbackBlockStore in class AbstractBlockChainBlockStoreException - if the operation fails or is unsupported.protected boolean shouldVerifyTransactions()
AbstractBlockChainshouldVerifyTransactions in class AbstractBlockChainpublic void setRunScripts(boolean value)
protected TransactionOutputChanges connectTransactions(int height, Block block) throws VerificationException, BlockStoreException
AbstractBlockChainconnectTransactions in class AbstractBlockChainVerificationException - if an attempt was made to spend an already-spent output, or if a transaction incorrectly solved an output script.BlockStoreException - if the block store had an underlying error.protected TransactionOutputChanges connectTransactions(StoredBlock newBlock) throws VerificationException, BlockStoreException, PrunedException
AbstractBlockChainconnectTransactions in class AbstractBlockChainVerificationException - if an attempt was made to spend an already-spent output, or if a transaction incorrectly solved an output script.BlockStoreException - if the block store had an underlying error or newBlock does not exist in the block store at all.PrunedException - if newBlock does not exist as a StoredUndoableBlock in the block store.protected void disconnectTransactions(StoredBlock oldBlock) throws PrunedException, BlockStoreException
disconnectTransactions in class AbstractBlockChainPrunedException - if block does not exist as a StoredUndoableBlock in the block store.BlockStoreException - if the block store had an underlying error or block does not exist in the block store at all.protected void doSetChainHead(StoredBlock chainHead) throws BlockStoreException
AbstractBlockChaindoSetChainHead in class AbstractBlockChainBlockStoreExceptionprotected void notSettingChainHead()
throws BlockStoreException
AbstractBlockChainnotSettingChainHead in class AbstractBlockChainBlockStoreExceptionprotected StoredBlock getStoredBlockInCurrentScope(Sha256Hash hash) throws BlockStoreException
AbstractBlockChaingetStoredBlockInCurrentScope in class AbstractBlockChainBlockStoreExceptionCopyright © 2015. All rights reserved.