From 0379444bf88bd98514520bc2ad71f0c43099ac94 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Hurlin?= Date: Mon, 6 Jan 2025 21:36:45 +0100 Subject: [PATCH 1/5] transaction id: add golden test --- cardano-cli/cardano-cli.cabal | 1 + .../Test/Golden/Shelley/Transaction/Id.hs | 23 +++++++++++++++++++ .../golden/shelley/transaction-id-flagless | 1 + .../files/input/shelley/tx-for-txid.json | 5 ++++ 4 files changed, 30 insertions(+) create mode 100644 cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs create mode 100644 cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id-flagless create mode 100644 cardano-cli/test/cardano-cli-golden/files/input/shelley/tx-for-txid.json diff --git a/cardano-cli/cardano-cli.cabal b/cardano-cli/cardano-cli.cabal index d70597a13b..609cbc2a7a 100644 --- a/cardano-cli/cardano-cli.cabal +++ b/cardano-cli/cardano-cli.cabal @@ -477,6 +477,7 @@ test-suite cardano-cli-golden Test.Golden.Shelley.Transaction.Build Test.Golden.Shelley.Transaction.CalculateMinFee Test.Golden.Shelley.Transaction.CreateWitness + Test.Golden.Shelley.Transaction.Id Test.Golden.Shelley.Transaction.Sign Test.Golden.TxView Test.Golden.Version diff --git a/cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs b/cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs new file mode 100644 index 0000000000..e502dca789 --- /dev/null +++ b/cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs @@ -0,0 +1,23 @@ +{-# LANGUAGE OverloadedStrings #-} + +module Test.Golden.Shelley.Transaction.Id where + +import Test.Cardano.CLI.Util + +import Hedgehog (Property) +import qualified Hedgehog.Extras.Test.Base as H +import qualified Hedgehog.Extras.Test.Golden as H + +{- HLINT ignore "Use camelCase" -} + +-- Execute this test with: +-- @cabal test cardano-cli-golden --test-options '-p "/golden shelley transaction id/"'@ +hprop_golden_shelley_transaction_id :: Property +hprop_golden_shelley_transaction_id = propertyOnce $ do + txFile <- noteInputFile "test/cardano-cli-golden/files/input/shelley/tx-for-txid.json" + + let baseCmd = ["latest", "transaction", "txid", "--tx-file", txFile] + + output1 <- execCardanoCLI baseCmd + goldenFile1 <- H.note "test/cardano-cli-golden/files/golden/shelley/transaction-id-flagless" + H.diffVsGoldenFile output1 goldenFile1 diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id-flagless b/cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id-flagless new file mode 100644 index 0000000000..aef6d681db --- /dev/null +++ b/cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id-flagless @@ -0,0 +1 @@ +345b88a38821ce10b1a19c41cbc9b48a55c26001cee4a7d2ad83fd9ddb157667 diff --git a/cardano-cli/test/cardano-cli-golden/files/input/shelley/tx-for-txid.json b/cardano-cli/test/cardano-cli-golden/files/input/shelley/tx-for-txid.json new file mode 100644 index 0000000000..3a1c0f6173 --- /dev/null +++ b/cardano-cli/test/cardano-cli-golden/files/input/shelley/tx-for-txid.json @@ -0,0 +1,5 @@ +{ + "type": "Unwitnessed Tx MaryEra", + "description": "Ledger Cddl Format", + "cborHex": "83a300818258202392d2b1200b5139fe555c81261697b29a8ccf561c5c783d46e78a479d977053000181825839016b837ca50316ee4e00033482ed128887d72c2bae5b0438d692dc1251b0c8b17595ebdb93c1f974be0a9b1ef26c474649d9c2ae766ed135cf1864020ca0f6" +} From 4b1b356d71277afc50ff4c580fc0ae1a4a8def20 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Hurlin?= Date: Tue, 7 Jan 2025 11:46:34 +0100 Subject: [PATCH 2/5] transaction id: add --output-json and --output-text flags --- .../CLI/EraBased/Commands/Transaction.hs | 3 ++- .../src/Cardano/CLI/EraBased/Options/Common.hs | 17 +++++++++++++++++ .../Cardano/CLI/EraBased/Options/Transaction.hs | 1 + .../src/Cardano/CLI/EraBased/Run/Transaction.hs | 12 +++++++++++- cardano-cli/src/Cardano/CLI/Types/Common.hs | 4 ++-- 5 files changed, 33 insertions(+), 4 deletions(-) diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs b/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs index de11edc37b..3405c6e415 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs @@ -243,8 +243,9 @@ newtype TransactionHashScriptDataCmdArgs = TransactionHashScriptDataCmdArgs } deriving Show -newtype TransactionTxIdCmdArgs = TransactionTxIdCmdArgs +data TransactionTxIdCmdArgs = TransactionTxIdCmdArgs { inputTxBodyOrTxFile :: InputTxBodyOrTxFile + , outputFormat :: !(Maybe OutputFormatJsonOrText) } deriving Show diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs b/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs index 5e945d52d1..208367fc1d 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs @@ -1723,6 +1723,23 @@ pOutputFormatJsonOrText kind = , Opt.long ("output-" <> flag_) ] +-- | @pTxIdOutputFormatJsonOrText kind@ is a parser to specify in which format +-- to write @transaction txid@'s output on standard output. +pTxIdOutputFormatJsonOrText :: Parser OutputFormatJsonOrText +pTxIdOutputFormatJsonOrText = + asum + [ make OutputFormatJson "JSON" "json" + , make OutputFormatText "TEXT" "text" + ] + where + default_ = OutputFormatText + make format desc flag_ = + Opt.flag' format $ + mconcat + [ Opt.help $ "Format output as " <> desc <> (if format == default_ then " (the default)." else ".") + , Opt.long ("output-" <> flag_) + ] + pTxViewOutputFormat :: Parser ViewOutputFormat pTxViewOutputFormat = pViewOutputFormat "transaction" diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs b/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs index 6b4a4d8e74..b8a3025f57 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs @@ -379,3 +379,4 @@ pTransactionId = fmap TransactionTxIdCmd $ TransactionTxIdCmdArgs <$> pInputTxOrTxBodyFile + <*> optional pTxIdOutputFormatJsonOrText diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs b/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs index b19c5f25b6..1c3ac5f253 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs @@ -1732,6 +1732,7 @@ runTransactionTxIdCmd runTransactionTxIdCmd Cmd.TransactionTxIdCmdArgs { inputTxBodyOrTxFile + , outputFormat } = do InAnyShelleyBasedEra _era txbody <- case inputTxBodyOrTxFile of @@ -1746,7 +1747,16 @@ runTransactionTxIdCmd InAnyShelleyBasedEra era tx <- lift (readFileTx txFile) & onLeft (left . TxCmdTextEnvCddlError) return . InAnyShelleyBasedEra era $ getTxBody tx - liftIO $ BS.putStrLn $ serialiseToRawBytesHex (getTxId txbody) + let txId = getTxId txbody + bsToWrite = serialiseToRawBytesHex txId + + liftIO $ + case outputFormat of + Just OutputFormatJson -> LBS.putStrLn $ Aeson.encode $ TxSubmissionResult txId + Just OutputFormatText -> BS.putStrLn bsToWrite + Nothing -> + -- Stay compatible with output when there was no --output-format flag + BS.putStrLn bsToWrite -- ---------------------------------------------------------------------------- -- Witness commands diff --git a/cardano-cli/src/Cardano/CLI/Types/Common.hs b/cardano-cli/src/Cardano/CLI/Types/Common.hs index 1bba0198c4..d23ee97f2b 100644 --- a/cardano-cli/src/Cardano/CLI/Types/Common.hs +++ b/cardano-cli/src/Cardano/CLI/Types/Common.hs @@ -545,7 +545,7 @@ data TxMempoolQuery data OutputFormatJsonOrText = OutputFormatJson | OutputFormatText - deriving Show + deriving (Eq, Show) data ViewOutputFormat = ViewOutputFormatJson @@ -686,7 +686,7 @@ data PotentiallyCheckedAnchor anchorType anchor deriving (Eq, Show) -- | Type used for serialization when printing the hash of a transaction --- after having submitted it. +-- after having submitted it. Also used for printing JSON output of "transaction txid". newtype TxSubmissionResult = TxSubmissionResult {txhash :: TxId} deriving (Show, Generic) From 02cf9d75692af3f59bc4d64e57361d7260cdbf09 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Hurlin?= Date: Tue, 7 Jan 2025 11:46:41 +0100 Subject: [PATCH 3/5] Adapt golden files --- cardano-cli/test/cardano-cli-golden/files/golden/help.cli | 7 +++++++ .../files/golden/help/allegra_transaction_txid.cli | 3 +++ .../files/golden/help/alonzo_transaction_txid.cli | 3 +++ .../files/golden/help/babbage_transaction_txid.cli | 3 +++ .../files/golden/help/conway_transaction_txid.cli | 3 +++ .../files/golden/help/latest_transaction_txid.cli | 3 +++ .../files/golden/help/mary_transaction_txid.cli | 3 +++ .../files/golden/help/shelley_transaction_txid.cli | 3 +++ 8 files changed, 28 insertions(+) diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help.cli index 78f7b97936..740827f9a1 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help.cli @@ -1994,6 +1994,7 @@ Usage: cardano-cli shelley transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. @@ -3045,6 +3046,7 @@ Usage: cardano-cli allegra transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. @@ -4086,6 +4088,7 @@ Usage: cardano-cli mary transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. @@ -5142,6 +5145,7 @@ Usage: cardano-cli alonzo transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. @@ -6498,6 +6502,7 @@ Usage: cardano-cli babbage transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. @@ -8519,6 +8524,7 @@ Usage: cardano-cli conway transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. @@ -10540,6 +10546,7 @@ Usage: cardano-cli latest transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help/allegra_transaction_txid.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help/allegra_transaction_txid.cli index 23af8c06f2..c64099a3a1 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help/allegra_transaction_txid.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help/allegra_transaction_txid.cli @@ -2,10 +2,13 @@ Usage: cardano-cli allegra transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. Available options: --tx-body-file FILEPATH Input filepath of the JSON TxBody. --tx-file FILEPATH Input filepath of the JSON Tx. + --output-json Format output as JSON. + --output-text Format output as TEXT (the default). -h,--help Show this help text diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help/alonzo_transaction_txid.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help/alonzo_transaction_txid.cli index 6dab1ac293..e55d5006b2 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help/alonzo_transaction_txid.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help/alonzo_transaction_txid.cli @@ -2,10 +2,13 @@ Usage: cardano-cli alonzo transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. Available options: --tx-body-file FILEPATH Input filepath of the JSON TxBody. --tx-file FILEPATH Input filepath of the JSON Tx. + --output-json Format output as JSON. + --output-text Format output as TEXT (the default). -h,--help Show this help text diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help/babbage_transaction_txid.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help/babbage_transaction_txid.cli index 4e1440b275..d545ef334a 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help/babbage_transaction_txid.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help/babbage_transaction_txid.cli @@ -2,10 +2,13 @@ Usage: cardano-cli babbage transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. Available options: --tx-body-file FILEPATH Input filepath of the JSON TxBody. --tx-file FILEPATH Input filepath of the JSON Tx. + --output-json Format output as JSON. + --output-text Format output as TEXT (the default). -h,--help Show this help text diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help/conway_transaction_txid.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help/conway_transaction_txid.cli index a4247b45b0..9e0b3d1fac 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help/conway_transaction_txid.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help/conway_transaction_txid.cli @@ -2,10 +2,13 @@ Usage: cardano-cli conway transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. Available options: --tx-body-file FILEPATH Input filepath of the JSON TxBody. --tx-file FILEPATH Input filepath of the JSON Tx. + --output-json Format output as JSON. + --output-text Format output as TEXT (the default). -h,--help Show this help text diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help/latest_transaction_txid.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help/latest_transaction_txid.cli index 7ed80315d8..3d928931ef 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help/latest_transaction_txid.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help/latest_transaction_txid.cli @@ -2,10 +2,13 @@ Usage: cardano-cli latest transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. Available options: --tx-body-file FILEPATH Input filepath of the JSON TxBody. --tx-file FILEPATH Input filepath of the JSON Tx. + --output-json Format output as JSON. + --output-text Format output as TEXT (the default). -h,--help Show this help text diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help/mary_transaction_txid.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help/mary_transaction_txid.cli index 70ec68a271..412461b2c1 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help/mary_transaction_txid.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help/mary_transaction_txid.cli @@ -2,10 +2,13 @@ Usage: cardano-cli mary transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. Available options: --tx-body-file FILEPATH Input filepath of the JSON TxBody. --tx-file FILEPATH Input filepath of the JSON Tx. + --output-json Format output as JSON. + --output-text Format output as TEXT (the default). -h,--help Show this help text diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/help/shelley_transaction_txid.cli b/cardano-cli/test/cardano-cli-golden/files/golden/help/shelley_transaction_txid.cli index 78e17f7991..bc37e52f09 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/help/shelley_transaction_txid.cli +++ b/cardano-cli/test/cardano-cli-golden/files/golden/help/shelley_transaction_txid.cli @@ -2,10 +2,13 @@ Usage: cardano-cli shelley transaction txid ( --tx-body-file FILEPATH | --tx-file FILEPATH ) + [--output-json | --output-text] Print a transaction identifier. Available options: --tx-body-file FILEPATH Input filepath of the JSON TxBody. --tx-file FILEPATH Input filepath of the JSON Tx. + --output-json Format output as JSON. + --output-text Format output as TEXT (the default). -h,--help Show this help text From f8d55ee5f1e451118806e5025ee6afea6e17f357 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Hurlin?= Date: Mon, 6 Jan 2025 21:45:11 +0100 Subject: [PATCH 4/5] transaction id: test new flags --- .../Test/Golden/Shelley/Transaction/Id.hs | 7 +++++++ .../files/golden/shelley/transaction-id.json | 1 + 2 files changed, 8 insertions(+) create mode 100644 cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id.json diff --git a/cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs b/cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs index e502dca789..7de4d39ad5 100644 --- a/cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs +++ b/cardano-cli/test/cardano-cli-golden/Test/Golden/Shelley/Transaction/Id.hs @@ -21,3 +21,10 @@ hprop_golden_shelley_transaction_id = propertyOnce $ do output1 <- execCardanoCLI baseCmd goldenFile1 <- H.note "test/cardano-cli-golden/files/golden/shelley/transaction-id-flagless" H.diffVsGoldenFile output1 goldenFile1 + + output2 <- execCardanoCLI $ baseCmd ++ ["--output-text"] + H.diffVsGoldenFile output2 goldenFile1 + + output3 <- execCardanoCLI $ baseCmd ++ ["--output-json"] + goldenFile2 <- H.note "test/cardano-cli-golden/files/golden/shelley/transaction-id.json" + H.diffVsGoldenFile output3 goldenFile2 diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id.json b/cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id.json new file mode 100644 index 0000000000..f0f491c300 --- /dev/null +++ b/cardano-cli/test/cardano-cli-golden/files/golden/shelley/transaction-id.json @@ -0,0 +1 @@ +{"txhash":"345b88a38821ce10b1a19c41cbc9b48a55c26001cee4a7d2ad83fd9ddb157667"} From b83358e5f6e16b5d8a85237b1770cab5b6338432 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Hurlin?= Date: Fri, 10 Jan 2025 11:30:27 +0100 Subject: [PATCH 5/5] transaction id: do not tie implementation with default of parser --- .../src/Cardano/CLI/EraBased/Commands/Transaction.hs | 2 +- cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs | 6 ++---- .../src/Cardano/CLI/EraBased/Options/Transaction.hs | 2 +- cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs | 8 ++------ 4 files changed, 6 insertions(+), 12 deletions(-) diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs b/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs index 3405c6e415..f6898c8c30 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Commands/Transaction.hs @@ -245,7 +245,7 @@ newtype TransactionHashScriptDataCmdArgs = TransactionHashScriptDataCmdArgs data TransactionTxIdCmdArgs = TransactionTxIdCmdArgs { inputTxBodyOrTxFile :: InputTxBodyOrTxFile - , outputFormat :: !(Maybe OutputFormatJsonOrText) + , outputFormat :: !OutputFormatJsonOrText } deriving Show diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs b/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs index 208367fc1d..4864b42784 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Options/Common.hs @@ -1727,10 +1727,8 @@ pOutputFormatJsonOrText kind = -- to write @transaction txid@'s output on standard output. pTxIdOutputFormatJsonOrText :: Parser OutputFormatJsonOrText pTxIdOutputFormatJsonOrText = - asum - [ make OutputFormatJson "JSON" "json" - , make OutputFormatText "TEXT" "text" - ] + asum [make OutputFormatJson "JSON" "json", make OutputFormatText "TEXT" "text"] + <|> pure default_ where default_ = OutputFormatText make format desc flag_ = diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs b/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs index b8a3025f57..9dc963024b 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Options/Transaction.hs @@ -379,4 +379,4 @@ pTransactionId = fmap TransactionTxIdCmd $ TransactionTxIdCmdArgs <$> pInputTxOrTxBodyFile - <*> optional pTxIdOutputFormatJsonOrText + <*> pTxIdOutputFormatJsonOrText diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs b/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs index 1c3ac5f253..7cc808e95e 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Run/Transaction.hs @@ -1748,15 +1748,11 @@ runTransactionTxIdCmd return . InAnyShelleyBasedEra era $ getTxBody tx let txId = getTxId txbody - bsToWrite = serialiseToRawBytesHex txId liftIO $ case outputFormat of - Just OutputFormatJson -> LBS.putStrLn $ Aeson.encode $ TxSubmissionResult txId - Just OutputFormatText -> BS.putStrLn bsToWrite - Nothing -> - -- Stay compatible with output when there was no --output-format flag - BS.putStrLn bsToWrite + OutputFormatJson -> LBS.putStrLn $ Aeson.encode $ TxSubmissionResult txId + OutputFormatText -> BS.putStrLn $ serialiseToRawBytesHex txId -- ---------------------------------------------------------------------------- -- Witness commands