Skip to content

Commit

Permalink
Extended to non-extended key: write description field in all cases
Browse files Browse the repository at this point in the history
  • Loading branch information
smelc committed Oct 31, 2023
1 parent 789e9fd commit d9673f7
Show file tree
Hide file tree
Showing 7 changed files with 41 additions and 27 deletions.
11 changes: 5 additions & 6 deletions cardano-cli/src/Cardano/CLI/EraBased/Run/Address.hs
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down Expand Up @@ -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
Expand All @@ -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)
Expand Down
11 changes: 5 additions & 6 deletions cardano-cli/src/Cardano/CLI/EraBased/Run/Genesis.hs
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Expand Down Expand Up @@ -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
Expand All @@ -197,7 +197,7 @@ runGenesisKeyGenDelegateCmd
firstExceptT GenesisCmdGenesisFileError
. newExceptT
$ writeLazyByteStringFile verificationKeyPath
$ textEnvelopeToJSON (Just vkeyDesc) vkey
$ textEnvelopeToJSON (Just Key.genesisVkeyDelegateDesc) vkey
firstExceptT GenesisCmdGenesisFileError
. newExceptT
$ writeLazyByteStringFile opCertCounterPath
Expand All @@ -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)

Expand Down
2 changes: 1 addition & 1 deletion cardano-cli/src/Cardano/CLI/EraBased/Run/Governance.hs
Original file line number Diff line number Diff line change
Expand Up @@ -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"
Expand Down
36 changes: 26 additions & 10 deletions cardano-cli/src/Cardano/CLI/EraBased/Run/Key.hs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,11 @@ module Cardano.CLI.EraBased.Run.Key
, runNonExtendedKeyCmd
, runVerificationKeyCmd

, drepKeyEnvelopeDescr
, drepVkeyDesc
, genesisVkeyDesc
, genesisVkeyDelegateDesc
, stakeVkeyDesc
, paymentVkeyDesc

-- * Exports for testing
, decodeBech32
Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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
Expand Down
4 changes: 2 additions & 2 deletions cardano-cli/src/Cardano/CLI/EraBased/Run/StakeAddress.hs
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down Expand Up @@ -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

Expand All @@ -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

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"type": "GenesisVerificationKey_ed25519",
"description": "",
"description": "Genesis Verification Key",
"cborHex": "58200834b58f4bdda9522bb202af1f546db4cbbd94b068ae72c9fd96d9b55279edf0"
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"type": "StakeVerificationKeyShelley_ed25519",
"description": "",
"description": "Stake Verification Key",
"cborHex": "58200f205175c0a47cba409c328f066e31ea4e81ef211f539c12b64b4b14e1d87188"
}

0 comments on commit d9673f7

Please sign in to comment.