{-# LANGUAGE DataKinds #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DerivingVia #-} {-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE LambdaCase #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE PatternSynonyms #-} {-# LANGUAGE QuantifiedConstraints #-} {-# LANGUAGE StandaloneDeriving #-} {-# LANGUAGE TypeApplications #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE UndecidableInstances #-} {-# LANGUAGE UndecidableSuperClasses #-} {-# LANGUAGE ViewPatterns #-} {-# OPTIONS_GHC -Wno-orphans #-} module Cardano.Ledger.Conway.Scripts ( ConwayEraScript (..), AlonzoScript (..), PlutusScript (..), isPlutusScript, ConwayPlutusPurpose (..), pattern VotingPurpose, pattern ProposingPurpose, ) where import Cardano.Ledger.Address (RewardAccount) import Cardano.Ledger.Allegra.Scripts import Cardano.Ledger.Alonzo.Scripts ( AlonzoPlutusPurpose (..), AlonzoScript (..), alonzoScriptPrefixTag, isPlutusScript, ) import Cardano.Ledger.Babbage.Core import Cardano.Ledger.Babbage.Scripts (PlutusScript (..)) import Cardano.Ledger.BaseTypes (kindObject) import Cardano.Ledger.Binary ( CBORGroup (..), DecCBOR (decCBOR), DecCBORGroup (..), EncCBOR (..), EncCBORGroup (..), decodeWord8, encodeWord8, ) import Cardano.Ledger.Conway.Era import Cardano.Ledger.Conway.Governance.Procedures import Cardano.Ledger.Conway.TxCert () import Cardano.Ledger.Mary.Value (PolicyID) import Cardano.Ledger.Plutus.Language import Cardano.Ledger.Shelley.Scripts (ShelleyEraScript (..)) import Cardano.Ledger.TxIn (TxIn) import Control.DeepSeq (NFData (..), rwhnf) import Data.Aeson (ToJSON (..), (.=)) import Data.MemPack import Data.Typeable import Data.Word (Word16, Word32, Word8) import GHC.Generics import NoThunks.Class (NoThunks (..)) class AlonzoEraScript era => ConwayEraScript era where mkVotingPurpose :: f Word32 Voter -> PlutusPurpose f era toVotingPurpose :: PlutusPurpose f era -> Maybe (f Word32 Voter) mkProposingPurpose :: f Word32 (ProposalProcedure era) -> PlutusPurpose f era toProposingPurpose :: PlutusPurpose f era -> Maybe (f Word32 (ProposalProcedure era)) instance EraScript ConwayEra where type Script ConwayEra = AlonzoScript ConwayEra type NativeScript ConwayEra = Timelock ConwayEra upgradeScript :: EraScript (PreviousEra ConwayEra) => Script (PreviousEra ConwayEra) -> Script ConwayEra upgradeScript = \case TimelockScript Timelock BabbageEra ts -> forall era. Timelock era -> AlonzoScript era TimelockScript forall a b. (a -> b) -> a -> b $ forall era1 era2. (Era era1, Era era2) => Timelock era1 -> Timelock era2 translateTimelock Timelock BabbageEra ts PlutusScript (BabbagePlutusV1 Plutus 'PlutusV1 ps) -> forall era. PlutusScript era -> AlonzoScript era PlutusScript forall a b. (a -> b) -> a -> b $ Plutus 'PlutusV1 -> PlutusScript ConwayEra ConwayPlutusV1 Plutus 'PlutusV1 ps PlutusScript (BabbagePlutusV2 Plutus 'PlutusV2 ps) -> forall era. PlutusScript era -> AlonzoScript era PlutusScript forall a b. (a -> b) -> a -> b $ Plutus 'PlutusV2 -> PlutusScript ConwayEra ConwayPlutusV2 Plutus 'PlutusV2 ps scriptPrefixTag :: Script ConwayEra -> ByteString scriptPrefixTag = forall era. (AlonzoEraScript era, AlonzoScript era ~ Script era) => Script era -> ByteString alonzoScriptPrefixTag getNativeScript :: Script ConwayEra -> Maybe (NativeScript ConwayEra) getNativeScript = \case TimelockScript Timelock ConwayEra ts -> forall a. a -> Maybe a Just Timelock ConwayEra ts Script ConwayEra _ -> forall a. Maybe a Nothing fromNativeScript :: NativeScript ConwayEra -> Script ConwayEra fromNativeScript = forall era. Timelock era -> AlonzoScript era TimelockScript instance AlonzoEraScript ConwayEra where data PlutusScript ConwayEra = ConwayPlutusV1 !(Plutus 'PlutusV1) | ConwayPlutusV2 !(Plutus 'PlutusV2) | ConwayPlutusV3 !(Plutus 'PlutusV3) deriving (PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a /= :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool $c/= :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool == :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool $c== :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool Eq, Eq (PlutusScript ConwayEra) PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool PlutusScript ConwayEra -> PlutusScript ConwayEra -> Ordering PlutusScript ConwayEra -> PlutusScript ConwayEra -> PlutusScript ConwayEra forall a. Eq a -> (a -> a -> Ordering) -> (a -> a -> Bool) -> (a -> a -> Bool) -> (a -> a -> Bool) -> (a -> a -> Bool) -> (a -> a -> a) -> (a -> a -> a) -> Ord a min :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> PlutusScript ConwayEra $cmin :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> PlutusScript ConwayEra max :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> PlutusScript ConwayEra $cmax :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> PlutusScript ConwayEra >= :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool $c>= :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool > :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool $c> :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool <= :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool $c<= :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool < :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool $c< :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Bool compare :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Ordering $ccompare :: PlutusScript ConwayEra -> PlutusScript ConwayEra -> Ordering Ord, Int -> PlutusScript ConwayEra -> ShowS [PlutusScript ConwayEra] -> ShowS PlutusScript ConwayEra -> String forall a. (Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a showList :: [PlutusScript ConwayEra] -> ShowS $cshowList :: [PlutusScript ConwayEra] -> ShowS show :: PlutusScript ConwayEra -> String $cshow :: PlutusScript ConwayEra -> String showsPrec :: Int -> PlutusScript ConwayEra -> ShowS $cshowsPrec :: Int -> PlutusScript ConwayEra -> ShowS Show, forall x. Rep (PlutusScript ConwayEra) x -> PlutusScript ConwayEra forall x. PlutusScript ConwayEra -> Rep (PlutusScript ConwayEra) x forall a. (forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a $cto :: forall x. Rep (PlutusScript ConwayEra) x -> PlutusScript ConwayEra $cfrom :: forall x. PlutusScript ConwayEra -> Rep (PlutusScript ConwayEra) x Generic) type PlutusPurpose f ConwayEra = ConwayPlutusPurpose f ConwayEra eraMaxLanguage :: Language eraMaxLanguage = Language PlutusV3 mkPlutusScript :: forall (l :: Language). PlutusLanguage l => Plutus l -> Maybe (PlutusScript ConwayEra) mkPlutusScript Plutus l plutus = case forall (l :: Language) (proxy :: Language -> *). PlutusLanguage l => proxy l -> SLanguage l plutusSLanguage Plutus l plutus of SLanguage l SPlutusV1 -> forall a. a -> Maybe a Just forall a b. (a -> b) -> a -> b $ Plutus 'PlutusV1 -> PlutusScript ConwayEra ConwayPlutusV1 Plutus l plutus SLanguage l SPlutusV2 -> forall a. a -> Maybe a Just forall a b. (a -> b) -> a -> b $ Plutus 'PlutusV2 -> PlutusScript ConwayEra ConwayPlutusV2 Plutus l plutus SLanguage l SPlutusV3 -> forall a. a -> Maybe a Just forall a b. (a -> b) -> a -> b $ Plutus 'PlutusV3 -> PlutusScript ConwayEra ConwayPlutusV3 Plutus l plutus withPlutusScript :: forall a. PlutusScript ConwayEra -> (forall (l :: Language). PlutusLanguage l => Plutus l -> a) -> a withPlutusScript (ConwayPlutusV1 Plutus 'PlutusV1 plutus) forall (l :: Language). PlutusLanguage l => Plutus l -> a f = forall (l :: Language). PlutusLanguage l => Plutus l -> a f Plutus 'PlutusV1 plutus withPlutusScript (ConwayPlutusV2 Plutus 'PlutusV2 plutus) forall (l :: Language). PlutusLanguage l => Plutus l -> a f = forall (l :: Language). PlutusLanguage l => Plutus l -> a f Plutus 'PlutusV2 plutus withPlutusScript (ConwayPlutusV3 Plutus 'PlutusV3 plutus) forall (l :: Language). PlutusLanguage l => Plutus l -> a f = forall (l :: Language). PlutusLanguage l => Plutus l -> a f Plutus 'PlutusV3 plutus hoistPlutusPurpose :: forall (g :: * -> * -> *) (f :: * -> * -> *). (forall ix it. g ix it -> f ix it) -> PlutusPurpose g ConwayEra -> PlutusPurpose f ConwayEra hoistPlutusPurpose forall ix it. g ix it -> f ix it f = \case ConwaySpending g Word32 TxIn x -> forall (f :: * -> * -> *) era. f Word32 TxIn -> ConwayPlutusPurpose f era ConwaySpending forall a b. (a -> b) -> a -> b $ forall ix it. g ix it -> f ix it f g Word32 TxIn x ConwayMinting g Word32 PolicyID x -> forall (f :: * -> * -> *) era. f Word32 PolicyID -> ConwayPlutusPurpose f era ConwayMinting forall a b. (a -> b) -> a -> b $ forall ix it. g ix it -> f ix it f g Word32 PolicyID x ConwayCertifying g Word32 (TxCert ConwayEra) x -> forall (f :: * -> * -> *) era. f Word32 (TxCert era) -> ConwayPlutusPurpose f era ConwayCertifying forall a b. (a -> b) -> a -> b $ forall ix it. g ix it -> f ix it f g Word32 (TxCert ConwayEra) x ConwayRewarding g Word32 RewardAccount x -> forall (f :: * -> * -> *) era. f Word32 RewardAccount -> ConwayPlutusPurpose f era ConwayRewarding forall a b. (a -> b) -> a -> b $ forall ix it. g ix it -> f ix it f g Word32 RewardAccount x ConwayVoting g Word32 Voter x -> forall (f :: * -> * -> *) era. f Word32 Voter -> ConwayPlutusPurpose f era ConwayVoting forall a b. (a -> b) -> a -> b $ forall ix it. g ix it -> f ix it f g Word32 Voter x ConwayProposing g Word32 (ProposalProcedure ConwayEra) x -> forall (f :: * -> * -> *) era. f Word32 (ProposalProcedure era) -> ConwayPlutusPurpose f era ConwayProposing forall a b. (a -> b) -> a -> b $ forall ix it. g ix it -> f ix it f g Word32 (ProposalProcedure ConwayEra) x mkSpendingPurpose :: forall (f :: * -> * -> *). f Word32 TxIn -> PlutusPurpose f ConwayEra mkSpendingPurpose = forall (f :: * -> * -> *) era. f Word32 TxIn -> ConwayPlutusPurpose f era ConwaySpending toSpendingPurpose :: forall (f :: * -> * -> *). PlutusPurpose f ConwayEra -> Maybe (f Word32 TxIn) toSpendingPurpose (ConwaySpending f Word32 TxIn i) = forall a. a -> Maybe a Just f Word32 TxIn i toSpendingPurpose PlutusPurpose f ConwayEra _ = forall a. Maybe a Nothing mkMintingPurpose :: forall (f :: * -> * -> *). f Word32 PolicyID -> PlutusPurpose f ConwayEra mkMintingPurpose = forall (f :: * -> * -> *) era. f Word32 PolicyID -> ConwayPlutusPurpose f era ConwayMinting toMintingPurpose :: forall (f :: * -> * -> *). PlutusPurpose f ConwayEra -> Maybe (f Word32 PolicyID) toMintingPurpose (ConwayMinting f Word32 PolicyID i) = forall a. a -> Maybe a Just f Word32 PolicyID i toMintingPurpose PlutusPurpose f ConwayEra _ = forall a. Maybe a Nothing mkCertifyingPurpose :: forall (f :: * -> * -> *). f Word32 (TxCert ConwayEra) -> PlutusPurpose f ConwayEra mkCertifyingPurpose = forall (f :: * -> * -> *) era. f Word32 (TxCert era) -> ConwayPlutusPurpose f era ConwayCertifying toCertifyingPurpose :: forall (f :: * -> * -> *). PlutusPurpose f ConwayEra -> Maybe (f Word32 (TxCert ConwayEra)) toCertifyingPurpose (ConwayCertifying f Word32 (TxCert ConwayEra) i) = forall a. a -> Maybe a Just f Word32 (TxCert ConwayEra) i toCertifyingPurpose PlutusPurpose f ConwayEra _ = forall a. Maybe a Nothing mkRewardingPurpose :: forall (f :: * -> * -> *). f Word32 RewardAccount -> PlutusPurpose f ConwayEra mkRewardingPurpose = forall (f :: * -> * -> *) era. f Word32 RewardAccount -> ConwayPlutusPurpose f era ConwayRewarding toRewardingPurpose :: forall (f :: * -> * -> *). PlutusPurpose f ConwayEra -> Maybe (f Word32 RewardAccount) toRewardingPurpose (ConwayRewarding f Word32 RewardAccount i) = forall a. a -> Maybe a Just f Word32 RewardAccount i toRewardingPurpose PlutusPurpose f ConwayEra _ = forall a. Maybe a Nothing upgradePlutusPurposeAsIx :: AlonzoEraScript (PreviousEra ConwayEra) => PlutusPurpose AsIx (PreviousEra ConwayEra) -> PlutusPurpose AsIx ConwayEra upgradePlutusPurposeAsIx = \case AlonzoSpending (AsIx Word32 ix) -> forall (f :: * -> * -> *) era. f Word32 TxIn -> ConwayPlutusPurpose f era ConwaySpending (forall ix it. ix -> AsIx ix it AsIx Word32 ix) AlonzoMinting (AsIx Word32 ix) -> forall (f :: * -> * -> *) era. f Word32 PolicyID -> ConwayPlutusPurpose f era ConwayMinting (forall ix it. ix -> AsIx ix it AsIx Word32 ix) AlonzoCertifying (AsIx Word32 ix) -> forall (f :: * -> * -> *) era. f Word32 (TxCert era) -> ConwayPlutusPurpose f era ConwayCertifying (forall ix it. ix -> AsIx ix it AsIx Word32 ix) AlonzoRewarding (AsIx Word32 ix) -> forall (f :: * -> * -> *) era. f Word32 RewardAccount -> ConwayPlutusPurpose f era ConwayRewarding (forall ix it. ix -> AsIx ix it AsIx Word32 ix) instance ConwayEraScript ConwayEra where mkVotingPurpose :: forall (f :: * -> * -> *). f Word32 Voter -> PlutusPurpose f ConwayEra mkVotingPurpose = forall (f :: * -> * -> *) era. f Word32 Voter -> ConwayPlutusPurpose f era ConwayVoting toVotingPurpose :: forall (f :: * -> * -> *). PlutusPurpose f ConwayEra -> Maybe (f Word32 Voter) toVotingPurpose (ConwayVoting f Word32 Voter i) = forall a. a -> Maybe a Just f Word32 Voter i toVotingPurpose PlutusPurpose f ConwayEra _ = forall a. Maybe a Nothing mkProposingPurpose :: forall (f :: * -> * -> *). f Word32 (ProposalProcedure ConwayEra) -> PlutusPurpose f ConwayEra mkProposingPurpose = forall (f :: * -> * -> *) era. f Word32 (ProposalProcedure era) -> ConwayPlutusPurpose f era ConwayProposing toProposingPurpose :: forall (f :: * -> * -> *). PlutusPurpose f ConwayEra -> Maybe (f Word32 (ProposalProcedure ConwayEra)) toProposingPurpose (ConwayProposing f Word32 (ProposalProcedure ConwayEra) i) = forall a. a -> Maybe a Just f Word32 (ProposalProcedure ConwayEra) i toProposingPurpose PlutusPurpose f ConwayEra _ = forall a. Maybe a Nothing instance ShelleyEraScript ConwayEra where mkRequireSignature :: KeyHash 'Witness -> NativeScript ConwayEra mkRequireSignature = forall era. Era era => KeyHash 'Witness -> Timelock era mkRequireSignatureTimelock getRequireSignature :: NativeScript ConwayEra -> Maybe (KeyHash 'Witness) getRequireSignature = forall era. Era era => Timelock era -> Maybe (KeyHash 'Witness) getRequireSignatureTimelock mkRequireAllOf :: StrictSeq (NativeScript ConwayEra) -> NativeScript ConwayEra mkRequireAllOf = forall era. Era era => StrictSeq (Timelock era) -> Timelock era mkRequireAllOfTimelock getRequireAllOf :: NativeScript ConwayEra -> Maybe (StrictSeq (NativeScript ConwayEra)) getRequireAllOf = forall era. Era era => Timelock era -> Maybe (StrictSeq (Timelock era)) getRequireAllOfTimelock mkRequireAnyOf :: StrictSeq (NativeScript ConwayEra) -> NativeScript ConwayEra mkRequireAnyOf = forall era. Era era => StrictSeq (Timelock era) -> Timelock era mkRequireAnyOfTimelock getRequireAnyOf :: NativeScript ConwayEra -> Maybe (StrictSeq (NativeScript ConwayEra)) getRequireAnyOf = forall era. Era era => Timelock era -> Maybe (StrictSeq (Timelock era)) getRequireAnyOfTimelock mkRequireMOf :: Int -> StrictSeq (NativeScript ConwayEra) -> NativeScript ConwayEra mkRequireMOf = forall era. Era era => Int -> StrictSeq (Timelock era) -> Timelock era mkRequireMOfTimelock getRequireMOf :: NativeScript ConwayEra -> Maybe (Int, StrictSeq (NativeScript ConwayEra)) getRequireMOf = forall era. Era era => Timelock era -> Maybe (Int, StrictSeq (Timelock era)) getRequireMOfTimelock instance AllegraEraScript ConwayEra where mkTimeStart :: SlotNo -> NativeScript ConwayEra mkTimeStart = forall era. Era era => SlotNo -> Timelock era mkTimeStartTimelock getTimeStart :: NativeScript ConwayEra -> Maybe SlotNo getTimeStart = forall era. Era era => Timelock era -> Maybe SlotNo getTimeStartTimelock mkTimeExpire :: SlotNo -> NativeScript ConwayEra mkTimeExpire = forall era. Era era => SlotNo -> Timelock era mkTimeExpireTimelock getTimeExpire :: NativeScript ConwayEra -> Maybe SlotNo getTimeExpire = forall era. Era era => Timelock era -> Maybe SlotNo getTimeExpireTimelock instance NFData (PlutusScript ConwayEra) where rnf :: PlutusScript ConwayEra -> () rnf = forall a. a -> () rwhnf instance NoThunks (PlutusScript ConwayEra) instance SafeToHash (PlutusScript ConwayEra) where originalBytes :: PlutusScript ConwayEra -> ByteString originalBytes PlutusScript ConwayEra ps = forall era a. AlonzoEraScript era => PlutusScript era -> (forall (l :: Language). PlutusLanguage l => Plutus l -> a) -> a withPlutusScript PlutusScript ConwayEra ps forall t. SafeToHash t => t -> ByteString originalBytes instance MemPack (PlutusScript ConwayEra) where packedByteCount :: PlutusScript ConwayEra -> Int packedByteCount = \case ConwayPlutusV1 Plutus 'PlutusV1 script -> Int packedTagByteCount forall a. Num a => a -> a -> a + forall a. MemPack a => a -> Int packedByteCount Plutus 'PlutusV1 script ConwayPlutusV2 Plutus 'PlutusV2 script -> Int packedTagByteCount forall a. Num a => a -> a -> a + forall a. MemPack a => a -> Int packedByteCount Plutus 'PlutusV2 script ConwayPlutusV3 Plutus 'PlutusV3 script -> Int packedTagByteCount forall a. Num a => a -> a -> a + forall a. MemPack a => a -> Int packedByteCount Plutus 'PlutusV3 script packM :: forall s. PlutusScript ConwayEra -> Pack s () packM = \case ConwayPlutusV1 Plutus 'PlutusV1 script -> forall s. Tag -> Pack s () packTagM Tag 0 forall (m :: * -> *) a b. Monad m => m a -> m b -> m b >> forall a s. MemPack a => a -> Pack s () packM Plutus 'PlutusV1 script ConwayPlutusV2 Plutus 'PlutusV2 script -> forall s. Tag -> Pack s () packTagM Tag 1 forall (m :: * -> *) a b. Monad m => m a -> m b -> m b >> forall a s. MemPack a => a -> Pack s () packM Plutus 'PlutusV2 script ConwayPlutusV3 Plutus 'PlutusV3 script -> forall s. Tag -> Pack s () packTagM Tag 2 forall (m :: * -> *) a b. Monad m => m a -> m b -> m b >> forall a s. MemPack a => a -> Pack s () packM Plutus 'PlutusV3 script {-# INLINE packM #-} unpackM :: forall b. Buffer b => Unpack b (PlutusScript ConwayEra) unpackM = forall b. Buffer b => Unpack b Tag unpackTagM forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b >>= \case Tag 0 -> Plutus 'PlutusV1 -> PlutusScript ConwayEra ConwayPlutusV1 forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a b. (MemPack a, Buffer b) => Unpack b a unpackM Tag 1 -> Plutus 'PlutusV2 -> PlutusScript ConwayEra ConwayPlutusV2 forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a b. (MemPack a, Buffer b) => Unpack b a unpackM Tag 2 -> Plutus 'PlutusV3 -> PlutusScript ConwayEra ConwayPlutusV3 forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a b. (MemPack a, Buffer b) => Unpack b a unpackM Tag n -> forall a (m :: * -> *) b. (MemPack a, MonadFail m) => Tag -> m b unknownTagM @(PlutusScript ConwayEra) Tag n {-# INLINE unpackM #-} data ConwayPlutusPurpose f era = ConwaySpending !(f Word32 TxIn) | ConwayMinting !(f Word32 PolicyID) | ConwayCertifying !(f Word32 (TxCert era)) | ConwayRewarding !(f Word32 RewardAccount) | ConwayVoting !(f Word32 Voter) | ConwayProposing !(f Word32 (ProposalProcedure era)) deriving (forall a. (forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a forall (f :: * -> * -> *) era x. Rep (ConwayPlutusPurpose f era) x -> ConwayPlutusPurpose f era forall (f :: * -> * -> *) era x. ConwayPlutusPurpose f era -> Rep (ConwayPlutusPurpose f era) x $cto :: forall (f :: * -> * -> *) era x. Rep (ConwayPlutusPurpose f era) x -> ConwayPlutusPurpose f era $cfrom :: forall (f :: * -> * -> *) era x. ConwayPlutusPurpose f era -> Rep (ConwayPlutusPurpose f era) x Generic) deriving instance Eq (ConwayPlutusPurpose AsIx era) deriving instance Ord (ConwayPlutusPurpose AsIx era) deriving instance Show (ConwayPlutusPurpose AsIx era) instance NoThunks (ConwayPlutusPurpose AsIx era) deriving instance (Eq (TxCert era), EraPParams era) => Eq (ConwayPlutusPurpose AsItem era) deriving instance (Show (TxCert era), EraPParams era) => Show (ConwayPlutusPurpose AsItem era) instance (NoThunks (TxCert era), EraPParams era) => NoThunks (ConwayPlutusPurpose AsItem era) deriving via (CBORGroup (ConwayPlutusPurpose f era)) instance ( forall a b. (EncCBOR a, EncCBOR b) => EncCBOR (f a b) , EraPParams era , Typeable f , EncCBOR (TxCert era) ) => EncCBOR (ConwayPlutusPurpose f era) deriving via (CBORGroup (ConwayPlutusPurpose f era)) instance ( forall a b. (EncCBOR a, EncCBOR b) => EncCBOR (f a b) , forall a b. (DecCBOR a, DecCBOR b) => DecCBOR (f a b) , EraPParams era , Typeable f , EncCBOR (TxCert era) , DecCBOR (TxCert era) ) => DecCBOR (ConwayPlutusPurpose f era) deriving instance (Eq (TxCert era), EraPParams era) => Eq (ConwayPlutusPurpose AsIxItem era) deriving instance (Show (TxCert era), EraPParams era) => Show (ConwayPlutusPurpose AsIxItem era) instance (NoThunks (TxCert era), EraPParams era) => NoThunks (ConwayPlutusPurpose AsIxItem era) instance (forall a b. (NFData a, NFData b) => NFData (f a b), NFData (TxCert era), EraPParams era) => NFData (ConwayPlutusPurpose f era) where rnf :: ConwayPlutusPurpose f era -> () rnf = \case ConwaySpending f Word32 TxIn x -> forall a. NFData a => a -> () rnf f Word32 TxIn x ConwayMinting f Word32 PolicyID x -> forall a. NFData a => a -> () rnf f Word32 PolicyID x ConwayCertifying f Word32 (TxCert era) x -> forall a. NFData a => a -> () rnf f Word32 (TxCert era) x ConwayRewarding f Word32 RewardAccount x -> forall a. NFData a => a -> () rnf f Word32 RewardAccount x ConwayVoting f Word32 Voter x -> forall a. NFData a => a -> () rnf f Word32 Voter x ConwayProposing f Word32 (ProposalProcedure era) x -> forall a. NFData a => a -> () rnf f Word32 (ProposalProcedure era) x instance ( forall a b. (EncCBOR a, EncCBOR b) => EncCBOR (f a b) , EraPParams era , Typeable f , EncCBOR (TxCert era) ) => EncCBORGroup (ConwayPlutusPurpose f era) where listLen :: ConwayPlutusPurpose f era -> Word listLen ConwayPlutusPurpose f era _ = Word 2 listLenBound :: Proxy (ConwayPlutusPurpose f era) -> Word listLenBound Proxy (ConwayPlutusPurpose f era) _ = Word 2 encCBORGroup :: ConwayPlutusPurpose f era -> Encoding encCBORGroup = \case ConwaySpending f Word32 TxIn p -> Word8 -> Encoding encodeWord8 Word8 0 forall a. Semigroup a => a -> a -> a <> forall a. EncCBOR a => a -> Encoding encCBOR f Word32 TxIn p ConwayMinting f Word32 PolicyID p -> Word8 -> Encoding encodeWord8 Word8 1 forall a. Semigroup a => a -> a -> a <> forall a. EncCBOR a => a -> Encoding encCBOR f Word32 PolicyID p ConwayCertifying f Word32 (TxCert era) p -> Word8 -> Encoding encodeWord8 Word8 2 forall a. Semigroup a => a -> a -> a <> forall a. EncCBOR a => a -> Encoding encCBOR f Word32 (TxCert era) p ConwayRewarding f Word32 RewardAccount p -> Word8 -> Encoding encodeWord8 Word8 3 forall a. Semigroup a => a -> a -> a <> forall a. EncCBOR a => a -> Encoding encCBOR f Word32 RewardAccount p ConwayVoting f Word32 Voter p -> Word8 -> Encoding encodeWord8 Word8 4 forall a. Semigroup a => a -> a -> a <> forall a. EncCBOR a => a -> Encoding encCBOR f Word32 Voter p ConwayProposing f Word32 (ProposalProcedure era) p -> Word8 -> Encoding encodeWord8 Word8 5 forall a. Semigroup a => a -> a -> a <> forall a. EncCBOR a => a -> Encoding encCBOR f Word32 (ProposalProcedure era) p encodedGroupSizeExpr :: (forall t. EncCBOR t => Proxy t -> Size) -> Proxy (ConwayPlutusPurpose f era) -> Size encodedGroupSizeExpr forall t. EncCBOR t => Proxy t -> Size size_ Proxy (ConwayPlutusPurpose f era) _proxy = forall a. EncCBOR a => (forall t. EncCBOR t => Proxy t -> Size) -> Proxy a -> Size encodedSizeExpr forall t. EncCBOR t => Proxy t -> Size size_ (forall {k} (t :: k). Proxy t Proxy :: Proxy Word8) forall a. Num a => a -> a -> a + forall a. EncCBOR a => (forall t. EncCBOR t => Proxy t -> Size) -> Proxy a -> Size encodedSizeExpr forall t. EncCBOR t => Proxy t -> Size size_ (forall {k} (t :: k). Proxy t Proxy :: Proxy Word16) instance ( forall a b. (DecCBOR a, DecCBOR b) => DecCBOR (f a b) , EraPParams era , Typeable f , DecCBOR (TxCert era) ) => DecCBORGroup (ConwayPlutusPurpose f era) where decCBORGroup :: forall s. Decoder s (ConwayPlutusPurpose f era) decCBORGroup = forall s. Decoder s Word8 decodeWord8 forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b >>= \case Word8 0 -> forall (f :: * -> * -> *) era. f Word32 TxIn -> ConwayPlutusPurpose f era ConwaySpending forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a s. DecCBOR a => Decoder s a decCBOR Word8 1 -> forall (f :: * -> * -> *) era. f Word32 PolicyID -> ConwayPlutusPurpose f era ConwayMinting forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a s. DecCBOR a => Decoder s a decCBOR Word8 2 -> forall (f :: * -> * -> *) era. f Word32 (TxCert era) -> ConwayPlutusPurpose f era ConwayCertifying forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a s. DecCBOR a => Decoder s a decCBOR Word8 3 -> forall (f :: * -> * -> *) era. f Word32 RewardAccount -> ConwayPlutusPurpose f era ConwayRewarding forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a s. DecCBOR a => Decoder s a decCBOR Word8 4 -> forall (f :: * -> * -> *) era. f Word32 Voter -> ConwayPlutusPurpose f era ConwayVoting forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a s. DecCBOR a => Decoder s a decCBOR Word8 5 -> forall (f :: * -> * -> *) era. f Word32 (ProposalProcedure era) -> ConwayPlutusPurpose f era ConwayProposing forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b <$> forall a s. DecCBOR a => Decoder s a decCBOR Word8 n -> forall (m :: * -> *) a. MonadFail m => String -> m a fail forall a b. (a -> b) -> a -> b $ String "Unexpected tag for ConwayPlutusPurpose: " forall a. Semigroup a => a -> a -> a <> forall a. Show a => a -> String show Word8 n instance ( forall a b. (ToJSON a, ToJSON b) => ToJSON (f a b) , ToJSON (TxCert era) , EraPParams era ) => ToJSON (ConwayPlutusPurpose f era) where toJSON :: ConwayPlutusPurpose f era -> Value toJSON = \case ConwaySpending f Word32 TxIn n -> forall {v}. ToJSON v => Text -> v -> Value kindObjectWithValue Text "ConwaySpending" f Word32 TxIn n ConwayMinting f Word32 PolicyID n -> forall {v}. ToJSON v => Text -> v -> Value kindObjectWithValue Text "ConwayMinting" f Word32 PolicyID n ConwayCertifying f Word32 (TxCert era) n -> forall {v}. ToJSON v => Text -> v -> Value kindObjectWithValue Text "ConwayCertifying" f Word32 (TxCert era) n ConwayRewarding f Word32 RewardAccount n -> forall {v}. ToJSON v => Text -> v -> Value kindObjectWithValue Text "ConwayRewarding" f Word32 RewardAccount n ConwayVoting f Word32 Voter n -> forall {v}. ToJSON v => Text -> v -> Value kindObjectWithValue Text "ConwayVoting" f Word32 Voter n ConwayProposing f Word32 (ProposalProcedure era) n -> forall {v}. ToJSON v => Text -> v -> Value kindObjectWithValue Text "ConwayProposing" f Word32 (ProposalProcedure era) n where kindObjectWithValue :: Text -> v -> Value kindObjectWithValue Text name v n = Text -> [Pair] -> Value kindObject Text name [Key "value" forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv .= v n] pattern VotingPurpose :: ConwayEraScript era => f Word32 Voter -> PlutusPurpose f era pattern $bVotingPurpose :: forall era (f :: * -> * -> *). ConwayEraScript era => f Word32 Voter -> PlutusPurpose f era $mVotingPurpose :: forall {r} {era} {f :: * -> * -> *}. ConwayEraScript era => PlutusPurpose f era -> (f Word32 Voter -> r) -> ((# #) -> r) -> r VotingPurpose c <- (toVotingPurpose -> Just c) where VotingPurpose f Word32 Voter c = forall era (f :: * -> * -> *). ConwayEraScript era => f Word32 Voter -> PlutusPurpose f era mkVotingPurpose f Word32 Voter c pattern ProposingPurpose :: ConwayEraScript era => f Word32 (ProposalProcedure era) -> PlutusPurpose f era pattern $bProposingPurpose :: forall era (f :: * -> * -> *). ConwayEraScript era => f Word32 (ProposalProcedure era) -> PlutusPurpose f era $mProposingPurpose :: forall {r} {era} {f :: * -> * -> *}. ConwayEraScript era => PlutusPurpose f era -> (f Word32 (ProposalProcedure era) -> r) -> ((# #) -> r) -> r ProposingPurpose c <- (toProposingPurpose -> Just c) where ProposingPurpose f Word32 (ProposalProcedure era) c = forall era (f :: * -> * -> *). ConwayEraScript era => f Word32 (ProposalProcedure era) -> PlutusPurpose f era mkProposingPurpose f Word32 (ProposalProcedure era) c