From 17c02c4161df2707f3ba98fbc7b33968cee6678d Mon Sep 17 00:00:00 2001 From: Jordan Millar Date: Thu, 20 Jun 2024 12:17:01 +0200 Subject: [PATCH] The `PoolDistribution` data type needed to be updated with the consensus version of `PoolDistr` so that `decodePoolDistribution` would use the correct cbor instances Ledger has updated it's definition of `PoolDistr` however to avoid breakage consensus implemented a backwards compatible version of `PoolDistr` --- .../internal/Cardano/Api/LedgerState.hs | 22 ++++++++++++++++++- cardano-api/internal/Cardano/Api/Query.hs | 2 +- 2 files changed, 22 insertions(+), 2 deletions(-) diff --git a/cardano-api/internal/Cardano/Api/LedgerState.hs b/cardano-api/internal/Cardano/Api/LedgerState.hs index f44498f2b7..4ea2f5d5bd 100644 --- a/cardano-api/internal/Cardano/Api/LedgerState.hs +++ b/cardano-api/internal/Cardano/Api/LedgerState.hs @@ -131,6 +131,7 @@ import Cardano.Ledger.BaseTypes (Globals (..), Nonce, ProtVer (..), na import qualified Cardano.Ledger.BaseTypes as Ledger import qualified Cardano.Ledger.BHeaderView as Ledger import Cardano.Ledger.Binary (DecoderError) +import qualified Cardano.Ledger.Coin as SL import Cardano.Ledger.Conway.Genesis (ConwayGenesis (..)) import qualified Cardano.Ledger.Keys as SL import qualified Cardano.Ledger.PoolDistr as SL @@ -164,6 +165,7 @@ import qualified Ouroboros.Consensus.Protocol.Praos.Common as Consensus import Ouroboros.Consensus.Protocol.Praos.VRF (mkInputVRF, vrfLeaderValue) import qualified Ouroboros.Consensus.Shelley.HFEras as Shelley import qualified Ouroboros.Consensus.Shelley.Ledger.Ledger as Shelley +import qualified Ouroboros.Consensus.Shelley.Ledger.Query.Types as Consensus import Ouroboros.Consensus.Storage.Serialisation import Ouroboros.Consensus.TypeFamilyWrappers (WrapLedgerEvent (WrapLedgerEvent)) import Ouroboros.Network.Block (blockNo) @@ -1754,7 +1756,7 @@ currentEpochEligibleLeadershipSlots sbe sGen eInfo pp ptclState poolid (VrfSigni $ Slot.epochInfoRange eInfo currentEpoch setSnapshotPoolDistr <- - first LeaderErrDecodeProtocolEpochStateFailure . fmap (SL.unPoolDistr . unPoolDistr) + first LeaderErrDecodeProtocolEpochStateFailure . fmap (SL.unPoolDistr . fromConsensusPoolDistr . unPoolDistr) $ decodePoolDistribution sbe serPoolDistr let slotRangeOfInterest :: Core.EraPParams ledgerera => Core.PParams ledgerera -> Set SlotNo @@ -2046,3 +2048,21 @@ handleExceptions = liftEither <=< liftIO . runExceptT . flip catches handlers handlers = [ Handler $ throwError . FoldBlocksIOException , Handler $ throwError . FoldBlocksMuxError ] + +-- WARNING: Do NOT use this function anywhere else except in its current call sites. +-- This is a temporary work around. +fromConsensusPoolDistr :: Consensus.PoolDistr c -> SL.PoolDistr c +fromConsensusPoolDistr cpd = + SL.PoolDistr + { SL.unPoolDistr = Map.map toLedgerIndividualPoolStake $ Consensus.unPoolDistr cpd + , SL.pdTotalActiveStake = SL.CompactCoin 0 + } + +-- WARNING: Do NOT use this function anywhere else except in its current call sites. +-- This is a temporary work around. +toLedgerIndividualPoolStake :: Consensus.IndividualPoolStake c -> SL.IndividualPoolStake c +toLedgerIndividualPoolStake ips = SL.IndividualPoolStake { + SL.individualPoolStake = Consensus.individualPoolStake ips + , SL.individualPoolStakeVrf = Consensus.individualPoolStakeVrf ips + , SL.individualTotalPoolStake = SL.CompactCoin 0 + } diff --git a/cardano-api/internal/Cardano/Api/Query.hs b/cardano-api/internal/Cardano/Api/Query.hs index abfeb48fc7..8807f23d84 100644 --- a/cardano-api/internal/Cardano/Api/Query.hs +++ b/cardano-api/internal/Cardano/Api/Query.hs @@ -465,7 +465,7 @@ newtype SerialisedPoolDistribution era = SerialisedPoolDistribution (Serialised (Consensus.PoolDistr (Core.EraCrypto (ShelleyLedgerEra era)))) newtype PoolDistribution era = PoolDistribution - { unPoolDistr :: Shelley.PoolDistr (Core.EraCrypto (ShelleyLedgerEra era)) + { unPoolDistr :: Consensus.PoolDistr (Core.EraCrypto (ShelleyLedgerEra era)) } decodePoolDistribution