Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Synopsis
- data BlockValidationMode
- toTxValidationMode ∷ BlockValidationMode → TxValidationMode
- adoptedProtocolParameters ∷ State → ProtocolParameters
- updateBody ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ BodyEnvironment → BodyState → ABlock ByteString → m BodyState
- updateChainBlockOrBoundary ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ Config → ChainValidationState → ABlockOrBoundary ByteString → m ChainValidationState
- updateChainBoundary ∷ MonadError ChainValidationError m ⇒ ChainValidationState → ABoundaryBlock ByteString → m ChainValidationState
- epochTransition ∷ EpochEnvironment → State → SlotNumber → State
- headerIsValid ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ State → AHeader ByteString → m ()
- validateHeaderMatchesBody ∷ MonadError ProofValidationError m ⇒ AHeader ByteString → ABody ByteString → m ()
- updateBlock ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ Config → ChainValidationState → ABlock ByteString → m ChainValidationState
- data BodyState = BodyState {
- utxo ∷ !UTxO
- updateState ∷ !State
- delegationState ∷ !State
- data BodyEnvironment = BodyEnvironment {}
- data EpochEnvironment = EpochEnvironment {}
- data ChainValidationState = ChainValidationState {}
- initialChainValidationState ∷ MonadError Error m ⇒ Config → m ChainValidationState
- data ChainValidationError
- = ChainValidationBoundaryTooLarge
- | ChainValidationBlockAttributesTooLarge
- | ChainValidationBlockTooLarge Natural Natural
- | ChainValidationHeaderAttributesTooLarge
- | ChainValidationHeaderTooLarge Natural Natural
- | ChainValidationDelegationPayloadError Text
- | ChainValidationInvalidDelegation VerificationKey VerificationKey
- | ChainValidationGenesisHashMismatch GenesisHash GenesisHash
- | ChainValidationExpectedGenesisHash GenesisHash HeaderHash
- | ChainValidationExpectedHeaderHash HeaderHash GenesisHash
- | ChainValidationInvalidHash HeaderHash HeaderHash
- | ChainValidationMissingHash HeaderHash
- | ChainValidationUnexpectedGenesisHash HeaderHash
- | ChainValidationInvalidSignature BlockSignature
- | ChainValidationDelegationSchedulingError Error
- | ChainValidationProtocolMagicMismatch ProtocolMagicId ProtocolMagicId
- | ChainValidationSignatureLight
- | ChainValidationTooManyDelegations VerificationKey
- | ChainValidationUpdateError SlotNumber Error
- | ChainValidationUTxOValidationError UTxOValidationError
- | ChainValidationProofValidationError ProofValidationError
- newtype HeapSize a = HeapSize {}
- newtype UTxOSize = UTxOSize {}
- calcUTxOSize ∷ UTxO → (HeapSize UTxO, UTxOSize)
- foldUTxO ∷ Environment → UTxO → Stream (Of (ABlock ByteString)) (ExceptT ParseError ResIO) () → ExceptT Error (ReaderT ValidationMode ResIO) UTxO
- foldUTxOBlock ∷ Environment → UTxO → ABlock ByteString → ExceptT Error (ReaderT ValidationMode ResIO) UTxO
- data Proof = Proof {
- proofUTxO ∷ !TxProof
- proofSsc ∷ !SscProof
- proofDelegation ∷ !(Hash Payload)
- proofUpdate ∷ !Proof
- data ProofValidationError
- mkProof ∷ Body → Proof
- recoverProof ∷ ABody ByteString → Proof
- type Header = AHeader ()
- data AHeader a = AHeader {
- aHeaderProtocolMagicId ∷ !(Annotated ProtocolMagicId a)
- aHeaderPrevHash ∷ !(Annotated HeaderHash a)
- aHeaderSlot ∷ !(Annotated SlotNumber a)
- aHeaderDifficulty ∷ !(Annotated ChainDifficulty a)
- headerProtocolVersion ∷ !ProtocolVersion
- headerSoftwareVersion ∷ !SoftwareVersion
- aHeaderProof ∷ !(Annotated Proof a)
- headerGenesisKey ∷ !VerificationKey
- headerSignature ∷ !(ABlockSignature a)
- headerAnnotation ∷ !a
- headerExtraAnnotation ∷ !a
- mkHeader ∷ ProtocolMagicId → Either GenesisHash Header → EpochSlots → SlotNumber → SigningKey → Certificate → Body → ProtocolVersion → SoftwareVersion → Header
- mkHeaderExplicit ∷ ProtocolMagicId → HeaderHash → ChainDifficulty → EpochSlots → SlotNumber → SigningKey → Certificate → Body → ProtocolVersion → SoftwareVersion → Header
- headerProtocolMagicId ∷ AHeader a → ProtocolMagicId
- headerPrevHash ∷ AHeader a → HeaderHash
- headerProof ∷ AHeader a → Proof
- headerSlot ∷ AHeader a → SlotNumber
- headerIssuer ∷ AHeader a → VerificationKey
- headerLength ∷ AHeader ByteString → Natural
- headerDifficulty ∷ AHeader a → ChainDifficulty
- headerToSign ∷ EpochSlots → AHeader a → ToSign
- encCBORHeader ∷ EpochSlots → Header → Encoding
- encCBORHeaderSize ∷ Proxy EpochSlots → Proxy (AHeader a) → Size
- encCBORHeaderToHash ∷ EpochSlots → Header → Encoding
- decCBORAHeader ∷ EpochSlots → Decoder s (AHeader ByteSpan)
- decCBORHeader ∷ EpochSlots → Decoder s Header
- decCBORHeaderToHash ∷ EpochSlots → Decoder s (Maybe Header)
- wrapHeaderBytes ∷ ByteString → ByteString
- encCBORBlockVersions ∷ ProtocolVersion → SoftwareVersion → Encoding
- encCBORBlockVersionsSize ∷ Proxy ProtocolVersion → Proxy SoftwareVersion → Size
- renderHeader ∷ EpochSlots → Header → Builder
- data ABoundaryHeader a = UnsafeABoundaryHeader {}
- mkABoundaryHeader ∷ Either GenesisHash HeaderHash → Word64 → ChainDifficulty → a → ABoundaryHeader a
- encCBORABoundaryHeader ∷ ProtocolMagicId → ABoundaryHeader a → Encoding
- encCBORABoundaryHeaderSize ∷ Proxy ProtocolMagicId → Proxy (ABoundaryHeader a) → Size
- decCBORABoundaryHeader ∷ Decoder s (ABoundaryHeader ByteSpan)
- boundaryHeaderHashAnnotated ∷ ABoundaryHeader ByteString → HeaderHash
- wrapBoundaryBytes ∷ ByteString → ByteString
- type HeaderHash = Hash Header
- headerHashF ∷ Format r (HeaderHash → r)
- hashHeader ∷ EpochSlots → Header → HeaderHash
- headerHashAnnotated ∷ AHeader ByteString → HeaderHash
- genesisHeaderHash ∷ GenesisHash → HeaderHash
- type BlockSignature = ABlockSignature ()
- data ABlockSignature a = ABlockSignature {
- delegationCertificate ∷ !(ACertificate a)
- signature ∷ !(Signature ToSign)
- data ToSign = ToSign {}
- recoverSignedBytes ∷ EpochSlots → AHeader ByteString → Annotated ToSign ByteString
- decCBORBoundaryConsensusData ∷ Decoder s (Word64, ChainDifficulty)
- dropBoundaryExtraHeaderData ∷ Dropper s
- dropBoundaryExtraHeaderDataRetainGenesisTag ∷ Decoder s Bool
- dropBoundaryBody ∷ Dropper s
- dropBoundaryExtraBodyData ∷ Dropper s
- type Body = ABody ()
- pattern Body ∷ TxPayload → SscPayload → Payload → Payload → Body
- data ABody a = ABody {
- bodyTxPayload ∷ !(ATxPayload a)
- bodySscPayload ∷ !SscPayload
- bodyDlgPayload ∷ !(APayload a)
- bodyUpdatePayload ∷ !(APayload a)
- bodyTxs ∷ Body → [Tx]
- bodyWitnesses ∷ Body → [TxWitness]
- type Block = ABlock ()
- data ABlock a = ABlock {
- blockHeader ∷ AHeader a
- blockBody ∷ ABody a
- blockAnnotation ∷ a
- mkBlock ∷ ProtocolMagicId → ProtocolVersion → SoftwareVersion → Either GenesisHash Header → EpochSlots → SlotNumber → SigningKey → Certificate → Body → Block
- mkBlockExplicit ∷ ProtocolMagicId → ProtocolVersion → SoftwareVersion → HeaderHash → ChainDifficulty → EpochSlots → SlotNumber → SigningKey → Certificate → Body → Block
- blockHash ∷ EpochSlots → Block → HeaderHash
- blockHashAnnotated ∷ ABlock ByteString → HeaderHash
- blockAProtocolMagicId ∷ ABlock a → Annotated ProtocolMagicId a
- blockProtocolMagicId ∷ ABlock a → ProtocolMagicId
- blockPrevHash ∷ ABlock a → HeaderHash
- blockProof ∷ ABlock a → Proof
- blockSlot ∷ ABlock a → SlotNumber
- blockGenesisKey ∷ ABlock a → VerificationKey
- blockIssuer ∷ ABlock a → VerificationKey
- blockDifficulty ∷ ABlock a → ChainDifficulty
- blockToSign ∷ EpochSlots → ABlock a → ToSign
- blockSignature ∷ ABlock a → ABlockSignature a
- blockProtocolVersion ∷ ABlock a → ProtocolVersion
- blockSoftwareVersion ∷ ABlock a → SoftwareVersion
- blockTxPayload ∷ ABlock a → ATxPayload a
- blockSscPayload ∷ ABlock a → SscPayload
- blockDlgPayload ∷ ABlock a → APayload a
- blockUpdatePayload ∷ ABlock a → APayload a
- blockLength ∷ ABlock ByteString → Natural
- encCBORBlock ∷ EpochSlots → Block → Encoding
- decCBORABlock ∷ EpochSlots → Decoder s (ABlock ByteSpan)
- renderBlock ∷ EpochSlots → Block → Builder
- data ABlockOrBoundary a
- = ABOBBlock (ABlock a)
- | ABOBBoundary (ABoundaryBlock a)
- encCBORABOBBlock ∷ EpochSlots → ABlock a → Encoding
- decCBORABOBBlock ∷ EpochSlots → Decoder s (Maybe Block)
- decCBORABlockOrBoundary ∷ EpochSlots → Decoder s (ABlockOrBoundary ByteSpan)
- encCBORABlockOrBoundary ∷ ProtocolMagicId → EpochSlots → ABlockOrBoundary a → Encoding
- data ABoundaryBlock a = ABoundaryBlock {
- boundaryBlockLength ∷ !Int64
- boundaryHeader ∷ !(ABoundaryHeader a)
- boundaryBody ∷ !(ABoundaryBody a)
- boundaryAnnotation ∷ !a
- boundaryHashAnnotated ∷ ABoundaryBlock ByteString → HeaderHash
- decCBORABoundaryBlock ∷ Decoder s (ABoundaryBlock ByteSpan)
- encCBORABoundaryBlock ∷ ProtocolMagicId → ABoundaryBlock a → Encoding
- encCBORABOBBoundary ∷ ProtocolMagicId → ABoundaryBlock a → Encoding
- boundaryBlockSlot ∷ EpochSlots → Word64 → SlotNumber
- data ABoundaryBody a = ABoundaryBody {}
- data ABlockOrBoundaryHdr a
- = ABOBBlockHdr !(AHeader a)
- | ABOBBoundaryHdr !(ABoundaryHeader a)
- aBlockOrBoundaryHdr ∷ (AHeader a → b) → (ABoundaryHeader a → b) → ABlockOrBoundaryHdr a → b
- decCBORABlockOrBoundaryHdr ∷ EpochSlots → Decoder s (ABlockOrBoundaryHdr ByteSpan)
- encCBORABlockOrBoundaryHdr ∷ ABlockOrBoundaryHdr ByteString → Encoding
- encCBORABlockOrBoundaryHdrSize ∷ Proxy (ABlockOrBoundaryHdr a) → Size
- abobHdrFromBlock ∷ ABlockOrBoundary a → ABlockOrBoundaryHdr a
- abobHdrSlotNo ∷ EpochSlots → ABlockOrBoundaryHdr a → SlotNumber
- abobHdrChainDifficulty ∷ ABlockOrBoundaryHdr a → ChainDifficulty
- abobHdrHash ∷ ABlockOrBoundaryHdr ByteString → HeaderHash
- abobHdrPrevHash ∷ ABlockOrBoundaryHdr a → Maybe HeaderHash
Documentation
data BlockValidationMode Source #
Indicates what sort of block validation should be performed.
BlockValidation | Perform all block validations. |
NoBlockValidation | Perform no block validations. |
Instances
Show BlockValidationMode Source # | |
Defined in Cardano.Chain.Block.ValidationMode showsPrec ∷ Int → BlockValidationMode → ShowS # show ∷ BlockValidationMode → String # showList ∷ [BlockValidationMode] → ShowS # | |
Eq BlockValidationMode Source # | |
Defined in Cardano.Chain.Block.ValidationMode |
toTxValidationMode ∷ BlockValidationMode → TxValidationMode Source #
Translate a BlockValidationMode
to an appropriate TxValidationMode
.
adoptedProtocolParameters ∷ State → ProtocolParameters Source #
Adopted protocol parameters
updateBody ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ BodyEnvironment → BodyState → ABlock ByteString → m BodyState Source #
This is an implementation of the BBODY rule as per the chain specification.
Compared to updateChain
, this does not validate any header level checks,
nor does it carry out anything which might be considered part of the
protocol.
updateChainBlockOrBoundary ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ Config → ChainValidationState → ABlockOrBoundary ByteString → m ChainValidationState Source #
updateChainBoundary ∷ MonadError ChainValidationError m ⇒ ChainValidationState → ABoundaryBlock ByteString → m ChainValidationState Source #
epochTransition ∷ EpochEnvironment → State → SlotNumber → State Source #
Perform epoch transition if we have moved across the epoch boundary
We pass through to the update interface UPIEC rule, which adopts any confirmed proposals and cleans up the state. This corresponds to the EPOCH rules from the Byron chain specification.
headerIsValid ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ State → AHeader ByteString → m () Source #
This is an implementation of the headerIsValid function from the Byron chain specification
validateHeaderMatchesBody ∷ MonadError ProofValidationError m ⇒ AHeader ByteString → ABody ByteString → m () Source #
updateBlock ∷ (MonadError ChainValidationError m, MonadReader ValidationMode m) ⇒ Config → ChainValidationState → ABlock ByteString → m ChainValidationState Source #
This represents the CHAIN rule. It is intended more for use in tests than in a real implementation, which will want to invoke its constituent rules directly.
Note that this also updates the previous block hash, which would usually be done as part of the PBFT rule.
BodyState | |
|
data BodyEnvironment Source #
data EpochEnvironment Source #
data ChainValidationState Source #
ChainValidationState | |
|
Instances
initialChainValidationState ∷ MonadError Error m ⇒ Config → m ChainValidationState Source #
Create the state needed to validate the zeroth epoch of the chain. The zeroth epoch starts with a boundary block where the previous hash is the genesis hash.
data ChainValidationError Source #
ChainValidationBoundaryTooLarge | The size of an epoch boundary block exceeds the limit |
ChainValidationBlockAttributesTooLarge | The size of a block's attributes is non-zero |
ChainValidationBlockTooLarge Natural Natural | The size of a regular block exceeds the limit |
ChainValidationHeaderAttributesTooLarge | The size of a block header's attributes is non-zero |
ChainValidationHeaderTooLarge Natural Natural | The size of a block header exceeds the limit |
ChainValidationDelegationPayloadError Text | There is a problem with the delegation payload signature |
ChainValidationInvalidDelegation VerificationKey VerificationKey | The delegation used in the signature is not valid according to the ledger |
ChainValidationGenesisHashMismatch GenesisHash GenesisHash | Genesis hash mismatch |
ChainValidationExpectedGenesisHash GenesisHash HeaderHash | Expected GenesisHash but got HeaderHash |
ChainValidationExpectedHeaderHash HeaderHash GenesisHash | Expected HeaderHash but GenesisHash |
ChainValidationInvalidHash HeaderHash HeaderHash | The hash of the previous block does not match the value in the header |
ChainValidationMissingHash HeaderHash | The hash of the previous block is missing and should be given hash. |
ChainValidationUnexpectedGenesisHash HeaderHash | There should not be a hash of the previous but there is. |
ChainValidationInvalidSignature BlockSignature | The signature of the block is invalid |
ChainValidationDelegationSchedulingError Error | A delegation certificate failed validation in the ledger layer |
ChainValidationProtocolMagicMismatch ProtocolMagicId ProtocolMagicId | The |
ChainValidationSignatureLight | A block is using unsupported lightweight delegation |
ChainValidationTooManyDelegations VerificationKey | The delegator for this block has delegated in too many recent blocks |
ChainValidationUpdateError SlotNumber Error | Something failed to register in the update interface |
ChainValidationUTxOValidationError UTxOValidationError | A transaction failed validation in the ledger layer |
ChainValidationProofValidationError ProofValidationError | A payload proof did not match. |
Instances
Show ChainValidationError Source # | |
Defined in Cardano.Chain.Block.Validation showsPrec ∷ Int → ChainValidationError → ShowS # show ∷ ChainValidationError → String # showList ∷ [ChainValidationError] → ShowS # | |
Eq ChainValidationError Source # | |
Defined in Cardano.Chain.Block.Validation |
UTxO
Size of a heap value, in words
Number of entries in the UTxO
foldUTxO ∷ Environment → UTxO → Stream (Of (ABlock ByteString)) (ExceptT ParseError ResIO) () → ExceptT Error (ReaderT ValidationMode ResIO) UTxO Source #
Fold transaction validation over a Stream
of Block
s
foldUTxOBlock ∷ Environment → UTxO → ABlock ByteString → ExceptT Error (ReaderT ValidationMode ResIO) UTxO Source #
Fold updateUTxO
over the transactions in a single Block
Proof of everything contained in the payload
Proof | |
|
Instances
ToJSON Proof Source # | |
Generic Proof Source # | |
Show Proof Source # | |
FromCBOR Proof Source # | |
ToCBOR Proof Source # | |
DecCBOR Proof Source # | |
EncCBOR Proof Source # | |
NFData Proof Source # | |
Defined in Cardano.Chain.Block.Proof | |
Buildable Proof Source # | |
Defined in Cardano.Chain.Block.Proof | |
Eq Proof Source # | |
NoThunks Proof Source # | |
type Rep Proof Source # | |
Defined in Cardano.Chain.Block.Proof type Rep Proof = D1 ('MetaData "Proof" "Cardano.Chain.Block.Proof" "cardano-ledger-byron-1.0.2.0-inplace" 'False) (C1 ('MetaCons "Proof" 'PrefixI 'True) ((S1 ('MetaSel ('Just "proofUTxO") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 TxProof) :*: S1 ('MetaSel ('Just "proofSsc") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 SscProof)) :*: (S1 ('MetaSel ('Just "proofDelegation") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (Hash Payload)) :*: S1 ('MetaSel ('Just "proofUpdate") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 Proof)))) |
data ProofValidationError Source #
Error which can result from attempting to validate an invalid payload proof.
DelegationProofValidationError | The delegation payload proof did not match |
UTxOProofValidationError | The UTxO payload proof did not match |
UpdateProofValidationError | The update payload proof did not match |
Instances
Show ProofValidationError Source # | |
Defined in Cardano.Chain.Block.Proof showsPrec ∷ Int → ProofValidationError → ShowS # show ∷ ProofValidationError → String # showList ∷ [ProofValidationError] → ShowS # | |
Eq ProofValidationError Source # | |
Defined in Cardano.Chain.Block.Proof |
Header
AHeader | |
|
Instances
Functor AHeader Source # | |
ToJSON a ⇒ ToJSON (AHeader a) Source # | |
Generic (AHeader a) Source # | |
Show a ⇒ Show (AHeader a) Source # | |
Decoded (AHeader ByteString) Source # | |
Defined in Cardano.Chain.Block.Header type BaseType (AHeader ByteString) Source # | |
NFData a ⇒ NFData (AHeader a) Source # | |
Defined in Cardano.Chain.Block.Header | |
Buildable (WithEpochSlots Header) Source # | |
Defined in Cardano.Chain.Block.Header build ∷ WithEpochSlots Header → Builder Source # | |
Eq a ⇒ Eq (AHeader a) Source # | |
NoThunks a ⇒ NoThunks (AHeader a) Source # | |
type Rep (AHeader a) Source # | |
Defined in Cardano.Chain.Block.Header type Rep (AHeader a) = D1 ('MetaData "AHeader" "Cardano.Chain.Block.Header" "cardano-ledger-byron-1.0.2.0-inplace" 'False) (C1 ('MetaCons "AHeader" 'PrefixI 'True) (((S1 ('MetaSel ('Just "aHeaderProtocolMagicId") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (Annotated ProtocolMagicId a)) :*: S1 ('MetaSel ('Just "aHeaderPrevHash") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (Annotated HeaderHash a))) :*: (S1 ('MetaSel ('Just "aHeaderSlot") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (Annotated SlotNumber a)) :*: (S1 ('MetaSel ('Just "aHeaderDifficulty") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (Annotated ChainDifficulty a)) :*: S1 ('MetaSel ('Just "headerProtocolVersion") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 ProtocolVersion)))) :*: ((S1 ('MetaSel ('Just "headerSoftwareVersion") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 SoftwareVersion) :*: (S1 ('MetaSel ('Just "aHeaderProof") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (Annotated Proof a)) :*: S1 ('MetaSel ('Just "headerGenesisKey") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 VerificationKey))) :*: (S1 ('MetaSel ('Just "headerSignature") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (ABlockSignature a)) :*: (S1 ('MetaSel ('Just "headerAnnotation") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 a) :*: S1 ('MetaSel ('Just "headerExtraAnnotation") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 a)))))) | |
type BaseType (AHeader ByteString) Source # | |
Defined in Cardano.Chain.Block.Header |
Header Constructors
∷ ProtocolMagicId | |
→ Either GenesisHash Header | |
→ EpochSlots | Number of slots per epoch. This is needed to convert the slot number to
the legacy format used in |
→ SlotNumber | |
→ SigningKey | The |
→ Certificate | A certificate of delegation from a genesis key to the |
→ Body | |
→ ProtocolVersion | |
→ SoftwareVersion | |
→ Header |
Smart constructor for Header
∷ ProtocolMagicId | |
→ HeaderHash | Parent |
→ ChainDifficulty | |
→ EpochSlots | See |
→ SlotNumber | |
→ SigningKey | The |
→ Certificate | A certificate of delegation from a genesis key to the |
→ Body | |
→ ProtocolVersion | |
→ SoftwareVersion | |
→ Header |
Make a Header
for a given slot, with a given body, parent hash,
and difficulty. This takes care of some signing and consensus data.
Header Accessors
headerPrevHash ∷ AHeader a → HeaderHash Source #
headerProof ∷ AHeader a → Proof Source #
headerSlot ∷ AHeader a → SlotNumber Source #
headerToSign ∷ EpochSlots → AHeader a → ToSign Source #
Header Binary Serialization
encCBORHeader ∷ EpochSlots → Header → Encoding Source #
Encode a header, without taking in to account deprecated epoch boundary blocks.
encCBORHeaderSize ∷ Proxy EpochSlots → Proxy (AHeader a) → Size Source #
encCBORHeaderToHash ∷ EpochSlots → Header → Encoding Source #
Encode a Header
accounting for deprecated epoch boundary blocks
This encoding is only used when hashing the header for backwards compatibility, but should not be used when serializing a header within a block
decCBORAHeader ∷ EpochSlots → Decoder s (AHeader ByteSpan) Source #
decCBORHeader ∷ EpochSlots → Decoder s Header Source #
decCBORHeaderToHash ∷ EpochSlots → Decoder s (Maybe Header) Source #
wrapHeaderBytes ∷ ByteString → ByteString Source #
These bytes must be prepended when hashing raw boundary header data
In the Byron release, hashes were taken over a data type that was never directly serialized to the blockchain, so these magic bytes cannot be determined from the raw header data.
These bytes are from `encodeListLen 2 <> encCBOR (1 :: Word8)`
Header Formatting
renderHeader ∷ EpochSlots → Header → Builder Source #
Boundary Header
data ABoundaryHeader a Source #
Instances
mkABoundaryHeader ∷ Either GenesisHash HeaderHash → Word64 → ChainDifficulty → a → ABoundaryHeader a Source #
Smart constructor for ABoundaryHeader
Makes sure that the hash is forced.
encCBORABoundaryHeader ∷ ProtocolMagicId → ABoundaryHeader a → Encoding Source #
Encode from a boundary header with any annotation. This does not
necessarily invert decCBORBoundaryHeader
, because that decoder drops
information that this encoder replaces, such as the body proof (assumes
the body is empty) and the extra header data (sets it to empty map).
boundaryHeaderHashAnnotated ∷ ABoundaryHeader ByteString → HeaderHash Source #
Compute the hash of a boundary block header from its annotation.
It uses wrapBoundaryBytes
, for the hash must be computed on the header
bytes tagged with the CBOR list length and tag discriminator, which is
the encoding chosen by cardano-sl.
wrapBoundaryBytes ∷ ByteString → ByteString Source #
These bytes must be prepended when hashing raw boundary header data
In the Byron release, hashes were taken over a data type that was never directly serialized to the blockchain, so these magic bytes cannot be determined from the raw header data.
HeaderHash
headerHashF ∷ Format r (HeaderHash → r) Source #
Specialized formatter for HeaderHash
hashHeader ∷ EpochSlots → Header → HeaderHash Source #
Hash the serialised representation of a Header
For backwards compatibility we have to take the hash of the header
serialised with encCBORHeaderToHash
genesisHeaderHash ∷ GenesisHash → HeaderHash Source #
Extract the genesis hash and cast it into a header hash.
BlockSignature
type BlockSignature = ABlockSignature () Source #
data ABlockSignature a Source #
Signature of the Block
We use a heavyweight delegation scheme, so the signature has two parts:
- A delegation certificate from a genesis key to the block signer
- The actual signature over
ToSign
Instances
ToSign
Data to be signed in Block
ToSign | |
|
Instances
Generic ToSign Source # | |
Show ToSign Source # | |
FromCBOR ToSign Source # | |
ToCBOR ToSign Source # | |
DecCBOR ToSign Source # | |
EncCBOR ToSign Source # | |
Eq ToSign Source # | |
type Rep ToSign Source # | |
Defined in Cardano.Chain.Block.Header type Rep ToSign = D1 ('MetaData "ToSign" "Cardano.Chain.Block.Header" "cardano-ledger-byron-1.0.2.0-inplace" 'False) (C1 ('MetaCons "ToSign" 'PrefixI 'True) ((S1 ('MetaSel ('Just "tsHeaderHash") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 HeaderHash) :*: (S1 ('MetaSel ('Just "tsBodyProof") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 Proof) :*: S1 ('MetaSel ('Just "tsSlot") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 EpochAndSlotCount))) :*: (S1 ('MetaSel ('Just "tsDifficulty") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 ChainDifficulty) :*: (S1 ('MetaSel ('Just "tsProtocolVersion") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 ProtocolVersion) :*: S1 ('MetaSel ('Just "tsSoftwareVersion") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 SoftwareVersion))))) |
recoverSignedBytes ∷ EpochSlots → AHeader ByteString → Annotated ToSign ByteString Source #
Produces the ByteString that was signed in the block
dropBoundaryExtraHeaderDataRetainGenesisTag ∷ Decoder s Bool Source #
When starting a new chain in ourorobos-consensus, we often start from a non-zero epoch. This is done in order to ensure synchronisation between nodes - we assume that the chain started at some fixed point in the past (e.g. midnight) which all nodes can agree on despite different node start times. However, the standard deserialisation assumes that the genesis EBB is precisely that in epoch zero.
In order to successfully round-trip a genesis EBB in a non-zero epoch, then, we add a "magic" tag which indicates the presense of the genesis hash. The choice of 255 and the word Genesis is completely arbitrary, and only done to correspond with the matching encoder. This encoding will only ever be seen when processing blocks from a demo.
Body
consists of payloads of all block components
ABody | |
|
Instances
Functor ABody Source # | |
FromCBOR Body Source # | |
ToCBOR Body Source # | |
DecCBOR Body Source # | |
EncCBOR Body Source # | |
ToJSON a ⇒ ToJSON (ABody a) Source # | |
Generic (ABody a) Source # | |
Show a ⇒ Show (ABody a) Source # | |
FromCBOR (ABody ByteSpan) Source # | |
DecCBOR (ABody ByteSpan) Source # | |
NFData a ⇒ NFData (ABody a) Source # | |
Defined in Cardano.Chain.Block.Body | |
Eq a ⇒ Eq (ABody a) Source # | |
type Rep (ABody a) Source # | |
Defined in Cardano.Chain.Block.Body type Rep (ABody a) = D1 ('MetaData "ABody" "Cardano.Chain.Block.Body" "cardano-ledger-byron-1.0.2.0-inplace" 'False) (C1 ('MetaCons "ABody" 'PrefixI 'True) ((S1 ('MetaSel ('Just "bodyTxPayload") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (ATxPayload a)) :*: S1 ('MetaSel ('Just "bodySscPayload") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 SscPayload)) :*: (S1 ('MetaSel ('Just "bodyDlgPayload") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (APayload a)) :*: S1 ('MetaSel ('Just "bodyUpdatePayload") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 (APayload a))))) |
bodyWitnesses ∷ Body → [TxWitness] Source #
Block
ABlock | |
|
Instances
Functor ABlock Source # | |
ToJSON a ⇒ ToJSON (ABlock a) Source # | |
Generic (ABlock a) Source # | |
Show a ⇒ Show (ABlock a) Source # | |
NFData a ⇒ NFData (ABlock a) Source # | |
Defined in Cardano.Chain.Block.Block | |
Buildable (WithEpochSlots Block) Source # | |
Defined in Cardano.Chain.Block.Block build ∷ WithEpochSlots Block → Builder Source # | |
Eq a ⇒ Eq (ABlock a) Source # | |
type Rep (ABlock a) Source # | |
Defined in Cardano.Chain.Block.Block type Rep (ABlock a) = D1 ('MetaData "ABlock" "Cardano.Chain.Block.Block" "cardano-ledger-byron-1.0.2.0-inplace" 'False) (C1 ('MetaCons "ABlock" 'PrefixI 'True) (S1 ('MetaSel ('Just "blockHeader") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (AHeader a)) :*: (S1 ('MetaSel ('Just "blockBody") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (ABody a)) :*: S1 ('MetaSel ('Just "blockAnnotation") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 a)))) |
Block Constructors
∷ ProtocolMagicId | |
→ ProtocolVersion | |
→ SoftwareVersion | |
→ Either GenesisHash Header | |
→ EpochSlots | |
→ SlotNumber | |
→ SigningKey | The |
→ Certificate | A certificate of delegation from a genesis key to the |
→ Body | |
→ Block |
Smart constructor for Block
∷ ProtocolMagicId | |
→ ProtocolVersion | |
→ SoftwareVersion | |
→ HeaderHash | |
→ ChainDifficulty | |
→ EpochSlots | |
→ SlotNumber | |
→ SigningKey | The |
→ Certificate | A certificate of delegation from a genesis key to the |
→ Body | |
→ Block |
Block Accessors
blockHash ∷ EpochSlots → Block → HeaderHash Source #
blockPrevHash ∷ ABlock a → HeaderHash Source #
blockProof ∷ ABlock a → Proof Source #
blockSlot ∷ ABlock a → SlotNumber Source #
blockIssuer ∷ ABlock a → VerificationKey Source #
blockToSign ∷ EpochSlots → ABlock a → ToSign Source #
blockSignature ∷ ABlock a → ABlockSignature a Source #
blockTxPayload ∷ ABlock a → ATxPayload a Source #
blockSscPayload ∷ ABlock a → SscPayload Source #
blockDlgPayload ∷ ABlock a → APayload a Source #
blockUpdatePayload ∷ ABlock a → APayload a Source #
Block Binary Serialization
encCBORBlock ∷ EpochSlots → Block → Encoding Source #
Encode a block, given a number of slots-per-epoch.
Unlike encCBORABOBBlock
, this function does not take the deprecated epoch
boundary blocks into account.
decCBORABlock ∷ EpochSlots → Decoder s (ABlock ByteSpan) Source #
Block Formatting
renderBlock ∷ EpochSlots → Block → Builder Source #
ABlockOrBoundary
data ABlockOrBoundary a Source #
ABOBBlock (ABlock a) | |
ABOBBoundary (ABoundaryBlock a) |
Instances
encCBORABOBBlock ∷ EpochSlots → ABlock a → Encoding Source #
Encode a Block
accounting for deprecated epoch boundary blocks
decCBORABOBBlock ∷ EpochSlots → Decoder s (Maybe Block) Source #
Decode a Block
accounting for deprecated epoch boundary blocks
decCBORABlockOrBoundary ∷ EpochSlots → Decoder s (ABlockOrBoundary ByteSpan) Source #
Decode a Block
accounting for deprecated epoch boundary blocks
Previous versions of Cardano had an explicit boundary block between epochs.
A Block
was then represented as 'Either BoundaryBlock MainBlock'. We have
now deprecated these explicit boundary blocks, but we still need to decode
blocks in the old format. In the case that we find a boundary block, we
drop it using dropBoundaryBlock
and return a Nothing
.
ABoundaryBlock
data ABoundaryBlock a Source #
For a boundary block, we keep the header, body, and an annotation for the whole thing (commonly the bytes from which it was decoded).
ABoundaryBlock | |
|
Instances
boundaryHashAnnotated ∷ ABoundaryBlock ByteString → HeaderHash Source #
Extract the hash of a boundary block from its annotation.
encCBORABoundaryBlock ∷ ProtocolMagicId → ABoundaryBlock a → Encoding Source #
See note on encCBORABoundaryHeader
. This as well does not necessarily
invert the decoder decCBORABoundaryBlock
.
encCBORABOBBoundary ∷ ProtocolMagicId → ABoundaryBlock a → Encoding Source #
encCBORABoundaryBlock but with the list length and tag discriminator bytes.
∷ EpochSlots | |
→ Word64 | Epoch number |
→ SlotNumber |
Compute the slot number assigned to a boundary block
data ABoundaryBody a Source #
For boundary body data, we only keep an annotation. It's the body and extra body data.
Instances
ABlockOrBoundaryHdr
data ABlockOrBoundaryHdr a Source #
ABOBBlockHdr !(AHeader a) | |
ABOBBoundaryHdr !(ABoundaryHeader a) |
Instances
aBlockOrBoundaryHdr ∷ (AHeader a → b) → (ABoundaryHeader a → b) → ABlockOrBoundaryHdr a → b Source #
The analogue of either
encCBORABlockOrBoundaryHdr ∷ ABlockOrBoundaryHdr ByteString → Encoding Source #
Encoder for ABlockOrBoundaryHdr
which is using the annotation.
It is right inverse of decCBORAblockOrBoundaryHdr
.
TODO: add a round trip test, e.g.
decCBORABlockOrBoundaryHdr . encCBORABlockOrBoundaryHdr = id
which does not type check, but convey the meaning.
encCBORABlockOrBoundaryHdrSize ∷ Proxy (ABlockOrBoundaryHdr a) → Size Source #
The size computation is compatible with encCBORABlockOrBoundaryHdr
abobHdrSlotNo ∷ EpochSlots → ABlockOrBoundaryHdr a → SlotNumber Source #
Slot number of the header
NOTE: Epoch slot number calculation must match the one in applyBoundary
.