Class Block
java.lang.Object
com.exonum.binding.core.blockchain.Block
public abstract class Block
extends java.lang.Object
Exonum block header data structure.
A block is essentially a list of transactions, which is a result of the consensus algorithm (thus authenticated by the supermajority of validators) and is applied atomically to the blockchain state.
This structure only contains the amount of transactions and the transactions root hash as well as other information, but not the transactions themselves.
- See Also:
Blockchain
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classBlock.Builder -
Constructor Summary
Constructors Constructor Description Block() -
Method Summary
Modifier and Type Method Description static Block.Builderbuilder()Creates a new block builder.static BlockfromMessage(Blockchain.Block blockMessage)Creates a block from the block message.abstract com.google.common.collect.ImmutableMap<java.lang.String,com.google.protobuf.ByteString>getAdditionalHeaders()Contains additional block headers of the block.abstract HashCodegetBlockHash()Returns the SHA-256 hash of this block.abstract HashCodegetErrorHash()Root hash of exceptions occurred in the block.abstract longgetHeight()Returns the height of this block which is a distance between the last block and the "genesis" block.abstract intgetNumTransactions()Number of transactions in this block.abstract HashCodegetPreviousBlockHash()Hash link to the previous block in the blockchain.abstract intgetProposerId()Identifier of the leader node which has proposed the block.abstract HashCodegetStateHash()Hash of the blockchain state after applying transactions in the block.abstract HashCodegetTxRootHash()Root hash of the Merkle tree of transactions in this block.inthashCode()booleanisEmpty()Returns true if this block is empty: contains no transactions.static BlockparseFrom(byte[] serializedBlock)Creates a block from the serialized block message.static com.google.gson.TypeAdapter<Block>typeAdapter(com.google.gson.Gson gson)Provides a Gson type adapter for this class.
-
Constructor Details
-
Block
public Block()
-
-
Method Details
-
getBlockHash
Returns the SHA-256 hash of this block. -
getProposerId
public abstract int getProposerId()Identifier of the leader node which has proposed the block. -
getHeight
public abstract long getHeight()Returns the height of this block which is a distance between the last block and the "genesis" block. Genesis block has 0 height. Therefore, the blockchain height is equal to the number of blocks plus one.The height also identifies each block in the blockchain.
-
isEmpty
public final boolean isEmpty()Returns true if this block is empty: contains no transactions. -
getNumTransactions
public abstract int getNumTransactions()Number of transactions in this block. -
getPreviousBlockHash
Hash link to the previous block in the blockchain. -
getTxRootHash
Root hash of the Merkle tree of transactions in this block. These transactions can be accessed withBlockchain.getBlockTransactions(Block). -
getStateHash
Hash of the blockchain state after applying transactions in the block.- See Also:
Schema
-
getErrorHash
Root hash of exceptions occurred in the block.- See Also:
Blockchain.getCallRecords(long)
-
getAdditionalHeaders
public abstract com.google.common.collect.ImmutableMap<java.lang.String,com.google.protobuf.ByteString> getAdditionalHeaders()Contains additional block headers of the block. The key is a block header; and the value is a header bytes value. -
hashCode
public int hashCode()- Overrides:
hashCodein classjava.lang.Object
-
typeAdapter
Provides a Gson type adapter for this class.- See Also:
CoreTypeAdapterFactory
-
fromMessage
Creates a block from the block message.- Parameters:
blockMessage- a block
-
parseFrom
Creates a block from the serialized block message.- Parameters:
serializedBlock- a serialized block message- Throws:
java.lang.IllegalArgumentException- if the block bytes are not a serializedBlockchain.Block
-
builder
Creates a new block builder.
-