Skip to content

Commit

Permalink
Add ledger-peer-snapshot to query command:
Browse files Browse the repository at this point in the history
This change introduces query subcommand ledger-peer-snapshot to
serialize a snapshot of big ledger peers from the tip of the current
chain.
  • Loading branch information
crocodile-dentist committed Jan 15, 2025
1 parent eecd898 commit 4b0bad5
Show file tree
Hide file tree
Showing 18 changed files with 387 additions and 1 deletion.
10 changes: 10 additions & 0 deletions cardano-cli/src/Cardano/CLI/EraBased/Commands/Query.hs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ module Cardano.CLI.EraBased.Commands.Query
, QueryDRepStakeDistributionCmdArgs (..)
, QuerySPOStakeDistributionCmdArgs (..)
, QueryTreasuryValueCmdArgs (..)
, QueryLedgerPeerSnapshotCmdArgs (..)
, renderQueryCmds
, IncludeStake (..)
)
Expand Down Expand Up @@ -69,6 +70,7 @@ data QueryCmds era
| QueryCommitteeMembersStateCmd !(QueryCommitteeMembersStateCmdArgs era)
| QueryTreasuryValueCmd !(QueryTreasuryValueCmdArgs era)
| QueryProposalsCmd !(QueryProposalsCmdArgs era)
| QueryLedgerPeerSnapshotCmd !QueryLedgerPeerSnapshotCmdArgs
deriving (Generic, Show)

-- | Fields that are common to most queries
Expand Down Expand Up @@ -140,6 +142,12 @@ data QueryLedgerStateCmdArgs = QueryLedgerStateCmdArgs
}
deriving (Generic, Show)

data QueryLedgerPeerSnapshotCmdArgs = QueryLedgerPeerSnapshotCmdArgs
{ commons :: !QueryCommons
, outFile :: !(Maybe (File () Out))
}
deriving (Generic, Show)

data QueryProtocolStateCmdArgs = QueryProtocolStateCmdArgs
{ commons :: !QueryCommons
, mOutFile :: !(Maybe (File () Out))
Expand Down Expand Up @@ -266,6 +274,8 @@ renderQueryCmds = \case
"query utxo"
QueryLedgerStateCmd{} ->
"query ledger-state"
QueryLedgerPeerSnapshotCmd{} ->
"query ledger-peer-snapshot"
QueryProtocolStateCmd{} ->
"query protocol-state"
QueryStakeSnapshotCmd{} ->
Expand Down
32 changes: 32 additions & 0 deletions cardano-cli/src/Cardano/CLI/EraBased/Options/Query.hs
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ pQueryCmdsTopLevel envCli =
, pPoolState envCli
, pTxMempool envCli
, pSlotNumber envCli
, pQueryLedgerPeerSnapshot envCli
]
i =
Opt.progDesc $
Expand Down Expand Up @@ -164,6 +165,19 @@ pSlotNumber envCli =
Opt.info (pQuerySlotNumberCmd ShelleyBasedEraConway envCli) $
Opt.progDesc "Query slot number for UTC timestamp"

pQueryLedgerPeerSnapshot :: EnvCli -> Parser (QueryCmds ConwayEra)
pQueryLedgerPeerSnapshot envCli =
subParser "ledger-peer-snapshot" $
Opt.info (pQueryLedgerPeerSnapshotCmd ShelleyBasedEraConway envCli) $
Opt.progDesc $
mconcat
[ "Dump the current snapshot of big ledger peers. "
, "These are the largest pools that cumulatively hold "
, "90% of total stake."
]
-- ^ TODO use bigLedgerPeerQuota from Ouroboros.Network.PeerSelection.LedgerPeers.Utils
-- which must be re-exposed thru cardano-api

pQueryCmds
:: ()
=> ShelleyBasedEra era
Expand Down Expand Up @@ -215,6 +229,17 @@ pQueryCmds era envCli =
mconcat
[ "Dump the current ledger state of the node (Ledger.NewEpochState -- advanced command)"
]
, Just $
subParser "ledger-peer-snapshot" $
Opt.info (pQueryLedgerPeerSnapshotCmd era envCli) $
Opt.progDesc $
mconcat
[ "Dump the current snapshot of ledger peers."
, "These are the largest pools that cumulatively hold "
, "90% of total stake."
]
-- ^ TODO use bigLedgerPeerQuota from Ouroboros.Network.PeerSelection.LedgerPeers.Utils
-- which must be re-exposed thru cardano-api
, Just $
subParser "protocol-state" $
Opt.info (pQueryProtocolStateCmd era envCli) $
Expand Down Expand Up @@ -327,6 +352,13 @@ pQueryLedgerStateCmd era envCli =
<$> pQueryCommons era envCli
<*> pMaybeOutputFile

