ouroboros-consensus-0.20.1.0: Consensus layer for the Ouroboros blockchain protocol
Safe HaskellSafe-Inferred
LanguageHaskell2010

Ouroboros.Consensus.HardFork.History.EraParams

Synopsis

API

data EraParams Source #

Parameters that can vary across hard forks

Instances

Instances details
Generic EraParams Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Associated Types

type Rep EraParamsTypeType #

Methods

fromEraParamsRep EraParams x #

toRep EraParams x → EraParams #

Show EraParams Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Methods

showsPrecIntEraParamsShowS #

showEraParamsString #

showList ∷ [EraParams] → ShowS #

Eq EraParams Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Methods

(==)EraParamsEraParamsBool #

(/=)EraParamsEraParamsBool #

NoThunks EraParams Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Given EraParamsFormatSerialise EraParams Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

type Rep EraParams Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

type Rep EraParams = D1 ('MetaData "EraParams" "Ouroboros.Consensus.HardFork.History.EraParams" "ouroboros-consensus-0.20.1.0-inplace" 'False) (C1 ('MetaCons "EraParams" 'PrefixI 'True) ((S1 ('MetaSel ('Just "eraEpochSize") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 EpochSize) :*: S1 ('MetaSel ('Just "eraSlotLength") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 SlotLength)) :*: (S1 ('MetaSel ('Just "eraSafeZone") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 SafeZone) :*: S1 ('MetaSel ('Just "eraGenesisWin") 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 GenesisWindow))))

data SafeZone Source #

Zone in which it is guaranteed that no hard fork can take place

Constructors

StandardSafeZone !Word64

Standard safe zone

We record

  • Number of slots from the tip of the ledger. This should be (at least) the number of slots in which we are guaranteed to have k blocks.
  • Optionally, an EpochNo before which no hard fork can take place.
UnsafeIndefiniteSafeZone

Pretend the transition to the next era will not take place.

This constructor is marked as unsafe because it effectively extends the safe zone of this era indefinitely into the future. This means that we might reach invalid conclusions when doing

  • slot to time conversions for blocks that are past the actual safe zone
  • time to slot conversions for the current time, when behind in syncing

This is safe when the code is simply not yet ready to transition to the next era, because in that case, we can be sure that blocks that come in are still from this era. It also means that we can always produce a block, no matter how far ahead of the current ledger we are.

If the code is ready for the transition, just awaiting an update proposal, then LowerBound can be used instead.

This constructor can be regarded as an " extreme " version of LowerBound, and can be used for similar reasons.

Instances

Instances details
Generic SafeZone Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Associated Types

type Rep SafeZoneTypeType #

Methods

fromSafeZoneRep SafeZone x #

toRep SafeZone x → SafeZone #

Show SafeZone Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Methods

showsPrecIntSafeZoneShowS #

showSafeZoneString #

showList ∷ [SafeZone] → ShowS #

Eq SafeZone Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Methods

(==)SafeZoneSafeZoneBool #

(/=)SafeZoneSafeZoneBool #

NoThunks SafeZone Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

Serialise SafeZone Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

type Rep SafeZone Source # 
Instance details

Defined in Ouroboros.Consensus.HardFork.History.EraParams

type Rep SafeZone = D1 ('MetaData "SafeZone" "Ouroboros.Consensus.HardFork.History.EraParams" "ouroboros-consensus-0.20.1.0-inplace" 'False) (C1 ('MetaCons "StandardSafeZone" 'PrefixI 'False) (S1 ('MetaSel ('NothingMaybe Symbol) 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 Word64)) :+: C1 ('MetaCons "UnsafeIndefiniteSafeZone" 'PrefixI 'False) (U1TypeType))

Defaults

defaultEraParamsSecurityParamSlotLengthEraParams Source #

Default EraParams

We set

  • epoch size to 10k slots
  • the safe zone to 2k slots
  • the upper bound to NoLowerBound

This is primarily useful for tests.

Serialisation

data EraParamsFormat Source #

Older versions are not aware of the Genesis window as part of EraParams, so we need to stay backwards-compatible for now. This type can be removed once mainnet is in Conway (as we can then always use the behavior of EraParamsWithGenesisWindow).