Skip to content

Commit

Permalink
Merge pull request #521 from IntersectMBO/mwojtowicz/query-ledger-pee…
Browse files Browse the repository at this point in the history
…r-snapshot

Added a new query for a snapshot of big ledger peers
  • Loading branch information
carbolymer authored Jan 14, 2025
2 parents b0547c1 + 6b76e3b commit c5cb6b2
Show file tree
Hide file tree
Showing 5 changed files with 43 additions and 1 deletion.
17 changes: 17 additions & 0 deletions cardano-api/internal/Cardano/Api/Query.hs
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ module Cardano.Api.Query
, LedgerState (..)
, getProgress
, getSlotForRelativeTime
, decodeBigLedgerPeerSnapshot

-- * Internal conversion functions
, toLedgerUTxO
Expand Down Expand Up @@ -112,6 +113,7 @@ import qualified Ouroboros.Consensus.Shelley.Ledger as Consensus
import qualified Ouroboros.Consensus.Shelley.Ledger.Query.Types as Consensus
import Ouroboros.Network.Block (Serialised (..))
import Ouroboros.Network.NodeToClient.Version (NodeToClientVersion (..))
import Ouroboros.Network.PeerSelection.LedgerPeers.Type (LedgerPeerSnapshot)
import Ouroboros.Network.Protocol.LocalStateQuery.Client (Some (..))

import Control.Monad.Trans.Except
Expand Down Expand Up @@ -300,6 +302,8 @@ data QueryInShelleyBasedEra era result where
QueryProposals
:: Set (L.GovActionId StandardCrypto)
-> QueryInShelleyBasedEra era (Seq (L.GovActionState (ShelleyLedgerEra era)))
QueryLedgerPeerSnapshot
:: QueryInShelleyBasedEra era (Serialised LedgerPeerSnapshot)

-- | Mapping for queries in Shelley-based eras returning minimal node-to-client protocol versions. More
-- information about queries versioning can be found:
Expand Down Expand Up @@ -333,6 +337,7 @@ instance NodeToClientVersionOf (QueryInShelleyBasedEra era result) where
nodeToClientVersionOf QueryCommitteeMembersState{} = NodeToClientV_16
nodeToClientVersionOf QueryStakeVoteDelegatees{} = NodeToClientV_16
nodeToClientVersionOf QueryProposals{} = NodeToClientV_17
nodeToClientVersionOf QueryLedgerPeerSnapshot = NodeToClientV_19

deriving instance Show (QueryInShelleyBasedEra era result)

Expand Down Expand Up @@ -473,6 +478,11 @@ decodeStakeSnapshot
-> Either DecoderError (StakeSnapshot era)
decodeStakeSnapshot (SerialisedStakeSnapshots (Serialised ls)) = StakeSnapshot <$> Plain.decodeFull ls

decodeBigLedgerPeerSnapshot
:: Serialised LedgerPeerSnapshot
-> Either (LBS.ByteString, DecoderError) LedgerPeerSnapshot
decodeBigLedgerPeerSnapshot (Serialised lps) = first (lps,) (Plain.decodeFull lps)

toShelleyAddrSet
:: CardanoEra era
-> Set AddressAny
Expand Down Expand Up @@ -718,6 +728,8 @@ toConsensusQueryShelleyBased sbe = \case
(consensusQueryInEraInMode era (Consensus.GetProposals govActs))
)
sbe
QueryLedgerPeerSnapshot ->
Some (consensusQueryInEraInMode era (Consensus.GetCBOR Consensus.GetBigLedgerPeerSnapshot))
where
era = toCardanoEra sbe

Expand Down Expand Up @@ -1004,6 +1016,11 @@ fromConsensusQueryResultShelleyBased sbe sbeQuery q' r' =
Consensus.GetProposals{} ->
r'
_ -> fromConsensusQueryResultMismatch
QueryLedgerPeerSnapshot{} ->
case q' of
Consensus.GetCBOR Consensus.GetBigLedgerPeerSnapshot ->
r'
_ -> fromConsensusQueryResultMismatch

-- | This should /only/ happen if we messed up the mapping in 'toConsensusQuery'
-- and 'fromConsensusQueryResult' so they are inconsistent with each other.
Expand Down
16 changes: 16 additions & 0 deletions cardano-api/internal/Cardano/Api/Query/Expr.hs
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ module Cardano.Api.Query.Expr
, queryStakeSnapshot
, querySystemStart
, queryUtxo
, queryLedgerPeerSnapshot
, L.MemberStatus (..)
, L.CommitteeMembersState (..)
, queryCommitteeMembersState
Expand Down Expand Up @@ -67,6 +68,8 @@ import Cardano.Ledger.SafeHash
import qualified Cardano.Ledger.Shelley.LedgerState as L
import Cardano.Slotting.Slot
import Ouroboros.Consensus.HardFork.Combinator.AcrossEras as Consensus
import Ouroboros.Network.Block (Serialised)
import Ouroboros.Network.PeerSelection.LedgerPeers (LedgerPeerSnapshot)

import Data.Map (Map)
import Data.Sequence (Seq)
Expand Down Expand Up @@ -136,6 +139,19 @@ queryDebugLedgerState
queryDebugLedgerState sbe =
queryExpr $ QueryInEra $ QueryInShelleyBasedEra sbe QueryDebugLedgerState

queryLedgerPeerSnapshot
:: ()
=> ShelleyBasedEra era
-> LocalStateQueryExpr
block
point
QueryInMode
r
IO
(Either UnsupportedNtcVersionError (Either EraMismatch (Serialised LedgerPeerSnapshot)))
queryLedgerPeerSnapshot sbe =
queryExpr $ QueryInEra $ QueryInShelleyBasedEra sbe QueryLedgerPeerSnapshot

queryEraHistory
:: ()
=> LocalStateQueryExpr block point QueryInMode r IO (Either UnsupportedNtcVersionError EraHistory)
Expand Down
9 changes: 8 additions & 1 deletion cardano-api/internal/Cardano/Api/ReexposeNetwork.hs
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
module Cardano.Api.ReexposeNetwork (Target (..), Serialised (..), SubmitResult (..)) where
module Cardano.Api.ReexposeNetwork
( LedgerPeerSnapshot (..)
, Target (..)
, Serialised (..)
, SubmitResult (..)
)
where

import Ouroboros.Network.Block (Serialised (..))
import Ouroboros.Network.PeerSelection.LedgerPeers.Type (LedgerPeerSnapshot (..))
import Ouroboros.Network.Protocol.LocalStateQuery.Type (Target (..))
import Ouroboros.Network.Protocol.LocalTxSubmission.Type (SubmitResult (..))
1 change: 1 addition & 0 deletions cardano-api/src/Cardano/Api.hs
Original file line number Diff line number Diff line change
Expand Up @@ -998,6 +998,7 @@ module Cardano.Api
, queryCurrentEpochState
, queryCurrentEra
, queryDebugLedgerState
, queryLedgerPeerSnapshot
, queryEpoch
, queryConstitutionHash
, queryEraHistory
Expand Down
1 change: 1 addition & 0 deletions cardano-api/src/Cardano/Api/Shelley.hs
Original file line number Diff line number Diff line change
Expand Up @@ -244,6 +244,7 @@ module Cardano.Api.Shelley
, StakeSnapshot (..)
, SerialisedStakeSnapshots (..)
, decodeStakeSnapshot
, decodeBigLedgerPeerSnapshot
, UTxO (..)
, AcquiringFailure (..)
, SystemStart (..)
Expand Down

0 comments on commit c5cb6b2

Please sign in to comment.