pQueryLedgerPeerSnapshotCmd :: ShelleyBasedEra era -> EnvCli -> Parser (QueryCmds era)
pQueryLedgerPeerSnapshotCmd era envCli =
fmap QueryLedgerPeerSnapshotCmd $
QueryLedgerPeerSnapshotCmdArgs
<$> pQueryCommons era envCli
<*> pMaybeOutputFile

pQueryProtocolStateCmd :: ShelleyBasedEra era -> EnvCli -> Parser (QueryCmds era)
pQueryProtocolStateCmd era envCli =
fmap QueryProtocolStateCmd $
Expand Down
55 changes: 54 additions & 1 deletion cardano-cli/src/Cardano/CLI/EraBased/Run/Query.hs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ module Cardano.CLI.EraBased.Run.Query
, runQueryKesPeriodInfoCmd
, runQueryLeadershipScheduleCmd
, runQueryLedgerStateCmd
, runQueryLedgerPeerSnapshot
, runQueryPoolStateCmd
, runQueryProtocolParametersCmd
, runQueryProtocolStateCmd
Expand All @@ -43,7 +44,7 @@ import qualified Cardano.Api as Api
import qualified Cardano.Api.Consensus as Consensus
import Cardano.Api.Ledger (StandardCrypto, strictMaybeToMaybe)
import qualified Cardano.Api.Ledger as L
import Cardano.Api.Network (Serialised (..))
import Cardano.Api.Network (LedgerPeerSnapshot, Serialised (..))
import qualified Cardano.Api.Network as Consensus
import Cardano.Api.Shelley hiding (QueryInShelleyBasedEra (..))

Expand Down Expand Up @@ -103,6 +104,7 @@ runQueryCmds = \case
Cmd.QueryStakeDistributionCmd args -> runQueryStakeDistributionCmd args
Cmd.QueryStakeAddressInfoCmd args -> runQueryStakeAddressInfoCmd args
Cmd.QueryLedgerStateCmd args -> runQueryLedgerStateCmd args
Cmd.QueryLedgerPeerSnapshotCmd args -> runQueryLedgerPeerSnapshot args
Cmd.QueryStakeSnapshotCmd args -> runQueryStakeSnapshotCmd args
Cmd.QueryProtocolStateCmd args -> runQueryProtocolStateCmd args
Cmd.QueryUTxOCmd args -> runQueryUTxOCmd args
Expand Down Expand Up @@ -834,6 +836,41 @@ runQueryLedgerStateCmd
& onLeft (left . QueryCmdAcquireFailure)
& onLeft left

runQueryLedgerPeerSnapshot
:: ()
=> Cmd.QueryLedgerPeerSnapshotCmdArgs
-> ExceptT QueryCmdError IO ()
runQueryLedgerPeerSnapshot
Cmd.QueryLedgerPeerSnapshotCmdArgs
{ Cmd.commons =
Cmd.QueryCommons
{ Cmd.nodeSocketPath
, Cmd.consensusModeParams
, Cmd.networkId
, Cmd.target
}
, Cmd.outFile
} = do
let localNodeConnInfo = LocalNodeConnectInfo consensusModeParams networkId nodeSocketPath

join $
lift
( executeLocalStateQueryExpr localNodeConnInfo target $ runExceptT $ do
AnyCardanoEra era <-
lift queryCurrentEra
& onLeft (left . QueryCmdUnsupportedNtcVersion)

sbe <-
requireShelleyBasedEra era
& onNothing (left QueryCmdByronEra)

result <- easyRunQuery (queryLedgerPeerSnapshot sbe)

pure $ shelleyBasedEraConstraints sbe (writeLedgerPeerSnapshot outFile) result
)
& onLeft (left . QueryCmdAcquireFailure)
& onLeft left

runQueryProtocolStateCmd
:: ()
=> Cmd.QueryProtocolStateCmdArgs
Expand Down Expand Up @@ -1040,6 +1077,22 @@ writeLedgerState mOutFile qState@(SerialisedDebugLedgerState serLedgerState) =
LBS.writeFile fpath $
unSerialised serLedgerState

-- | Writes JSON-encoded big ledger peer snapshot
writeLedgerPeerSnapshot
:: Maybe (File () Out)
-> Serialised LedgerPeerSnapshot
-> ExceptT QueryCmdError IO ()
writeLedgerPeerSnapshot mOutPath serBigLedgerPeerSnapshot = do
case decodeBigLedgerPeerSnapshot serBigLedgerPeerSnapshot of
Left (bs, _decoderError) ->
firstExceptT QueryCmdHelpersError $ pPrintCBOR bs
Right snapshot ->
case mOutPath of
Nothing -> liftIO . LBS.putStrLn $ Aeson.encode snapshot
Just fpath ->
firstExceptT QueryCmdWriteFileError $
newExceptT . writeLazyByteStringFile fpath $ encodePretty snapshot

