Skip to content
This repository has been archived by the owner on Dec 2, 2024. It is now read-only.

Commit

Permalink
PLT-990 Removed Plutus.Contract.Wallet.finalize as we instead set the…
Browse files Browse the repository at this point in the history
… validity range of a transaction directly in `plutus-ledger-constraints` (since we now have access to the `SlotConfig`)
  • Loading branch information
koslambrou committed Oct 6, 2022
1 parent 4c832ce commit df15e04
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 30 deletions.
27 changes: 6 additions & 21 deletions plutus-contract/src/Plutus/Contract/Wallet.hs
Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,10 @@ module Plutus.Contract.Wallet(
, ExportTxInput(..)
, ExportTxRedeemer(..)
, export
, finalize
) where

import Cardano.Api qualified as C
import Control.Applicative ((<|>))
import Control.Lens ((&), (.~))
import Control.Monad ((>=>))
import Control.Monad.Error.Lens (throwing)
import Control.Monad.Freer (Eff, Member)
Expand All @@ -50,10 +48,8 @@ import Ledger qualified (ScriptPurpose (..))
import Ledger qualified as P
import Ledger.Ada qualified as Ada
import Ledger.Constraints (mustPayToPubKey)
import Ledger.Constraints.OffChain (UnbalancedTx (UnbalancedCardanoTx, UnbalancedEmulatorTx, unBalancedTxRequiredSignatories, unBalancedTxUtxoIndex, unBalancedTxValidityTimeRange),
mkTx, unBalancedTxTx)
import Ledger.Constraints.OffChain qualified as U
import Ledger.TimeSlot (SlotConfig, posixTimeRangeToContainedSlotRange)
import Ledger.Constraints.OffChain (UnbalancedTx (unBalancedTxRequiredSignatories, unBalancedTxUtxoIndex), mkTx,
unBalancedTxTx)
import Ledger.Tx (CardanoTx, TxId (TxId), TxIn (..), TxOutRef, getCardanoTxInputs, txInRef)
import Ledger.Validation (CardanoLedgerError, fromPlutusIndex, makeTransactionBody)
import Ledger.Value (currencyMPSHash)
Expand Down Expand Up @@ -258,30 +254,19 @@ export
-> UnbalancedTx
-> Either CardanoLedgerError ExportTx
export params utx =
let utxFinal = finalize (P.pSlotConfig params) utx
requiredSigners = Set.toList (unBalancedTxRequiredSignatories utxFinal)
let requiredSigners = Set.toList (unBalancedTxRequiredSignatories utx)
fromCardanoTx ctx = do
utxo <- fromPlutusIndex $ P.UtxoIndex (unBalancedTxUtxoIndex utxFinal)
utxo <- fromPlutusIndex $ P.UtxoIndex (unBalancedTxUtxoIndex utx)
makeTransactionBody params utxo ctx
in ExportTx
<$> fmap (C.makeSignedTransaction [])
(either
fromCardanoTx
(first Right . CardanoAPI.toCardanoTxBody params requiredSigners)
(unBalancedTxTx utxFinal))
<*> first Right (mkInputs (P.pNetworkId params) (unBalancedTxUtxoIndex utxFinal))
(unBalancedTxTx utx))
<*> first Right (mkInputs (P.pNetworkId params) (unBalancedTxUtxoIndex utx))
<*> either (const $ Right []) (Right . mkRedeemers) (unBalancedTxTx utx)

-- | when we use UnbalancedEmulatorTx, finalize computes the final validityRange and set it into the Tx.
-- In the case of a UnbalancedCardanoTx, there's nothing to do here as the validityRange of the Tx is set when we process the
-- constraints.
finalize :: SlotConfig -> UnbalancedTx -> UnbalancedTx
finalize slotConfig utx@UnbalancedEmulatorTx{unBalancedTxValidityTimeRange} =
utx & U.tx
. P.validRange
.~ posixTimeRangeToContainedSlotRange slotConfig unBalancedTxValidityTimeRange
finalize _ utx@UnbalancedCardanoTx{} = utx

mkInputs :: C.NetworkId -> Map Plutus.TxOutRef P.TxOut -> Either CardanoAPI.ToCardanoError [ExportTxInput]
mkInputs networkId = traverse (uncurry (toExportTxInput networkId)) . Map.toList

