{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilyDependencies #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE UndecidableInstances #-}
{-# LANGUAGE UndecidableSuperClasses #-}
{-# OPTIONS_GHC -Wno-orphans #-}
module Cardano.Ledger.Core (
EraTx (..),
txIdTx,
EraTxOut (..),
bootAddrTxOutF,
coinTxOutL,
compactCoinTxOutL,
isAdaOnlyTxOutF,
EraTxBody (..),
txIdTxBody,
EraTxAuxData (..),
hashTxAuxData,
EraTxWits (..),
EraScript (..),
hashScript,
isNativeScript,
hashScriptTxWitsL,
Value,
EraPParams (..),
mkCoinTxOut,
module Cardano.Ledger.Core.Era,
EraSegWits (..),
bBodySize,
RewardType (..),
Reward (..),
module Cardano.Ledger.Hashes,
module Cardano.Ledger.Core.TxCert,
module Cardano.Ledger.Core.PParams,
module Cardano.Ledger.Core.Translation,
)
where
import qualified Cardano.Crypto.Hash as Hash
import Cardano.Ledger.Address (
Addr (..),
BootstrapAddress,
CompactAddr,
Withdrawals,
compactAddr,
decompactAddr,
isBootstrapCompactAddr,
)
import Cardano.Ledger.BaseTypes (ProtVer (..))
import Cardano.Ledger.Binary (
Annotator,
DecCBOR,
DecShareCBOR (Share),
EncCBOR,
EncCBORGroup,
Interns,
Sized (sizedValue),
ToCBOR,
encCBORGroup,
mkSized,
serialize',
)
import Cardano.Ledger.Coin (Coin)
import Cardano.Ledger.Compactible (Compactible (..))
import Cardano.Ledger.Core.Era
import Cardano.Ledger.Core.PParams
import Cardano.Ledger.Core.Translation
import Cardano.Ledger.Core.TxCert
import Cardano.Ledger.Credential (Credential)
import Cardano.Ledger.Hashes hiding (GenDelegPair (..), GenDelegs (..), unsafeMakeSafeHash)
import Cardano.Ledger.Keys.Bootstrap (BootstrapWitness)
import Cardano.Ledger.Keys.WitVKey (WitVKey)
import Cardano.Ledger.MemoBytes
import Cardano.Ledger.Metadata
import Cardano.Ledger.Rewards (Reward (..), RewardType (..))
import Cardano.Ledger.TxIn (TxId (..), TxIn (..))
import Cardano.Ledger.Val (Val (..), inject)
import Control.DeepSeq (NFData)
import Data.Aeson (ToJSON)
import qualified Data.ByteString as BS
import Data.Kind (Type)
import Data.Map (Map)
import qualified Data.Map.Strict as Map
import Data.Maybe (fromMaybe, isJust)
import Data.Maybe.Strict (StrictMaybe)
import Data.MemPack
import Data.Sequence.Strict (StrictSeq)
import Data.Set (Set)
import Data.Void (Void)
import Data.Word (Word32, Word64)
import GHC.Stack (HasCallStack)
import Lens.Micro
import NoThunks.Class (NoThunks)
class
( EraTxBody era
, EraTxWits era
, EraTxAuxData era
, EraPParams era
,
NoThunks (Tx era)
, DecCBOR (Annotator (Tx era))
, EncCBOR (Tx era)
, ToCBOR (Tx era)
, Show (Tx era)
, Eq (Tx era)
, EqRaw (Tx era)
) =>
EraTx era
where
type Tx era = (r :: Type) | r -> era
type TxUpgradeError era :: Type
type TxUpgradeError era = Void
mkBasicTx :: TxBody era -> Tx era
bodyTxL :: Lens' (Tx era) (TxBody era)
witsTxL :: Lens' (Tx era) (TxWits era)
auxDataTxL :: Lens' (Tx era) (StrictMaybe (TxAuxData era))
sizeTxF :: SimpleGetter (Tx era) Integer
wireSizeTxF :: SimpleGetter (Tx era) Word32
validateNativeScript :: Tx era -> NativeScript era -> Bool
getMinFeeTx ::
PParams era ->
Tx era ->
Int ->
Coin
upgradeTx ::
EraTx (PreviousEra era) =>
Tx (PreviousEra era) ->
Either (TxUpgradeError era) (Tx era)
class
( EraTxOut era
, EraTxCert era
, EraPParams era
, HashAnnotated (TxBody era) EraIndependentTxBody
, DecCBOR (Annotator (TxBody era))
, EncCBOR (TxBody era)
, ToCBOR (TxBody era)
, NoThunks (TxBody era)
, NFData (TxBody era)
, Show (TxBody era)
, Eq (TxBody era)
, EqRaw (TxBody era)
) =>
EraTxBody era
where
type TxBody era = (r :: Type) | r -> era
type TxBodyUpgradeError era :: Type
type TxBodyUpgradeError era = Void
mkBasicTxBody :: TxBody era
inputsTxBodyL :: Lens' (TxBody era) (Set TxIn)
outputsTxBodyL :: Lens' (TxBody era) (StrictSeq (TxOut era))
feeTxBodyL :: Lens' (TxBody era) Coin
withdrawalsTxBodyL :: Lens' (TxBody era) Withdrawals
auxDataHashTxBodyL :: Lens' (TxBody era) (StrictMaybe TxAuxDataHash)
spendableInputsTxBodyF :: SimpleGetter (TxBody era) (Set TxIn)
allInputsTxBodyF :: SimpleGetter (TxBody era) (Set TxIn)
certsTxBodyL :: Lens' (TxBody era) (StrictSeq (TxCert era))
getTotalDepositsTxBody ::
PParams era ->
(KeyHash 'StakePool -> Bool) ->
TxBody era ->
Coin
getTotalDepositsTxBody PParams era
pp KeyHash 'StakePool -> Bool
isPoolRegisted TxBody era
txBody =
forall era (f :: * -> *).
(EraTxCert era, Foldable f) =>
PParams era
-> (KeyHash 'StakePool -> Bool) -> f (TxCert era) -> Coin
getTotalDepositsTxCerts PParams era
pp KeyHash 'StakePool -> Bool
isPoolRegisted (TxBody era
txBody forall s a. s -> Getting a s a -> a
^. forall era.
EraTxBody era =>
Lens' (TxBody era) (StrictSeq (TxCert era))
certsTxBodyL)
getTotalRefundsTxBody ::
PParams era ->
(Credential 'Staking -> Maybe Coin) ->
(Credential 'DRepRole -> Maybe Coin) ->
TxBody era ->
Coin
getTotalRefundsTxBody PParams era
pp Credential 'Staking -> Maybe Coin
lookupStakingDeposit Credential 'DRepRole -> Maybe Coin
lookupDRepDeposit TxBody era
txBody =
forall era (f :: * -> *).
(EraTxCert era, Foldable f) =>
PParams era
-> (Credential 'Staking -> Maybe Coin)
-> (Credential 'DRepRole -> Maybe Coin)
-> f (TxCert era)
-> Coin
getTotalRefundsTxCerts PParams era
pp Credential 'Staking -> Maybe Coin
lookupStakingDeposit Credential 'DRepRole -> Maybe Coin
lookupDRepDeposit (TxBody era
txBody forall s a. s -> Getting a s a -> a
^. forall era.
EraTxBody era =>
Lens' (TxBody era) (StrictSeq (TxCert era))
certsTxBodyL)
getGenesisKeyHashCountTxBody :: TxBody era -> Int
getGenesisKeyHashCountTxBody TxBody era
_ = Int
0
upgradeTxBody ::
EraTxBody (PreviousEra era) =>
TxBody (PreviousEra era) ->
Either (TxBodyUpgradeError era) (TxBody era)
class
( Val (Value era)
, ToJSON (TxOut era)
, DecCBOR (Value era)
, DecCBOR (CompactForm (Value era))
, MemPack (CompactForm (Value era))
, EncCBOR (Value era)
, ToCBOR (TxOut era)
, EncCBOR (TxOut era)
, DecCBOR (TxOut era)
, DecShareCBOR (TxOut era)
, Share (TxOut era) ~ Interns (Credential 'Staking)
, NoThunks (TxOut era)
, NFData (TxOut era)
, Show (TxOut era)
, Eq (TxOut era)
, MemPack (TxOut era)
, EraPParams era
) =>
EraTxOut era
where
type TxOut era = (r :: Type) | r -> era
{-# MINIMAL
mkBasicTxOut
, upgradeTxOut
, valueEitherTxOutL
, addrEitherTxOutL
, (getMinCoinSizedTxOut | getMinCoinTxOut)
#-}
mkBasicTxOut :: HasCallStack => Addr -> Value era -> TxOut era
upgradeTxOut :: EraTxOut (PreviousEra era) => TxOut (PreviousEra era) -> TxOut era
valueTxOutL :: Lens' (TxOut era) (Value era)
valueTxOutL =
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens
( \TxOut era
txOut -> case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL of
Left Value era
value -> Value era
value
Right CompactForm (Value era)
cValue -> forall a. Compactible a => CompactForm a -> a
fromCompact CompactForm (Value era)
cValue
)
(\TxOut era
txOut Value era
value -> TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall a b. a -> Either a b
Left Value era
value)
{-# INLINE valueTxOutL #-}
compactValueTxOutL :: HasCallStack => Lens' (TxOut era) (CompactForm (Value era))
compactValueTxOutL =
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens
( \TxOut era
txOut -> case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL of
Left Value era
value -> forall a. (HasCallStack, Val a) => a -> CompactForm a
toCompactPartial Value era
value
Right CompactForm (Value era)
cValue -> CompactForm (Value era)
cValue
)
(\TxOut era
txOut CompactForm (Value era)
cValue -> TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall a b. b -> Either a b
Right CompactForm (Value era)
cValue)
{-# INLINE compactValueTxOutL #-}
valueEitherTxOutL :: Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
addrTxOutL :: Lens' (TxOut era) Addr
addrTxOutL =
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens
( \TxOut era
txOut -> case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either Addr CompactAddr)
addrEitherTxOutL of
Left Addr
addr -> Addr
addr
Right CompactAddr
cAddr -> HasCallStack => CompactAddr -> Addr
decompactAddr CompactAddr
cAddr
)
(\TxOut era
txOut Addr
addr -> TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era.
EraTxOut era =>
Lens' (TxOut era) (Either Addr CompactAddr)
addrEitherTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall a b. a -> Either a b
Left Addr
addr)
{-# INLINE addrTxOutL #-}
compactAddrTxOutL :: Lens' (TxOut era) CompactAddr
compactAddrTxOutL =
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens
( \TxOut era
txOut -> case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either Addr CompactAddr)
addrEitherTxOutL of
Left Addr
addr -> Addr -> CompactAddr
compactAddr Addr
addr
Right CompactAddr
cAddr -> CompactAddr
cAddr
)
(\TxOut era
txOut CompactAddr
cAddr -> TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era.
EraTxOut era =>
Lens' (TxOut era) (Either Addr CompactAddr)
addrEitherTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall a b. b -> Either a b
Right CompactAddr
cAddr)
{-# INLINE compactAddrTxOutL #-}
addrEitherTxOutL :: Lens' (TxOut era) (Either Addr CompactAddr)
getMinCoinSizedTxOut :: PParams era -> Sized (TxOut era) -> Coin
getMinCoinSizedTxOut PParams era
pp = forall era. EraTxOut era => PParams era -> TxOut era -> Coin
getMinCoinTxOut PParams era
pp forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Sized a -> a
sizedValue
getMinCoinTxOut :: PParams era -> TxOut era -> Coin
getMinCoinTxOut PParams era
pp TxOut era
txOut =
let ProtVer Version
version Natural
_ = PParams era
pp forall s a. s -> Getting a s a -> a
^. forall era. EraPParams era => Lens' (PParams era) ProtVer
ppProtocolVersionL
in forall era.
EraTxOut era =>
PParams era -> Sized (TxOut era) -> Coin
getMinCoinSizedTxOut PParams era
pp (forall a. EncCBOR a => Version -> a -> Sized a
mkSized Version
version TxOut era
txOut)
bootAddrTxOutF ::
EraTxOut era => SimpleGetter (TxOut era) (Maybe BootstrapAddress)
bootAddrTxOutF :: forall era.
EraTxOut era =>
SimpleGetter (TxOut era) (Maybe BootstrapAddress)
bootAddrTxOutF = forall s a. (s -> a) -> SimpleGetter s a
to forall a b. (a -> b) -> a -> b
$ \TxOut era
txOut ->
case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either Addr CompactAddr)
addrEitherTxOutL of
Left (AddrBootstrap BootstrapAddress
bootstrapAddr) -> forall a. a -> Maybe a
Just BootstrapAddress
bootstrapAddr
Right CompactAddr
cAddr
| CompactAddr -> Bool
isBootstrapCompactAddr CompactAddr
cAddr -> do
AddrBootstrap BootstrapAddress
bootstrapAddr <- forall a. a -> Maybe a
Just (HasCallStack => CompactAddr -> Addr
decompactAddr CompactAddr
cAddr)
forall a. a -> Maybe a
Just BootstrapAddress
bootstrapAddr
Either Addr CompactAddr
_ -> forall a. Maybe a
Nothing
{-# INLINE bootAddrTxOutF #-}
coinTxOutL :: (HasCallStack, EraTxOut era) => Lens' (TxOut era) Coin
coinTxOutL :: forall era. (HasCallStack, EraTxOut era) => Lens' (TxOut era) Coin
coinTxOutL =
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens
( \TxOut era
txOut ->
case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL of
Left Value era
val -> forall t. Val t => t -> Coin
coin Value era
val
Right CompactForm (Value era)
cVal -> forall a. Compactible a => CompactForm a -> a
fromCompact (forall t. Val t => CompactForm t -> CompactForm Coin
coinCompact CompactForm (Value era)
cVal)
)
( \TxOut era
txOut Coin
c ->
case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL of
Left Value era
val -> TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era. EraTxOut era => Lens' (TxOut era) (Value era)
valueTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall t. Val t => (Coin -> Coin) -> t -> t
modifyCoin (forall a b. a -> b -> a
const Coin
c) Value era
val
Right CompactForm (Value era)
cVal ->
TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era.
(EraTxOut era, HasCallStack) =>
Lens' (TxOut era) (CompactForm (Value era))
compactValueTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall t.
Val t =>
(CompactForm Coin -> CompactForm Coin)
-> CompactForm t -> CompactForm t
modifyCompactCoin (forall a b. a -> b -> a
const (forall a. (HasCallStack, Val a) => a -> CompactForm a
toCompactPartial Coin
c)) CompactForm (Value era)
cVal
)
{-# INLINE coinTxOutL #-}
compactCoinTxOutL :: (HasCallStack, EraTxOut era) => Lens' (TxOut era) (CompactForm Coin)
compactCoinTxOutL :: forall era.
(HasCallStack, EraTxOut era) =>
Lens' (TxOut era) (CompactForm Coin)
compactCoinTxOutL =
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens
( \TxOut era
txOut ->
case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL of
Left Value era
val -> forall a. (HasCallStack, Val a) => a -> CompactForm a
toCompactPartial (forall t. Val t => t -> Coin
coin Value era
val)
Right CompactForm (Value era)
cVal -> forall t. Val t => CompactForm t -> CompactForm Coin
coinCompact CompactForm (Value era)
cVal
)
( \TxOut era
txOut CompactForm Coin
cCoin ->
case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL of
Left Value era
val -> TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era. EraTxOut era => Lens' (TxOut era) (Value era)
valueTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall t. Val t => (Coin -> Coin) -> t -> t
modifyCoin (forall a b. a -> b -> a
const (forall a. Compactible a => CompactForm a -> a
fromCompact CompactForm Coin
cCoin)) Value era
val
Right CompactForm (Value era)
cVal ->
TxOut era
txOut forall a b. a -> (a -> b) -> b
& forall era.
(EraTxOut era, HasCallStack) =>
Lens' (TxOut era) (CompactForm (Value era))
compactValueTxOutL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall t.
Val t =>
(CompactForm Coin -> CompactForm Coin)
-> CompactForm t -> CompactForm t
modifyCompactCoin (forall a b. a -> b -> a
const CompactForm Coin
cCoin) CompactForm (Value era)
cVal
)
{-# INLINE compactCoinTxOutL #-}
isAdaOnlyTxOutF :: EraTxOut era => SimpleGetter (TxOut era) Bool
isAdaOnlyTxOutF :: forall era. EraTxOut era => SimpleGetter (TxOut era) Bool
isAdaOnlyTxOutF = forall s a. (s -> a) -> SimpleGetter s a
to forall a b. (a -> b) -> a -> b
$ \TxOut era
txOut ->
case TxOut era
txOut forall s a. s -> Getting a s a -> a
^. forall era.
EraTxOut era =>
Lens' (TxOut era) (Either (Value era) (CompactForm (Value era)))
valueEitherTxOutL of
Left Value era
val -> forall t. Val t => t -> Bool
isAdaOnly Value era
val
Right CompactForm (Value era)
cVal -> forall t. Val t => CompactForm t -> Bool
isAdaOnlyCompact CompactForm (Value era)
cVal
toCompactPartial :: (HasCallStack, Val a) => a -> CompactForm a
toCompactPartial :: forall a. (HasCallStack, Val a) => a -> CompactForm a
toCompactPartial a
v =
forall a. a -> Maybe a -> a
fromMaybe (forall a. HasCallStack => [Char] -> a
error forall a b. (a -> b) -> a -> b
$ [Char]
"Illegal value in TxOut: " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> [Char]
show a
v) forall a b. (a -> b) -> a -> b
$ forall a. Compactible a => a -> Maybe (CompactForm a)
toCompact a
v
mkCoinTxOut :: EraTxOut era => Addr -> Coin -> TxOut era
mkCoinTxOut :: forall era. EraTxOut era => Addr -> Coin -> TxOut era
mkCoinTxOut Addr
addr = forall era.
(EraTxOut era, HasCallStack) =>
Addr -> Value era -> TxOut era
mkBasicTxOut Addr
addr forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall t s. Inject t s => t -> s
inject
type family Value era :: Type
class
( Era era
, Eq (TxAuxData era)
, EqRaw (TxAuxData era)
, Show (TxAuxData era)
, NoThunks (TxAuxData era)
, ToCBOR (TxAuxData era)
, EncCBOR (TxAuxData era)
, DecCBOR (Annotator (TxAuxData era))
, HashAnnotated (TxAuxData era) EraIndependentTxAuxData
) =>
EraTxAuxData era
where
type TxAuxData era = (r :: Type) | r -> era
mkBasicTxAuxData :: TxAuxData era
metadataTxAuxDataL :: Lens' (TxAuxData era) (Map Word64 Metadatum)
upgradeTxAuxData :: EraTxAuxData (PreviousEra era) => TxAuxData (PreviousEra era) -> TxAuxData era
validateTxAuxData :: ProtVer -> TxAuxData era -> Bool
hashTxAuxData :: EraTxAuxData era => TxAuxData era -> TxAuxDataHash
hashTxAuxData :: forall era. EraTxAuxData era => TxAuxData era -> TxAuxDataHash
hashTxAuxData = SafeHash EraIndependentTxAuxData -> TxAuxDataHash
TxAuxDataHash forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall x i. HashAnnotated x i => x -> SafeHash i
hashAnnotated
class
( EraScript era
, Eq (TxWits era)
, EqRaw (TxWits era)
, Show (TxWits era)
, Monoid (TxWits era)
, NoThunks (TxWits era)
, ToCBOR (TxWits era)
, EncCBOR (TxWits era)
, DecCBOR (Annotator (TxWits era))
) =>
EraTxWits era
where
type TxWits era = (r :: Type) | r -> era
mkBasicTxWits :: TxWits era
mkBasicTxWits = forall a. Monoid a => a
mempty
addrTxWitsL :: Lens' (TxWits era) (Set (WitVKey 'Witness))
bootAddrTxWitsL :: Lens' (TxWits era) (Set BootstrapWitness)
scriptTxWitsL :: Lens' (TxWits era) (Map ScriptHash (Script era))
upgradeTxWits :: EraTxWits (PreviousEra era) => TxWits (PreviousEra era) -> TxWits era
hashScriptTxWitsL ::
EraTxWits era =>
Lens (TxWits era) (TxWits era) (Map ScriptHash (Script era)) [Script era]
hashScriptTxWitsL :: forall era.
EraTxWits era =>
Lens
(TxWits era)
(TxWits era)
(Map ScriptHash (Script era))
[Script era]
hashScriptTxWitsL =
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens
(\TxWits era
wits -> TxWits era
wits forall s a. s -> Getting a s a -> a
^. forall era.
EraTxWits era =>
Lens' (TxWits era) (Map ScriptHash (Script era))
scriptTxWitsL)
(\TxWits era
wits [Script era]
ss -> TxWits era
wits forall a b. a -> (a -> b) -> b
& forall era.
EraTxWits era =>
Lens' (TxWits era) (Map ScriptHash (Script era))
scriptTxWitsL forall s t a b. ASetter s t a b -> b -> s -> t
.~ forall k a. Ord k => [(k, a)] -> Map k a
Map.fromList [(forall era. EraScript era => Script era -> ScriptHash
hashScript Script era
s, Script era
s) | Script era
s <- [Script era]
ss])
{-# INLINEABLE hashScriptTxWitsL #-}
class
( Era era
, Show (Script era)
, Eq (Script era)
, EqRaw (Script era)
, ToCBOR (Script era)
, EncCBOR (Script era)
, DecCBOR (Annotator (Script era))
, NoThunks (Script era)
, SafeToHash (Script era)
, Eq (NativeScript era)
, Show (NativeScript era)
, NFData (NativeScript era)
, NoThunks (NativeScript era)
, EncCBOR (NativeScript era)
, DecCBOR (Annotator (NativeScript era))
) =>
EraScript era
where
type Script era = (r :: Type) | r -> era
type NativeScript era = (r :: Type) | r -> era
upgradeScript :: EraScript (PreviousEra era) => Script (PreviousEra era) -> Script era
scriptPrefixTag :: Script era -> BS.ByteString
getNativeScript :: Script era -> Maybe (NativeScript era)
fromNativeScript :: NativeScript era -> Script era
isNativeScript :: EraScript era => Script era -> Bool
isNativeScript :: forall era. EraScript era => Script era -> Bool
isNativeScript = forall a. Maybe a -> Bool
isJust forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall era. EraScript era => Script era -> Maybe (NativeScript era)
getNativeScript
hashScript :: forall era. EraScript era => Script era -> ScriptHash
hashScript :: forall era. EraScript era => Script era -> ScriptHash
hashScript =
Hash ADDRHASH EraIndependentScript -> ScriptHash
ScriptHash
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall h a b. Hash h a -> Hash h b
Hash.castHash
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall h a. HashAlgorithm h => (a -> ByteString) -> a -> Hash h a
Hash.hashWith
(\Script era
x -> forall era. EraScript era => Script era -> ByteString
scriptPrefixTag @era Script era
x forall a. Semigroup a => a -> a -> a
<> forall t. SafeToHash t => t -> ByteString
originalBytes Script era
x)
class
( EraTx era
, Eq (TxSeq era)
, Show (TxSeq era)
, EncCBORGroup (TxSeq era)
, DecCBOR (Annotator (TxSeq era))
) =>
EraSegWits era
where
type TxSeq era = (r :: Type) | r -> era
fromTxSeq :: TxSeq era -> StrictSeq (Tx era)
toTxSeq :: StrictSeq (Tx era) -> TxSeq era
hashTxSeq :: TxSeq era -> Hash.Hash HASH EraIndependentBlockBody
numSegComponents :: Word64
bBodySize :: forall era. EraSegWits era => ProtVer -> TxSeq era -> Int
bBodySize :: forall era. EraSegWits era => ProtVer -> TxSeq era -> Int
bBodySize (ProtVer Version
v Natural
_) = ByteString -> Int
BS.length forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. EncCBOR a => Version -> a -> ByteString
serialize' Version
v forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. EncCBORGroup a => a -> Encoding
encCBORGroup
txIdTx :: EraTx era => Tx era -> TxId
txIdTx :: forall era. EraTx era => Tx era -> TxId
txIdTx Tx era
tx = forall era. EraTxBody era => TxBody era -> TxId
txIdTxBody (Tx era
tx forall s a. s -> Getting a s a -> a
^. forall era. EraTx era => Lens' (Tx era) (TxBody era)
bodyTxL)
txIdTxBody :: EraTxBody era => TxBody era -> TxId
txIdTxBody :: forall era. EraTxBody era => TxBody era -> TxId
txIdTxBody = SafeHash EraIndependentTxBody -> TxId
TxId forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall x i. HashAnnotated x i => x -> SafeHash i
hashAnnotated