Skip to content

Commit

Permalink
Use only stake credentials required in witnessing
Browse files Browse the repository at this point in the history
  • Loading branch information
carbolymer committed Nov 23, 2023
1 parent 6767351 commit aa9fbf9
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 14 deletions.
24 changes: 14 additions & 10 deletions cardano-api/internal/Cardano/Api/Certificate.hs
Original file line number Diff line number Diff line change
Expand Up @@ -55,20 +55,21 @@ module Cardano.Api.Certificate (
makeGenesisKeyDelegationCertificate,
Ledger.MIRTarget (..),
Ledger.MIRPot(..),
selectStakeCredentialWitness,

-- * Internal conversion functions
toShelleyCertificate,
fromShelleyCertificate,
toShelleyPoolParams,
fromShelleyPoolParams,


-- * Data family instances
AsType(..),

-- * Internal functions
filterUnRegCreds,
filterUnRegDRepCreds,
selectStakeCredential,
) where

import Cardano.Api.Address
Expand Down Expand Up @@ -467,29 +468,31 @@ makeStakeAddressAndDRepDelegationCertificate w cred delegatee deposit =
-- Helper functions
--

selectStakeCredential
:: Certificate era -> Maybe StakeCredential
selectStakeCredential = fmap fromShelleyStakeCredential . \case
-- | Get the stake credential witness for a certificate that requires it.
-- Only stake address deregistration and delegation requires witnessing (witness can be script or key).
selectStakeCredentialWitness
:: Certificate era
-> Maybe StakeCredential
selectStakeCredentialWitness = fmap fromShelleyStakeCredential . \case
ShelleyRelatedCertificate stbEra shelleyCert -> shelleyToBabbageEraConstraints stbEra $
case shelleyCert of
Ledger.RegTxCert sCred -> Just sCred
Ledger.RegTxCert _ -> Nothing -- contains stake cred
Ledger.UnRegTxCert sCred -> Just sCred
Ledger.DelegStakeTxCert sCred _ -> Just sCred
-- StakePool is always controlled by key, i.e. it is never a script. In other words,
-- @Credential StakePool@ cannot exist, because @ScriptHashObj@ constructor can't be used for that type.
Ledger.RegPoolTxCert _ -> Nothing -- contains StakePool key which cannot be a credential
Ledger.RetirePoolTxCert _ _ -> Nothing -- contains StakePool key which cannot be a credential

Ledger.MirTxCert _ -> Nothing
Ledger.GenesisDelegTxCert{} -> Nothing

ConwayCertificate cEra conwayCert -> conwayEraOnwardsConstraints cEra $
case conwayCert of
Ledger.RegPoolTxCert _ -> Nothing -- contains StakePool key which cannot be a credential
Ledger.RetirePoolTxCert _ _ -> Nothing -- contains StakePool key which cannot be a credential
Ledger.RegTxCert sCred -> Just sCred
Ledger.RegTxCert{} -> Nothing -- contains stake cred
Ledger.UnRegTxCert sCred -> Just sCred
Ledger.RegDepositTxCert sCred _ -> Just sCred
Ledger.RegDepositTxCert{} -> Nothing -- contains stake cred
Ledger.UnRegDepositTxCert sCred _ -> Just sCred
Ledger.DelegTxCert sCred _ -> Just sCred
Ledger.RegDepositDelegTxCert sCred _ _ -> Just sCred
Expand All @@ -499,6 +502,7 @@ selectStakeCredential = fmap fromShelleyStakeCredential . \case
Ledger.UnRegDRepTxCert{} -> Nothing
Ledger.UpdateDRepTxCert{} -> Nothing


