Mavryk_raw_protocol_alpha.Block_header_repr
Representation of block headers.
type contents = {
payload_hash : Block_payload_hash.t;
payload_round : Round_repr.t;
seed_nonce_hash : Nonce_hash.t option;
proof_of_work_nonce : bytes;
per_block_votes : Per_block_votes_repr.per_block_votes;
}
type protocol_data = {
contents : contents;
signature : Mavryk_protocol_environment_alpha.Signature.t;
}
type t = {
shell : Mavryk_protocol_environment_alpha.Block_header.shell_header;
protocol_data : protocol_data;
}
type block_header = t
type shell_header = Mavryk_protocol_environment_alpha.Block_header.shell_header
val raw : block_header -> raw
val raw_encoding : raw Mavryk_protocol_environment_alpha.Data_encoding.t
val contents_encoding :
contents Mavryk_protocol_environment_alpha.Data_encoding.t
val unsigned_encoding :
(Mavryk_protocol_environment_alpha.Block_header.shell_header * contents)
Mavryk_protocol_environment_alpha.Data_encoding.t
val protocol_data_encoding :
protocol_data Mavryk_protocol_environment_alpha.Data_encoding.encoding
val shell_header_encoding :
shell_header Mavryk_protocol_environment_alpha.Data_encoding.encoding
val to_watermark :
block_watermark ->
Mavryk_protocol_environment_alpha.Signature.watermark
val of_watermark :
Mavryk_protocol_environment_alpha.Signature.watermark ->
block_watermark option
val hash : block_header -> Mavryk_protocol_environment_alpha.Block_hash.t
val hash_raw : raw -> Mavryk_protocol_environment_alpha.Block_hash.t
module Proof_of_work : sig ... end
Checks if the header that would be built from the given components is valid for the given difficulty. The signature is not passed as it is does not impact the proof-of-work stamp. The stamp is checked on the hash of a block header whose signature has been zeroed-out.
val check_timestamp :
Round_repr.Durations.t ->
timestamp:Mavryk_protocol_environment_alpha.Time.t ->
round:Round_repr.t ->
predecessor_timestamp:Mavryk_protocol_environment_alpha.Time.t ->
predecessor_round:Round_repr.t ->
unit Mavryk_protocol_environment_alpha.Error_monad.tzresult
check_timestamp ctxt timestamp round predecessor_timestamp
predecessor_round
verifies that the block's timestamp and round are coherent with the predecessor block's timestamp and round. Fails with an error if that is not the case.
val check_signature :
t ->
Mavryk_protocol_environment_alpha.Chain_id.t ->
Mavryk_protocol_environment_alpha.Signature.Public_key.t ->
unit Mavryk_protocol_environment_alpha.Error_monad.tzresult
val begin_validate_block_header :
block_header:t ->
chain_id:Mavryk_protocol_environment_alpha.Chain_id.t ->
predecessor_timestamp:Mavryk_protocol_environment_alpha.Time.t ->
predecessor_round:Round_repr.t ->
fitness:Fitness_repr.t ->
timestamp:Mavryk_protocol_environment_alpha.Time.t ->
delegate_pk:Mavryk_protocol_environment_alpha.Signature.public_key ->
round_durations:Round_repr.Durations.t ->
proof_of_work_threshold:int64 ->
expected_commitment:bool ->
unit Mavryk_protocol_environment_alpha.Error_monad.tzresult