writeStakeSnapshots
:: forall era ledgerera
. ()
Expand Down
83 changes: 83 additions & 0 deletions cardano-cli/test/cardano-cli-golden/files/golden/help.cli
Original file line number Diff line number Diff line change
Expand Up @@ -1360,6 +1360,7 @@ Usage: cardano-cli shelley query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -1448,6 +1449,16 @@ Usage: cardano-cli shelley query ledger-state --socket-path SOCKET_PATH
Dump the current ledger state of the node (Ledger.NewEpochState -- advanced
command)

Usage: cardano-cli shelley query ledger-peer-snapshot --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
( --mainnet
| --testnet-magic NATURAL
)
[--out-file FILEPATH]

Dump the current snapshot of ledger peers

Usage: cardano-cli shelley query protocol-state --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
Expand Down Expand Up @@ -2412,6 +2423,7 @@ Usage: cardano-cli allegra query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -2500,6 +2512,16 @@ Usage: cardano-cli allegra query ledger-state --socket-path SOCKET_PATH
Dump the current ledger state of the node (Ledger.NewEpochState -- advanced
command)

Usage: cardano-cli allegra query ledger-peer-snapshot --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
( --mainnet
| --testnet-magic NATURAL
)
[--out-file FILEPATH]

Dump the current snapshot of ledger peers

Usage: cardano-cli allegra query protocol-state --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
Expand Down Expand Up @@ -3462,6 +3484,7 @@ Usage: cardano-cli mary query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -3550,6 +3573,16 @@ Usage: cardano-cli mary query ledger-state --socket-path SOCKET_PATH
Dump the current ledger state of the node (Ledger.NewEpochState -- advanced
command)

Usage: cardano-cli mary query ledger-peer-snapshot --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
( --mainnet
| --testnet-magic NATURAL
)
[--out-file FILEPATH]

Dump the current snapshot of ledger peers

Usage: cardano-cli mary query protocol-state --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
Expand Down Expand Up @@ -4511,6 +4544,7 @@ Usage: cardano-cli alonzo query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -4599,6 +4633,16 @@ Usage: cardano-cli alonzo query ledger-state --socket-path SOCKET_PATH
Dump the current ledger state of the node (Ledger.NewEpochState -- advanced
command)

Usage: cardano-cli alonzo query ledger-peer-snapshot --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
( --mainnet
| --testnet-magic NATURAL
)
[--out-file FILEPATH]

Dump the current snapshot of ledger peers

Usage: cardano-cli alonzo query protocol-state --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
Expand Down Expand Up @@ -5609,6 +5653,7 @@ Usage: cardano-cli babbage query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -5697,6 +5742,16 @@ Usage: cardano-cli babbage query ledger-state --socket-path SOCKET_PATH
Dump the current ledger state of the node (Ledger.NewEpochState -- advanced
command)

Usage: cardano-cli babbage query ledger-peer-snapshot --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
( --mainnet
| --testnet-magic NATURAL
)
[--out-file FILEPATH]

Dump the current snapshot of ledger peers

Usage: cardano-cli babbage query protocol-state --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
Expand Down Expand Up @@ -7248,6 +7303,7 @@ Usage: cardano-cli conway query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -7356,6 +7412,19 @@ Usage: cardano-cli conway query ledger-state --socket-path SOCKET_PATH
Dump the current ledger state of the node (Ledger.NewEpochState -- advanced
command)

Usage: cardano-cli conway query ledger-peer-snapshot --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
( --mainnet
| --testnet-magic NATURAL
)
[ --volatile-tip
| --immutable-tip
]
[--out-file FILEPATH]

Dump the current snapshot of ledger peers

Usage: cardano-cli conway query protocol-state --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
Expand Down Expand Up @@ -9270,6 +9339,7 @@ Usage: cardano-cli latest query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -9378,6 +9448,19 @@ Usage: cardano-cli latest query ledger-state --socket-path SOCKET_PATH
Dump the current ledger state of the node (Ledger.NewEpochState -- advanced
command)

Usage: cardano-cli latest query ledger-peer-snapshot --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
( --mainnet
| --testnet-magic NATURAL
)
[ --volatile-tip
| --immutable-tip
]
[--out-file FILEPATH]

Dump the current snapshot of ledger peers

Usage: cardano-cli latest query protocol-state --socket-path SOCKET_PATH
[--cardano-mode
[--epoch-slots SLOTS]]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ Usage: cardano-cli allegra query
| stake-address-info
| utxo
| ledger-state
| ledger-peer-snapshot
| protocol-state
| stake-snapshot
| leadership-schedule
Expand Down Expand Up @@ -33,6 +34,7 @@ Available commands:
address or the whole.
ledger-state Dump the current ledger state of the node
(Ledger.NewEpochState -- advanced command)
ledger-peer-snapshot Dump the current snapshot of ledger peers
protocol-state Dump the current protocol state of the node
(Ledger.ChainDepState -- advanced command)
stake-snapshot Obtain the three stake snapshots for a pool, plus the
Expand Down
Loading

0 comments on commit 4b0bad5

Please sign in to comment.