Safe Haskell | Safe-Inferred |
---|---|
Language | GHC2021 |
Smart constructors for creating Hydra protocol transactions to be used in
the Direct
way of talking to the main-chain.
This module also encapsulates the transaction format used when talking to the
cardano-node, which is currently different from the Cardano
,
thus we have not yet "reached" isomorphism
.
Synopsis
- newtype AbortObservation = AbortObservation {
- headId :: HeadId
- data CloseObservation = CloseObservation {
- threadOutput :: ClosedThreadOutput
- headId :: HeadId
- snapshotNumber :: SnapshotNumber
- data CollectComObservation = CollectComObservation {
- threadOutput :: OpenThreadOutput
- headId :: HeadId
- utxoHash :: UTxOHash
- data CommitObservation = CommitObservation {
- commitOutput :: (TxIn, TxOut CtxUTxO)
- party :: Party
- committed :: UTxO
- headId :: HeadId
- data ContestObservation = ContestObservation {
- contestedThreadOutput :: (TxIn, TxOut CtxUTxO)
- headId :: HeadId
- snapshotNumber :: SnapshotNumber
- contestationDeadline :: UTCTime
- contesters :: [PubKeyHash]
- data DecrementObservation = DecrementObservation {
- headId :: HeadId
- newVersion :: SnapshotVersion
- distributedOutputs :: [TxOut CtxUTxO]
- newtype FanoutObservation = FanoutObservation {
- headId :: HeadId
- data HeadObservation
- = NoHeadTx
- | Init InitObservation
- | Abort AbortObservation
- | Commit CommitObservation
- | CollectCom CollectComObservation
- | Deposit DepositObservation
- | Recover RecoverObservation
- | Increment IncrementObservation
- | Decrement DecrementObservation
- | Close CloseObservation
- | Contest ContestObservation
- | Fanout FanoutObservation
- data IncrementObservation = IncrementObservation {
- headId :: HeadId
- newVersion :: SnapshotVersion
- depositTxId :: TxId
- data InitObservation = InitObservation {
- initialThreadUTxO :: (TxIn, TxOut CtxUTxO)
- initials :: [(TxIn, TxOut CtxUTxO)]
- headId :: HeadId
- seedTxIn :: TxIn
- contestationPeriod :: ContestationPeriod
- parties :: [Party]
- participants :: [OnChainId]
- data InitialThreadOutput = InitialThreadOutput {
- initialThreadUTxO :: (TxIn, TxOut CtxUTxO)
- initialContestationPeriod :: ContestationPeriod
- initialParties :: [Party]
- data NotAnInitReason
- newtype UTxOHash = UTxOHash ByteString
- type UTxOWithScript = (TxIn, TxOut CtxUTxO, HashableScriptData)
- headSeedToTxIn :: MonadFail m => HeadSeed -> m TxIn
- observeHeadTx :: NetworkId -> UTxO -> Tx -> HeadObservation
- txInToHeadSeed :: TxIn -> HeadSeed
- headIdToPolicyId :: MonadFail m => HeadId -> m PolicyId
- observeCloseTx :: UTxO -> Tx -> Maybe CloseObservation
- observeCollectComTx :: UTxO -> Tx -> Maybe CollectComObservation
- observeCommitTx :: NetworkId -> UTxO -> Tx -> Maybe CommitObservation
- observeInitTx :: Tx -> Either NotAnInitReason InitObservation
- observeAbortTx :: UTxO -> Tx -> Maybe AbortObservation
- observeIncrementTx :: UTxO -> Tx -> Maybe IncrementObservation
- observeDecrementTx :: UTxO -> Tx -> Maybe DecrementObservation
- observeContestTx :: UTxO -> Tx -> Maybe ContestObservation
- observeFanoutTx :: UTxO -> Tx -> Maybe FanoutObservation
- findStateToken :: TxOut ctx -> Maybe HeadId
- currencySymbolToHeadId :: MonadFail m => CurrencySymbol -> m HeadId
- findHeadAssetId :: TxOut ctx -> Maybe (PolicyId, AssetName)
Documentation
newtype AbortObservation Source #
AbortObservation | |
|
Instances
Generic AbortObservation Source # | |
Defined in Hydra.Chain.Direct.Tx from :: AbortObservation -> Rep AbortObservation x Source # to :: Rep AbortObservation x -> AbortObservation Source # | |
Show AbortObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Eq AbortObservation Source # | |
Defined in Hydra.Chain.Direct.Tx (==) :: AbortObservation -> AbortObservation -> Bool Source # (/=) :: AbortObservation -> AbortObservation -> Bool Source # | |
type Rep AbortObservation Source # | |
Defined in Hydra.Chain.Direct.Tx type Rep AbortObservation = D1 ('MetaData "AbortObservation" "Hydra.Chain.Direct.Tx" "hydra-node-0.20.0-36eQlJ1pRR653kUqePgM5r" 'True) (C1 ('MetaCons "AbortObservation" 'PrefixI 'True) (S1 ('MetaSel ('Just "headId") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 HeadId))) |
data CloseObservation Source #
CloseObservation | |
|
Instances
data CollectComObservation Source #
CollectComObservation | |
|
Instances
Generic CollectComObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Show CollectComObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Eq CollectComObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
type Rep CollectComObservation Source # | |
Defined in Hydra.Chain.Direct.Tx type Rep CollectComObservation = D1 ('MetaData "CollectComObservation" "Hydra.Chain.Direct.Tx" "hydra-node-0.20.0-36eQlJ1pRR653kUqePgM5r" 'False) (C1 ('MetaCons "CollectComObservation" 'PrefixI 'True) (S1 ('MetaSel ('Just "threadOutput") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 OpenThreadOutput) :*: (S1 ('MetaSel ('Just "headId") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 HeadId) :*: S1 ('MetaSel ('Just "utxoHash") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 UTxOHash)))) |
data CommitObservation Source #
Full observation of a commit transaction.
CommitObservation | |
|
Instances
data ContestObservation Source #
ContestObservation | |
|
Instances
data DecrementObservation Source #
DecrementObservation | |
|
Instances
Generic DecrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Show DecrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Eq DecrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx (==) :: DecrementObservation -> DecrementObservation -> Bool Source # (/=) :: DecrementObservation -> DecrementObservation -> Bool Source # | |
type Rep DecrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx type Rep DecrementObservation = D1 ('MetaData "DecrementObservation" "Hydra.Chain.Direct.Tx" "hydra-node-0.20.0-36eQlJ1pRR653kUqePgM5r" 'False) (C1 ('MetaCons "DecrementObservation" 'PrefixI 'True) (S1 ('MetaSel ('Just "headId") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 HeadId) :*: (S1 ('MetaSel ('Just "newVersion") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 SnapshotVersion) :*: S1 ('MetaSel ('Just "distributedOutputs") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TxOut CtxUTxO])))) |
newtype FanoutObservation Source #
FanoutObservation | |
|
Instances
Generic FanoutObservation Source # | |
Defined in Hydra.Chain.Direct.Tx from :: FanoutObservation -> Rep FanoutObservation x Source # to :: Rep FanoutObservation x -> FanoutObservation Source # | |
Show FanoutObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Eq FanoutObservation Source # | |
Defined in Hydra.Chain.Direct.Tx (==) :: FanoutObservation -> FanoutObservation -> Bool Source # (/=) :: FanoutObservation -> FanoutObservation -> Bool Source # | |
type Rep FanoutObservation Source # | |
Defined in Hydra.Chain.Direct.Tx type Rep FanoutObservation = D1 ('MetaData "FanoutObservation" "Hydra.Chain.Direct.Tx" "hydra-node-0.20.0-36eQlJ1pRR653kUqePgM5r" 'True) (C1 ('MetaCons "FanoutObservation" 'PrefixI 'True) (S1 ('MetaSel ('Just "headId") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 HeadId))) |
data HeadObservation Source #
Generalised type for arbitrary Head observations on-chain.
Instances
data IncrementObservation Source #
IncrementObservation | |
|
Instances
Generic IncrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Show IncrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Eq IncrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx (==) :: IncrementObservation -> IncrementObservation -> Bool Source # (/=) :: IncrementObservation -> IncrementObservation -> Bool Source # | |
type Rep IncrementObservation Source # | |
Defined in Hydra.Chain.Direct.Tx type Rep IncrementObservation = D1 ('MetaData "IncrementObservation" "Hydra.Chain.Direct.Tx" "hydra-node-0.20.0-36eQlJ1pRR653kUqePgM5r" 'False) (C1 ('MetaCons "IncrementObservation" 'PrefixI 'True) (S1 ('MetaSel ('Just "headId") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 HeadId) :*: (S1 ('MetaSel ('Just "newVersion") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 SnapshotVersion) :*: S1 ('MetaSel ('Just "depositTxId") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 TxId)))) |
data InitObservation Source #
Data which can be observed from an initTx
.
InitObservation | |
|
Instances
data InitialThreadOutput Source #
Representation of the Head output after an Init transaction.
InitialThreadOutput | |
|
Instances
data NotAnInitReason Source #
Instances
Generic NotAnInitReason Source # | |
Defined in Hydra.Chain.Direct.Tx from :: NotAnInitReason -> Rep NotAnInitReason x Source # to :: Rep NotAnInitReason x -> NotAnInitReason Source # | |
Show NotAnInitReason Source # | |
Defined in Hydra.Chain.Direct.Tx | |
Eq NotAnInitReason Source # | |
Defined in Hydra.Chain.Direct.Tx (==) :: NotAnInitReason -> NotAnInitReason -> Bool Source # (/=) :: NotAnInitReason -> NotAnInitReason -> Bool Source # | |
type Rep NotAnInitReason Source # | |
Defined in Hydra.Chain.Direct.Tx type Rep NotAnInitReason = D1 ('MetaData "NotAnInitReason" "Hydra.Chain.Direct.Tx" "hydra-node-0.20.0-36eQlJ1pRR653kUqePgM5r" 'False) ((C1 ('MetaCons "NoHeadOutput" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "NotAHeadDatum" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "NoSTFound" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "NotAHeadPolicy" 'PrefixI 'False) (U1 :: Type -> Type))) |
Instances
Arbitrary UTxOHash Source # | |
Generic UTxOHash Source # | |
Show UTxOHash Source # | |
Eq UTxOHash Source # | |
type Rep UTxOHash Source # | |
Defined in Hydra.Chain.Direct.Tx type Rep UTxOHash = D1 ('MetaData "UTxOHash" "Hydra.Chain.Direct.Tx" "hydra-node-0.20.0-36eQlJ1pRR653kUqePgM5r" 'True) (C1 ('MetaCons "UTxOHash" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 ByteString))) |
type UTxOWithScript = (TxIn, TxOut CtxUTxO, HashableScriptData) Source #
Needed on-chain data to create Head transactions.
headSeedToTxIn :: MonadFail m => HeadSeed -> m TxIn Source #
observeHeadTx :: NetworkId -> UTxO -> Tx -> HeadObservation Source #
Observe any Hydra head transaction.
txInToHeadSeed :: TxIn -> HeadSeed Source #
headIdToPolicyId :: MonadFail m => HeadId -> m PolicyId Source #
:: UTxO | A UTxO set to lookup tx inputs |
-> Tx | |
-> Maybe CloseObservation |
Identify a close tx by lookup up the input spending the Head output and decoding its redeemer.
:: UTxO | A UTxO set to lookup tx inputs |
-> Tx | |
-> Maybe CollectComObservation |
Identify a collectCom tx by lookup up the input spending the Head output and decoding its redeemer.
:: NetworkId | |
-> UTxO | A UTxO set to lookup tx inputs. Should at least contain the input spending from νInitial. |
-> Tx | |
-> Maybe CommitObservation |
Identify a commit tx by:
- Check that its spending from the init validator,
- Find the outputs which pays to the commit validator,
- Using the datum of that output, deserialize the committed output,
- Reconstruct the committed UTxO from both values (tx input and output).
observeInitTx :: Tx -> Either NotAnInitReason InitObservation Source #
Identify a init tx by checking the output value for holding tokens that are valid head tokens (checked by seed + policy).
:: UTxO | A UTxO set to lookup tx inputs |
-> Tx | |
-> Maybe AbortObservation |
Identify an abort tx by looking up the input spending the Head output and decoding its redeemer.
observeIncrementTx :: UTxO -> Tx -> Maybe IncrementObservation Source #
observeDecrementTx :: UTxO -> Tx -> Maybe DecrementObservation Source #
:: UTxO | A UTxO set to lookup tx inputs |
-> Tx | |
-> Maybe ContestObservation |
Identify a close tx by lookup up the input spending the Head output and decoding its redeemer.
:: UTxO | A UTxO set to lookup tx inputs |
-> Tx | |
-> Maybe FanoutObservation |
Identify a fanout tx by lookup up the input spending the Head output and decoding its redeemer.
findStateToken :: TxOut ctx -> Maybe HeadId Source #
Find (if it exists) the head identifier contained in given TxOut
.
currencySymbolToHeadId :: MonadFail m => CurrencySymbol -> m HeadId Source #
findHeadAssetId :: TxOut ctx -> Maybe (PolicyId, AssetName) Source #