From a112454767ed1212d1c9bb66034727b9f56fa6b0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Hurlin?= Date: Tue, 31 Oct 2023 15:59:07 +0100 Subject: [PATCH] Extended to non-extended key: write description field in all cases --- .../src/Cardano/CLI/EraBased/Run/Address.hs | 11 +++--- .../src/Cardano/CLI/EraBased/Run/Genesis.hs | 11 +++--- .../Cardano/CLI/EraBased/Run/Governance.hs | 2 +- .../src/Cardano/CLI/EraBased/Run/Key.hs | 36 +++++++++++++------ .../Cardano/CLI/EraBased/Run/StakeAddress.hs | 4 +-- .../non-extended-shelley.000.vkey | 2 +- .../non-extended-stake.000.vkey | 2 +- 7 files changed, 41 insertions(+), 27 deletions(-) diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Run/Address.hs b/cardano-cli/src/Cardano/CLI/EraBased/Run/Address.hs index 63c70f1801..d3ba338a5f 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Run/Address.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Run/Address.hs @@ -18,6 +18,7 @@ import Cardano.Api.Shelley import Cardano.CLI.EraBased.Commands.Address import Cardano.CLI.EraBased.Run.Address.Info +import qualified Cardano.CLI.EraBased.Run.Key as Key import Cardano.CLI.Read import Cardano.CLI.Types.Common import Cardano.CLI.Types.Errors.AddressCmdError @@ -105,16 +106,15 @@ writePaymentKeyFiles fmt vkeyPath skeyPath vkey skey = do KeyOutputFormatTextEnvelope -> newExceptT $ writeLazyByteStringFile vkeyPath - $ textEnvelopeToJSON (Just vkeyDesc) vkey + $ textEnvelopeToJSON (Just Key.paymentVkeyDesc) vkey KeyOutputFormatBech32 -> newExceptT $ writeTextFile vkeyPath $ serialiseToBech32 vkey where - skeyDesc, vkeyDesc :: TextEnvelopeDescr + skeyDesc :: TextEnvelopeDescr skeyDesc = "Payment Signing Key" - vkeyDesc = "Payment Verification Key" writeByronPaymentKeyFiles :: Key keyrole @@ -127,11 +127,10 @@ writeByronPaymentKeyFiles vkeyPath skeyPath vkey skey = do firstExceptT AddressCmdWriteFileError $ do -- No bech32 encoding for Byron keys newExceptT $ writeLazyByteStringFile skeyPath $ textEnvelopeToJSON (Just skeyDesc) skey - newExceptT $ writeLazyByteStringFile vkeyPath $ textEnvelopeToJSON (Just vkeyDesc) vkey + newExceptT $ writeLazyByteStringFile vkeyPath $ textEnvelopeToJSON (Just Key.paymentVkeyDesc) vkey where - skeyDesc, vkeyDesc :: TextEnvelopeDescr + skeyDesc :: TextEnvelopeDescr skeyDesc = "Payment Signing Key" - vkeyDesc = "Payment Verification Key" runAddressKeyHashCmd :: VerificationKeyTextOrFile -> Maybe (File () Out) diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Run/Genesis.hs b/cardano-cli/src/Cardano/CLI/EraBased/Run/Genesis.hs index 4e31a50cf9..a1d586a9ad 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Run/Genesis.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Run/Genesis.hs @@ -57,6 +57,7 @@ import Cardano.CLI.Byron.Delegation import Cardano.CLI.Byron.Genesis as Byron import qualified Cardano.CLI.Byron.Key as Byron import Cardano.CLI.EraBased.Commands.Genesis as Cmd +import qualified Cardano.CLI.EraBased.Run.Key as Key import Cardano.CLI.EraBased.Run.Node (runNodeIssueOpCertCmd, runNodeKeyGenColdCmd, runNodeKeyGenKesCmd, runNodeKeyGenVrfCmd) import Cardano.CLI.EraBased.Run.StakeAddress (runStakeAddressKeyGenCmd) @@ -172,11 +173,10 @@ runGenesisKeyGenGenesisCmd firstExceptT GenesisCmdGenesisFileError . newExceptT $ writeLazyByteStringFile verificationKeyPath - $ textEnvelopeToJSON (Just vkeyDesc) vkey + $ textEnvelopeToJSON (Just Key.genesisVkeyDesc) vkey where - skeyDesc, vkeyDesc :: TextEnvelopeDescr + skeyDesc :: TextEnvelopeDescr skeyDesc = "Genesis Signing Key" - vkeyDesc = "Genesis Verification Key" runGenesisKeyGenDelegateCmd @@ -197,7 +197,7 @@ runGenesisKeyGenDelegateCmd firstExceptT GenesisCmdGenesisFileError . newExceptT $ writeLazyByteStringFile verificationKeyPath - $ textEnvelopeToJSON (Just vkeyDesc) vkey + $ textEnvelopeToJSON (Just Key.genesisVkeyDelegateDesc) vkey firstExceptT GenesisCmdGenesisFileError . newExceptT $ writeLazyByteStringFile opCertCounterPath @@ -206,9 +206,8 @@ runGenesisKeyGenDelegateCmd initialCounter (castVerificationKey vkey) -- Cast to a 'StakePoolKey' where - skeyDesc, vkeyDesc, certCtrDesc :: TextEnvelopeDescr + skeyDesc, certCtrDesc :: TextEnvelopeDescr skeyDesc = "Genesis delegate operator key" - vkeyDesc = "Genesis delegate operator key" certCtrDesc = "Next certificate issue number: " <> fromString (show initialCounter) diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Run/Governance.hs b/cardano-cli/src/Cardano/CLI/EraBased/Run/Governance.hs index a0306836a9..16d8257cdd 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Run/Governance.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Run/Governance.hs @@ -91,7 +91,7 @@ runGovernanceDRepKeyGen _w vkeyPath skeyPath = firstExceptT GovernanceCmdWriteFi skey <- liftIO $ generateSigningKey AsDRepKey let vkey = getVerificationKey skey newExceptT $ writeLazyByteStringFile skeyPath (textEnvelopeToJSON (Just skeyDesc) skey) - newExceptT $ writeLazyByteStringFile vkeyPath (textEnvelopeToJSON (Just Key.drepKeyEnvelopeDescr) vkey) + newExceptT $ writeLazyByteStringFile vkeyPath (textEnvelopeToJSON (Just Key.drepVkeyDesc) vkey) where skeyDesc :: TextEnvelopeDescr skeyDesc = "Delegate Representative Signing Key" diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Run/Key.hs b/cardano-cli/src/Cardano/CLI/EraBased/Run/Key.hs index f9c77ae11b..a04f97c81b 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Run/Key.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Run/Key.hs @@ -18,7 +18,11 @@ module Cardano.CLI.EraBased.Run.Key , runNonExtendedKeyCmd , runVerificationKeyCmd - , drepKeyEnvelopeDescr + , drepVkeyDesc + , genesisVkeyDesc + , genesisVkeyDelegateDesc + , stakeVkeyDesc + , paymentVkeyDesc -- * Exports for testing , decodeBech32 @@ -56,8 +60,20 @@ import qualified Data.Text as Text import qualified Data.Text.Encoding as Text import System.Exit (exitFailure) -drepKeyEnvelopeDescr :: TextEnvelopeDescr -drepKeyEnvelopeDescr = "Delegate Representative Verification Key" +drepVkeyDesc :: TextEnvelopeDescr +drepVkeyDesc = "Delegate Representative Verification Key" + +genesisVkeyDesc :: TextEnvelopeDescr +genesisVkeyDesc = "Genesis Verification Key" + +genesisVkeyDelegateDesc :: TextEnvelopeDescr +genesisVkeyDelegateDesc = "Genesis delegate operator key" + +paymentVkeyDesc :: TextEnvelopeDescr +paymentVkeyDesc = "Payment Verification Key" + +stakeVkeyDesc :: TextEnvelopeDescr +stakeVkeyDesc = "Stake Verification Key" runKeyCmds :: () => Cmd.KeyCmds era @@ -115,27 +131,27 @@ runNonExtendedKeyCmd writeVerificationKey ssk = case ssk of APaymentExtendedVerificationKey vk -> - writeToDisk vkf Nothing (castVerificationKey vk :: VerificationKey PaymentKey) + writeToDisk vkf paymentVkeyDesc (castVerificationKey vk :: VerificationKey PaymentKey) ADRepExtendedVerificationKey vk -> - writeToDisk vkf (Just drepKeyEnvelopeDescr) (castVerificationKey vk :: VerificationKey DRepKey) + writeToDisk vkf drepVkeyDesc (castVerificationKey vk :: VerificationKey DRepKey) AStakeExtendedVerificationKey vk -> - writeToDisk vkf Nothing (castVerificationKey vk :: VerificationKey StakeKey) + writeToDisk vkf stakeVkeyDesc (castVerificationKey vk :: VerificationKey StakeKey) AGenesisExtendedVerificationKey vk -> - writeToDisk vkf Nothing (castVerificationKey vk :: VerificationKey GenesisKey) + writeToDisk vkf genesisVkeyDesc (castVerificationKey vk :: VerificationKey GenesisKey) AGenesisDelegateExtendedVerificationKey vk -> - writeToDisk vkf Nothing (castVerificationKey vk :: VerificationKey GenesisDelegateKey) + writeToDisk vkf genesisVkeyDelegateDesc (castVerificationKey vk :: VerificationKey GenesisDelegateKey) nonExtendedKey -> left $ KeyCmdExpectedExtendedVerificationKey nonExtendedKey writeToDisk :: Key keyrole => File content Out - -> Maybe TextEnvelopeDescr + -> TextEnvelopeDescr -> VerificationKey keyrole -> ExceptT KeyCmdError IO () writeToDisk vkf' descr vk = firstExceptT KeyCmdWriteFileError . newExceptT - $ writeLazyByteStringFile vkf' $ textEnvelopeToJSON descr vk + $ writeLazyByteStringFile vkf' $ textEnvelopeToJSON (Just descr) vk readExtendedVerificationKeyFile diff --git a/cardano-cli/src/Cardano/CLI/EraBased/Run/StakeAddress.hs b/cardano-cli/src/Cardano/CLI/EraBased/Run/StakeAddress.hs index 01a7360fbc..740d4fd66e 100644 --- a/cardano-cli/src/Cardano/CLI/EraBased/Run/StakeAddress.hs +++ b/cardano-cli/src/Cardano/CLI/EraBased/Run/StakeAddress.hs @@ -23,6 +23,7 @@ import qualified Cardano.Api.Ledger as Ledger import Cardano.Api.Shelley import Cardano.CLI.EraBased.Commands.StakeAddress +import qualified Cardano.CLI.EraBased.Run.Key as Key import Cardano.CLI.Read import Cardano.CLI.Types.Common import Cardano.CLI.Types.Errors.StakeAddressCmdError @@ -67,7 +68,6 @@ runStakeAddressKeyGenCmd :: () -> ExceptT StakeAddressCmdError IO () runStakeAddressKeyGenCmd fmt vkFp skFp = do let skeyDesc = "Stake Signing Key" - let vkeyDesc = "Stake Verification Key" skey <- liftIO $ generateSigningKey AsStakeKey @@ -82,7 +82,7 @@ runStakeAddressKeyGenCmd fmt vkFp skFp = do case fmt of KeyOutputFormatTextEnvelope -> - newExceptT $ writeLazyByteStringFile vkFp $ textEnvelopeToJSON (Just vkeyDesc) vkey + newExceptT $ writeLazyByteStringFile vkFp $ textEnvelopeToJSON (Just Key.stakeVkeyDesc) vkey KeyOutputFormatBech32 -> newExceptT $ writeTextFile vkFp $ serialiseToBech32 vkey diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-shelley.000.vkey b/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-shelley.000.vkey index 8620a4295e..71416e4b51 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-shelley.000.vkey +++ b/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-shelley.000.vkey @@ -1,5 +1,5 @@ { "type": "GenesisVerificationKey_ed25519", - "description": "", + "description": "Genesis Verification Key", "cborHex": "58200834b58f4bdda9522bb202af1f546db4cbbd94b068ae72c9fd96d9b55279edf0" } diff --git a/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-stake.000.vkey b/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-stake.000.vkey index d729371ef8..e390ad5fe8 100644 --- a/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-stake.000.vkey +++ b/cardano-cli/test/cardano-cli-golden/files/golden/key/non-extended-keys/non-extended-stake.000.vkey @@ -1,5 +1,5 @@ { "type": "StakeVerificationKeyShelley_ed25519", - "description": "", + "description": "Stake Verification Key", "cborHex": "58200f205175c0a47cba409c328f066e31ea4e81ef211f539c12b64b4b14e1d87188" }