Skip to content

Commit

Permalink
Add support for script-based CC members
Browse files Browse the repository at this point in the history
Co-authored-by: Clément Hurlin <[email protected]>
  • Loading branch information
carbolymer and smelc committed Mar 19, 2024
1 parent c4b6f16 commit 988a291
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 41 deletions.
6 changes: 3 additions & 3 deletions cardano-api/internal/Cardano/Api/Certificate.hs
Original file line number Diff line number Diff line change
Expand Up @@ -423,18 +423,18 @@ makeCommitteeHotKeyAuthorizationCertificate (CommitteeHotKeyAuthorizationRequire
data CommitteeColdkeyResignationRequirements era where
CommitteeColdkeyResignationRequirements
:: ConwayEraOnwards era
-> Ledger.KeyHash Ledger.ColdCommitteeRole (EraCrypto (ShelleyLedgerEra era))
-> Ledger.Credential Ledger.ColdCommitteeRole (EraCrypto (ShelleyLedgerEra era))
-> Maybe (Ledger.Anchor (EraCrypto (ShelleyLedgerEra era)))
-> CommitteeColdkeyResignationRequirements era

makeCommitteeColdkeyResignationCertificate :: ()
=> CommitteeColdkeyResignationRequirements era
-> Certificate era
makeCommitteeColdkeyResignationCertificate (CommitteeColdkeyResignationRequirements cOnwards coldKeyHash anchor) =
makeCommitteeColdkeyResignationCertificate (CommitteeColdkeyResignationRequirements cOnwards coldKeyCred anchor) =
ConwayCertificate cOnwards
. Ledger.ConwayTxCertGov
$ Ledger.ConwayResignCommitteeColdKey
(Ledger.KeyHashObj coldKeyHash)
coldKeyCred
(noInlineMaybeToStrictMaybe anchor)

data DRepUnregistrationRequirements era where
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,10 +37,9 @@ import Cardano.Ledger.Keys (KeyRole (ColdCommitteeRole))

import Data.ByteString (ByteString)
import Data.Map.Strict (Map)
import qualified Data.Map.Strict as Map
import Data.Maybe (fromMaybe)
import qualified Data.Set as Set
import Data.Word
import GHC.Exts (IsList (..))

data AnyGovernanceAction = forall era. AnyGovernanceAction (Gov.GovAction era)

Expand All @@ -54,8 +53,8 @@ data GovernanceAction era
(StrictMaybe (Shelley.ScriptHash StandardCrypto))
| ProposeNewCommittee
(StrictMaybe (Ledger.GovPurposeId Ledger.CommitteePurpose (ShelleyLedgerEra era)))
[Hash CommitteeColdKey] -- ^ Old constitutional committee
(Map (Hash CommitteeColdKey) EpochNo) -- ^ New committee members with epoch number when each of them expires
[L.Credential ColdCommitteeRole StandardCrypto] -- ^ Old constitutional committee
(Map (L.Credential ColdCommitteeRole StandardCrypto) EpochNo) -- ^ New committee members with epoch number when each of them expires
Rational -- ^ Quorum of the committee that is necessary for a successful vote
| InfoAct
| TreasuryWithdrawal
Expand Down Expand Up @@ -85,8 +84,8 @@ toGovernanceAction sbe =
ProposeNewCommittee prevGovId oldCommitteeMembers newCommitteeMembers quor ->
Gov.UpdateCommittee
prevGovId -- previous governance action id
(Set.fromList $ map toCommitteeMember oldCommitteeMembers) -- members to remove
(Map.mapKeys toCommitteeMember newCommitteeMembers) -- members to add
(fromList oldCommitteeMembers) -- members to remove
newCommitteeMembers -- members to add
(fromMaybe (error $ mconcat ["toGovernanceAction: the given quorum "
, show quor
, " was outside of the unit interval!"
Expand All @@ -95,7 +94,7 @@ toGovernanceAction sbe =
InfoAct ->
Gov.InfoAction
TreasuryWithdrawal withdrawals govPol ->
let m = Map.fromList [(L.RewardAcnt nw (toShelleyStakeCredential sc), l) | (nw,sc,l) <- withdrawals]
let m = fromList [(L.RewardAcnt nw (toShelleyStakeCredential sc), l) | (nw,sc,l) <- withdrawals]
in Gov.TreasuryWithdrawals m govPol
InitiateHardfork prevGovId pVer ->
Gov.HardForkInitiation prevGovId pVer
Expand All @@ -119,14 +118,14 @@ fromGovernanceAction = \case
InitiateHardfork prevGovId pVer
Gov.TreasuryWithdrawals withdrawlMap govPolicy ->
let res = [ (L.getRwdNetwork rwdAcnt, fromShelleyStakeCredential (L.getRwdCred rwdAcnt), coin)
| (rwdAcnt, coin) <- Map.toList withdrawlMap
| (rwdAcnt, coin) <- toList withdrawlMap
]
in TreasuryWithdrawal res govPolicy
Gov.UpdateCommittee prevGovId oldCommitteeMembers newCommitteeMembers quor ->
ProposeNewCommittee
prevGovId
(map fromCommitteeMember $ Set.toList oldCommitteeMembers)
(Map.mapKeys fromCommitteeMember newCommitteeMembers)
(toList oldCommitteeMembers)
newCommitteeMembers
(unboundRational quor)
Gov.InfoAction ->
InfoAct
Expand Down Expand Up @@ -215,16 +214,3 @@ createAnchor url anchorData =
, anchorDataHash = hashAnchorData $ Ledger.AnchorData anchorData
}

-- ----------------------------------------------------------------------------
-- TODO conversions that likely need to live elsewhere and may even deserve
-- additional wrapper types

toCommitteeMember :: Hash CommitteeColdKey -> L.Credential ColdCommitteeRole StandardCrypto
toCommitteeMember (CommitteeColdKeyHash keyhash) = L.KeyHashObj keyhash

fromCommitteeMember :: L.Credential ColdCommitteeRole StandardCrypto -> Hash CommitteeColdKey
fromCommitteeMember = \case
L.KeyHashObj keyhash -> CommitteeColdKeyHash keyhash
L.ScriptHashObj _scripthash -> error "TODO script committee members not yet supported"


15 changes: 11 additions & 4 deletions cardano-api/internal/Cardano/Api/Keys/Class.hs
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import Cardano.Api.SerialiseTextEnvelope
import qualified Cardano.Crypto.DSIGN.Class as Crypto
import qualified Cardano.Crypto.Seed as Crypto

import Control.Monad.IO.Class
import Data.Kind (Type)
import qualified System.Random as Random
import System.Random (StdGen)
Expand Down Expand Up @@ -68,19 +69,25 @@ class (Eq (VerificationKey keyrole),
-- For KES we can then override it to keep the seed and key in mlocked memory at all times.
-- | Generate a 'SigningKey' using a seed from operating system entropy.
--
generateSigningKey :: Key keyrole => AsType keyrole -> IO (SigningKey keyrole)
generateSigningKey
:: MonadIO m
=> Key keyrole
=> AsType keyrole
-> m (SigningKey keyrole)
generateSigningKey keytype = do
seed <- Crypto.readSeedFromSystemEntropy seedSize
seed <- liftIO $ Crypto.readSeedFromSystemEntropy seedSize
return $! deterministicSigningKey keytype seed
where
seedSize = deterministicSigningKeySeedSize keytype


generateInsecureSigningKey
:: (Key keyrole, SerialiseAsRawBytes (SigningKey keyrole))
:: MonadIO m
=> Key keyrole
=> SerialiseAsRawBytes (SigningKey keyrole)
=> StdGen
-> AsType keyrole
-> IO (SigningKey keyrole, StdGen)
-> m (SigningKey keyrole, StdGen)
generateInsecureSigningKey g keytype = do
let (bs, g') = Random.genByteString (fromIntegral $ deterministicSigningKeySeedSize keytype) g
case deserialiseFromRawBytes (AsSigningKey keytype) bs of
Expand Down
22 changes: 11 additions & 11 deletions cardano-api/internal/Cardano/Api/Keys/Shelley.hs
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ instance SerialiseAsBech32 (SigningKey PaymentKey) where
bech32PrefixesPermitted _ = ["addr_sk"]

newtype instance Hash PaymentKey =
PaymentKeyHash (Shelley.KeyHash Shelley.Payment StandardCrypto)
PaymentKeyHash { unPaymentKeyHash :: Shelley.KeyHash Shelley.Payment StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash PaymentKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash PaymentKey)
Expand Down Expand Up @@ -294,7 +294,7 @@ instance SerialiseAsBech32 (SigningKey PaymentExtendedKey) where


newtype instance Hash PaymentExtendedKey =
PaymentExtendedKeyHash (Shelley.KeyHash Shelley.Payment StandardCrypto)
PaymentExtendedKeyHash { unPaymentExtendedKeyHash :: Shelley.KeyHash Shelley.Payment StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash PaymentExtendedKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash PaymentExtendedKey)
Expand Down Expand Up @@ -400,7 +400,7 @@ instance SerialiseAsBech32 (SigningKey StakeKey) where


newtype instance Hash StakeKey =
StakeKeyHash (Shelley.KeyHash Shelley.Staking StandardCrypto)
StakeKeyHash { unStakeKeyHash :: Shelley.KeyHash Shelley.Staking StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash StakeKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash StakeKey)
Expand Down Expand Up @@ -543,7 +543,7 @@ instance SerialiseAsBech32 (SigningKey StakeExtendedKey) where


newtype instance Hash StakeExtendedKey =
StakeExtendedKeyHash (Shelley.KeyHash Shelley.Staking StandardCrypto)
StakeExtendedKeyHash { unStakeExtendedKeyHash :: Shelley.KeyHash Shelley.Staking StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash StakeExtendedKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash StakeExtendedKey)
Expand Down Expand Up @@ -640,7 +640,7 @@ instance SerialiseAsRawBytes (SigningKey GenesisKey) where


newtype instance Hash GenesisKey =
GenesisKeyHash (Shelley.KeyHash Shelley.Genesis StandardCrypto)
GenesisKeyHash { unGenesisKeyHash :: Shelley.KeyHash Shelley.Genesis StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash GenesisKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash GenesisKey)
Expand Down Expand Up @@ -738,7 +738,7 @@ instance SerialiseAsRawBytes (SigningKey CommitteeHotKey) where


newtype instance Hash CommitteeHotKey =
CommitteeHotKeyHash (Shelley.KeyHash Shelley.HotCommitteeRole StandardCrypto)
CommitteeHotKeyHash { unCommitteeHotKeyHash :: Shelley.KeyHash Shelley.HotCommitteeRole StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash CommitteeHotKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash CommitteeHotKey)
Expand Down Expand Up @@ -846,7 +846,7 @@ instance SerialiseAsRawBytes (SigningKey CommitteeColdKey) where


newtype instance Hash CommitteeColdKey =
CommitteeColdKeyHash (Shelley.KeyHash Shelley.ColdCommitteeRole StandardCrypto)
CommitteeColdKeyHash { unCommitteeColdKeyHash :: Shelley.KeyHash Shelley.ColdCommitteeRole StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash CommitteeColdKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash CommitteeColdKey)
Expand Down Expand Up @@ -1251,7 +1251,7 @@ instance SerialiseAsRawBytes (SigningKey GenesisExtendedKey) where


newtype instance Hash GenesisExtendedKey =
GenesisExtendedKeyHash (Shelley.KeyHash Shelley.Staking StandardCrypto)
GenesisExtendedKeyHash { unGenesisExtendedKeyHash :: Shelley.KeyHash Shelley.Staking StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash GenesisExtendedKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash GenesisExtendedKey)
Expand Down Expand Up @@ -1349,7 +1349,7 @@ instance SerialiseAsRawBytes (SigningKey GenesisDelegateKey) where


newtype instance Hash GenesisDelegateKey =
GenesisDelegateKeyHash (Shelley.KeyHash Shelley.GenesisDelegate StandardCrypto)
GenesisDelegateKeyHash { unGenesisDelegateKeyHash :: Shelley.KeyHash Shelley.GenesisDelegate StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash GenesisDelegateKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash GenesisDelegateKey)
Expand Down Expand Up @@ -1492,7 +1492,7 @@ instance SerialiseAsRawBytes (SigningKey GenesisDelegateExtendedKey) where


newtype instance Hash GenesisDelegateExtendedKey =
GenesisDelegateExtendedKeyHash (Shelley.KeyHash Shelley.Staking StandardCrypto)
GenesisDelegateExtendedKeyHash { unGenesisDelegateExtendedKeyHash :: Shelley.KeyHash Shelley.Staking StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash GenesisDelegateExtendedKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash GenesisDelegateExtendedKey)
Expand Down Expand Up @@ -1589,7 +1589,7 @@ instance SerialiseAsRawBytes (SigningKey GenesisUTxOKey) where


newtype instance Hash GenesisUTxOKey =
GenesisUTxOKeyHash (Shelley.KeyHash Shelley.Payment StandardCrypto)
GenesisUTxOKeyHash { unGenesisUTxOKeyHash :: Shelley.KeyHash Shelley.Payment StandardCrypto }
deriving stock (Eq, Ord)
deriving (Show, IsString) via UsingRawBytesHex (Hash GenesisUTxOKey)
deriving (ToCBOR, FromCBOR) via UsingRawBytes (Hash GenesisUTxOKey)
Expand Down

0 comments on commit 988a291

Please sign in to comment.