Expand Down
10 changes: 4 additions & 6 deletions plutus-contract/src/Wallet/Emulator/Wallet.hs
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ import Ledger.Constraints.OffChain qualified as U
import Ledger.Credential (Credential (PubKeyCredential, ScriptCredential))
import Ledger.Fee (estimateTransactionFee, makeAutoBalancedTransaction)
import Ledger.Index.Internal (UtxoIndex (UtxoIndex, getIndex))
import Ledger.Params (Params (Params, pNetworkId, pProtocolParams, pSlotConfig))
import Ledger.Params (Params (Params, pNetworkId, pProtocolParams))
import Ledger.Tx (CardanoTx, ChainIndexTxOut, SomeCardanoApiTx, Tx (txFee, txMint), TxOut (TxOut))
import Ledger.Tx qualified as Tx
import Ledger.Tx.CardanoAPI.Internal (makeTransactionBody, toCardanoTxOut, toCardanoTxOutDatum)
Expand All @@ -69,7 +69,6 @@ import Plutus.ChainIndex qualified as ChainIndex
import Plutus.ChainIndex.Api (UtxosResponse (page))
import Plutus.ChainIndex.Emulator (ChainIndexEmulatorState, ChainIndexQueryEffect)
import Plutus.Contract.Checkpoint (CheckpointLogMsg)
import Plutus.Contract.Wallet (finalize)
import Plutus.V1.Ledger.Api (PubKeyHash, TxOutRef, ValidatorHash, Value)
import PlutusTx.Prelude qualified as PlutusTx
import Prettyprinter (Pretty (pretty))
Expand Down Expand Up @@ -317,11 +316,10 @@ handleBalance ::
)
=> UnbalancedTx
-> Eff effs CardanoTx
handleBalance utx' = do
handleBalance utx = do
utxo <- get >>= ownOutputs
params@Params { pSlotConfig, pNetworkId } <- WAPI.getClientParams
let utx = finalize pSlotConfig utx'
requiredSigners = Set.toList (U.unBalancedTxRequiredSignatories utx)
params@Params { pNetworkId } <- WAPI.getClientParams
let requiredSigners = Set.toList (U.unBalancedTxRequiredSignatories utx)
eitherTx = U.unBalancedTxTx utx
plUtxo = traverse (Tx.toTxOut pNetworkId) utxo
mappedUtxo <- either (throwError . WAPI.ToCardanoError) pure plUtxo
Expand Down
12 changes: 9 additions & 3 deletions plutus-ledger-constraints/src/Ledger/Constraints/OffChain.hs
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,8 @@ import Ledger.Constraints.TxConstraints (ScriptInputConstraint (ScriptInputConst
import Ledger.Crypto (pubKeyHash)
import Ledger.Index (minAdaTxOut)
import Ledger.Orphans ()
import Ledger.Params (Params (pNetworkId))
import Ledger.Params (Params (pNetworkId, pSlotConfig))
import Ledger.TimeSlot (posixTimeRangeToContainedSlotRange)
import Ledger.Tx (ChainIndexTxOut (_ciTxOutReferenceScript), Language (PlutusV1, PlutusV2), ReferenceScript,
TxOut (TxOut), TxOutRef, Versioned (Versioned), txOutValue)
import Ledger.Tx qualified as Tx
Expand Down Expand Up @@ -702,8 +703,13 @@ processConstraint = \case
let dvHash = P.datumHash dv
unless (dvHash `elem` Map.keys datums)
(throwError $ DatumNotFoundInTx dvHash)
MustValidateIn timeRange ->
unbalancedTx . validityTimeRange %= (timeRange /\)
MustValidateIn timeRange -> do
slotRange <-
gets ( flip posixTimeRangeToContainedSlotRange timeRange
. pSlotConfig
. cpsParams
)
unbalancedTx . tx . Tx.validRange %= (slotRange /\)
MustBeSignedBy pk ->
unbalancedTx . requiredSignatories <>= Set.singleton pk
MustSpendAtLeast vl -> valueSpentInputs <>= required vl
Expand Down

0 comments on commit df15e04

Please sign in to comment.