filterUnRegCreds
:: Certificate era -> Maybe StakeCredential
filterUnRegCreds = fmap fromShelleyStakeCredential . \case
Expand All @@ -523,7 +527,7 @@ filterUnRegCreds = fmap fromShelleyStakeCredential . \case
Ledger.DelegTxCert _ _ -> Nothing
Ledger.RegDepositDelegTxCert{} -> Nothing
Ledger.AuthCommitteeHotKeyTxCert{} -> Nothing
Ledger.ResignCommitteeColdTxCert _ _ -> Nothing
Ledger.ResignCommitteeColdTxCert{} -> Nothing
Ledger.RegDRepTxCert{} -> Nothing
Ledger.UnRegDRepTxCert{} -> Nothing
Ledger.UpdateDRepTxCert{} -> Nothing
Expand All @@ -544,7 +548,7 @@ filterUnRegDRepCreds = \case
Ledger.DelegTxCert _ _ -> Nothing
Ledger.RegDepositDelegTxCert{} -> Nothing
Ledger.AuthCommitteeHotKeyTxCert{} -> Nothing
Ledger.ResignCommitteeColdTxCert _ _ -> Nothing
Ledger.ResignCommitteeColdTxCert{} -> Nothing
Ledger.RegDRepTxCert{} -> Nothing
Ledger.UnRegDRepTxCert cred _ -> Just cred
Ledger.UpdateDRepTxCert{} -> Nothing
Expand Down
2 changes: 1 addition & 1 deletion cardano-api/internal/Cardano/Api/Fees.hs
Original file line number Diff line number Diff line change
Expand Up @@ -1150,7 +1150,7 @@ mapTxScriptWitnesses f txbodycontent@TxBodyContent {
[ (stakecred, ScriptWitness ctx <$> witness')
-- The certs are indexed in list order
| (ix, cert) <- zip [0..] certs
, stakecred <- maybeToList (selectStakeCredential cert)
, stakecred <- maybeToList (selectStakeCredentialWitness cert)
, ScriptWitness ctx witness
<- maybeToList (Map.lookup stakecred witnesses)
, let witness' = f (ScriptWitnessIndexCertificate ix) witness
Expand Down
8 changes: 5 additions & 3 deletions cardano-api/internal/Cardano/Api/TxBody.hs
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,7 @@ import qualified Text.Parsec as Parsec
import Text.Parsec ((<?>))
import qualified Text.Parsec.String as Parsec


-- | Indicates whether a script is expected to fail or pass validation.
data ScriptValidity
= ScriptInvalid -- ^ Script is expected to fail validation.
Expand Down Expand Up @@ -1843,7 +1844,8 @@ createTransactionBody sbe bc =
mkCommonTxBody sbe (txIns bc) (txOuts bc) (txFee bc) (txWithdrawals bc) txAuxData
& A.certsTxBodyL sbe .~ certs
& A.invalidHereAfterTxBodyL sbe .~ convValidityUpperBound sbe (txValidityUpperBound bc)
& ( appEndo $ mconcat
& appEndo
(mconcat
[ setUpdateProposal
, setInvalidBefore
, setMint
Expand All @@ -1854,7 +1856,7 @@ createTransactionBody sbe bc =
, setCollateralReturn
, setTotalCollateral
]
)
)

-- TODO: NetworkId for hardware wallets. We don't always want this
-- & L.networkIdTxBodyL .~ ...
Expand Down Expand Up @@ -3264,7 +3266,7 @@ collectTxBodyScriptWitnesses _ TxBodyContent {
-- The certs are indexed in list order
| (ix, cert) <- zip [0..] certs
, ScriptWitness _ witness <- maybeToList $ do
stakecred <- selectStakeCredential cert
stakecred <- selectStakeCredentialWitness cert
Map.lookup stakecred witnesses
]

Expand Down
1 change: 1 addition & 0 deletions cardano-api/internal/Cardano/Api/Utils.hs
Original file line number Diff line number Diff line change
Expand Up @@ -140,3 +140,4 @@ modifyWith :: ()
=> (a -> a)
-> (a -> a)
modifyWith = id

1 change: 1 addition & 0 deletions cardano-api/src/Cardano/Api.hs
Original file line number Diff line number Diff line change
Expand Up @@ -862,6 +862,7 @@ module Cardano.Api (
makeGenesisKeyDelegationCertificate,
MIRTarget (..),
MIRPot(..),
selectStakeCredentialWitness,

-- * Protocol parameter updates
UpdateProposal(..),
Expand Down

0 comments on commit aa9fbf9

Please sign in to comment.