-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #775 from IntersectMBO/newhoggy/new-debug-log-epoc…
…h-state-command New `debug log-epoch-state` command
- Loading branch information
Showing
15 changed files
with
372 additions
and
119 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
{-# LANGUAGE GADTs #-} | ||
|
||
module Cardano.CLI.Commands | ||
( ClientCommand(..) | ||
) where | ||
|
||
import Cardano.CLI.Byron.Commands (ByronCommand) | ||
import Cardano.CLI.Commands.Debug | ||
import Cardano.CLI.Commands.Ping (PingCmd (..)) | ||
import Cardano.CLI.EraBased.Commands | ||
import Cardano.CLI.Legacy.Commands | ||
|
||
import Options.Applicative.Types (ParserInfo (..), ParserPrefs (..)) | ||
|
||
-- | Sub-commands of 'cardano-cli'. | ||
data ClientCommand = | ||
AnyEraCommand AnyEraCommand | ||
|
||
-- | Byron Related Commands | ||
| ByronCommand ByronCommand | ||
|
||
-- | Legacy shelley-based Commands | ||
| LegacyCmds LegacyCmds | ||
|
||
| CliPingCommand PingCmd | ||
| CliDebugCmds DebugCmds | ||
|
||
| forall a. Help ParserPrefs (ParserInfo a) | ||
| DisplayVersion |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
module Cardano.CLI.Commands.Debug | ||
( DebugCmds (..) | ||
) where | ||
|
||
import Cardano.CLI.Commands.Debug.LogEpochState | ||
|
||
newtype DebugCmds = | ||
DebugLogEpochStateCmd LogEpochStateCmdArgs |
18 changes: 18 additions & 0 deletions
18
cardano-cli/src/Cardano/CLI/Commands/Debug/LogEpochState.hs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
{-# LANGUAGE DataKinds #-} | ||
|
||
module Cardano.CLI.Commands.Debug.LogEpochState | ||
( LogEpochStateCmdArgs(..) | ||
, Configuration | ||
) where | ||
|
||
import Cardano.Api | ||
|
||
import Cardano.CLI.Orphans () | ||
|
||
data Configuration | ||
|
||
data LogEpochStateCmdArgs = LogEpochStateCmdArgs | ||
{ nodeSocketPath :: !SocketPath | ||
, configurationFile :: !(NodeConfigFile 'In) | ||
, outputFilePath :: !(File Configuration 'Out) | ||
} deriving Show |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
module Cardano.CLI.Commands.Ping | ||
( EndPoint(..) | ||
, PingCmd(..) | ||
) where | ||
|
||
import Data.Word | ||
|
||
data EndPoint = | ||
HostEndPoint String | ||
| UnixSockEndPoint String | ||
deriving (Eq, Show) | ||
|
||
data PingCmd = PingCmd | ||
{ pingCmdCount :: !Word32 | ||
, pingCmdEndPoint :: !EndPoint | ||
, pingCmdPort :: !String | ||
, pingCmdMagic :: !Word32 | ||
, pingCmdJson :: !Bool | ||
, pingCmdQuiet :: !Bool | ||
, pingOptsHandshakeQuery :: !Bool | ||
} deriving (Eq, Show) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
{-# LANGUAGE DataKinds #-} | ||
{-# LANGUAGE FlexibleContexts #-} | ||
{-# LANGUAGE GADTs #-} | ||
{-# LANGUAGE ScopedTypeVariables #-} | ||
|
||
{- HLINT ignore "Use <$>" -} | ||
{- HLINT ignore "Move brackets to avoid $" -} | ||
|
||
module Cardano.CLI.Options.Debug | ||
( parseDebugCmds | ||
) where | ||
|
||
import Cardano.Api.Shelley hiding (QueryInShelleyBasedEra (..)) | ||
|
||
import Cardano.CLI.Commands.Debug | ||
import Cardano.CLI.Commands.Debug.LogEpochState | ||
import Cardano.CLI.Environment | ||
import Cardano.CLI.EraBased.Options.Common | ||
|
||
import Data.Foldable | ||
import Options.Applicative hiding (help, str) | ||
import qualified Options.Applicative as Opt | ||
|
||
parseDebugCmds :: EnvCli -> Parser DebugCmds | ||
parseDebugCmds envCli = | ||
Opt.hsubparser $ mconcat | ||
[ Opt.metavar "debug commands" | ||
, Opt.commandGroup "debug commands" | ||
, Opt.command "debug" | ||
$ Opt.info (pDebugCmds envCli) | ||
$ Opt.progDesc "Debug commands" | ||
] | ||
|
||
pDebugCmds :: EnvCli -> Parser DebugCmds | ||
pDebugCmds envCli = | ||
asum | ||
[ subParser "log-epoch-state" | ||
(Opt.info pLogEpochStateCmdArgs $ Opt.progDesc "Log epoch state.") | ||
] | ||
where | ||
pLogEpochStateCmdArgs :: Parser DebugCmds | ||
pLogEpochStateCmdArgs = | ||
fmap DebugLogEpochStateCmd $ | ||
LogEpochStateCmdArgs | ||
<$> pSocketPath envCli | ||
<*> pNodeConfigurationFileIn | ||
<*> pFileOutDirection "out-file" "Output filepath of the log file. The log file format is line delimited JSON." | ||
|
||
pNodeConfigurationFileIn :: Parser (NodeConfigFile In) | ||
pNodeConfigurationFileIn = | ||
fmap File $ Opt.strOption $ mconcat | ||
[ Opt.long "node-configuration-file" | ||
, Opt.metavar "FILE" | ||
, Opt.help "Input filepath of the node configuration file." | ||
, Opt.completer (Opt.bashCompleter "file") | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
{-# LANGUAGE TypeApplications #-} | ||
|
||
{- HLINT ignore "Move brackets to avoid $" -} | ||
|
||
module Cardano.CLI.Options.Ping | ||
( parsePingCmd | ||
) where | ||
|
||
import Cardano.CLI.Commands.Ping | ||
import qualified Cardano.Network.Ping as CNP | ||
|
||
import Control.Applicative ((<|>)) | ||
import qualified Options.Applicative as Opt | ||
import qualified Prettyprinter as PP | ||
|
||
parsePingCmd :: Opt.Parser PingCmd | ||
parsePingCmd = Opt.hsubparser $ mconcat | ||
[ Opt.metavar "ping" | ||
, Opt.command "ping" $ Opt.info pPing $ Opt.progDescDoc $ Just $ mconcat | ||
[ PP.pretty @String "Ping a cardano node either using node-to-node or node-to-client protocol. " | ||
, PP.pretty @String "It negotiates a handshake and keeps sending keep alive messages." | ||
] | ||
] | ||
|
||
pHost :: Opt.Parser String | ||
pHost = | ||
Opt.strOption $ mconcat | ||
[ Opt.long "host" | ||
, Opt.short 'h' | ||
, Opt.metavar "HOST" | ||
, Opt.help "Hostname/IP, e.g. relay.iohk.example." | ||
] | ||
|
||
pUnixSocket :: Opt.Parser String | ||
pUnixSocket = | ||
Opt.strOption $ mconcat | ||
[ Opt.long "unixsock" | ||
, Opt.short 'u' | ||
, Opt.metavar "SOCKET" | ||
, Opt.help "Unix socket, e.g. file.socket." | ||
] | ||
|
||
pEndPoint :: Opt.Parser EndPoint | ||
pEndPoint = fmap HostEndPoint pHost <|> fmap UnixSockEndPoint pUnixSocket | ||
|
||
pPing :: Opt.Parser PingCmd | ||
pPing = PingCmd | ||
<$> ( Opt.option Opt.auto $ mconcat | ||
[ Opt.long "count" | ||
, Opt.short 'c' | ||
, Opt.metavar "COUNT" | ||
, Opt.help $ mconcat | ||
[ "Stop after sending count requests and receiving count responses. " | ||
, "If this option is not specified, ping will operate until interrupted. " | ||
] | ||
, Opt.value maxBound | ||
] | ||
) | ||
<*> pEndPoint | ||
<*> ( Opt.strOption $ mconcat | ||
[ Opt.long "port" | ||
, Opt.short 'p' | ||
, Opt.metavar "PORT" | ||
, Opt.help "Port number, e.g. 1234." | ||
, Opt.value "3001" | ||
] | ||
) | ||
<*> ( Opt.option Opt.auto $ mconcat | ||
[ Opt.long "magic" | ||
, Opt.short 'm' | ||
, Opt.metavar "MAGIC" | ||
, Opt.help "Network magic." | ||
, Opt.value CNP.mainnetMagic | ||
] | ||
) | ||
<*> ( Opt.switch $ mconcat | ||
[ Opt.long "json" | ||
, Opt.short 'j' | ||
, Opt.help "JSON output flag." | ||
] | ||
) | ||
<*> ( Opt.switch $ mconcat | ||
[ Opt.long "quiet" | ||
, Opt.short 'q' | ||
, Opt.help "Quiet flag, CSV/JSON only output" | ||
] | ||
) | ||
<*> ( Opt.switch $ mconcat | ||
[ Opt.long "query-versions" | ||
, Opt.short 'Q' | ||
, Opt.help "Query the supported protocol versions using the handshake protocol and terminate the connection." | ||
] | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
{-# OPTIONS_GHC -Wno-orphans #-} | ||
|
||
module Cardano.CLI.Orphans | ||
( | ||
) where | ||
|
||
import Cardano.Api | ||
|
||
import qualified Cardano.Ledger.Api as L | ||
import qualified Cardano.Ledger.Shelley.LedgerState as L | ||
|
||
import Data.Aeson | ||
|
||
-- TODO upstream this orphaned instance to the ledger | ||
instance (L.EraTxOut ledgerera, L.EraGov ledgerera) => ToJSON (L.NewEpochState ledgerera) where | ||
toJSON (L.NewEpochState nesEL nesBprev nesBCur nesEs nesRu nesPd _stashedAvvm)= | ||
object | ||
[ "currentEpoch" .= nesEL | ||
, "priorBlocks" .= nesBprev | ||
, "currentEpochBlocks" .= nesBCur | ||
, "currentEpochState" .= nesEs | ||
, "rewardUpdate" .= nesRu | ||
, "currentStakeDistribution" .= nesPd | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.