{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DerivingStrategies #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
{-# OPTIONS_GHC -Wno-unticked-promoted-constructors #-}
module Cardano.Api.IPC
(
connectToLocalNode
, connectToLocalNodeWithVersion
, LocalNodeConnectInfo (..)
, LocalNodeClientParams (..)
, mkLocalNodeClientParams
, LocalNodeClientProtocols (..)
, LocalChainSyncClient (..)
, LocalNodeClientProtocolsInMode
, ConsensusModeParams (..)
, EpochSlots (..)
, ChainSyncClient (..)
, ChainSyncClientPipelined (..)
, BlockInMode (..)
, LocalTxSubmissionClient (..)
, TxInMode (..)
, TxValidationErrorInCardanoMode
, TxValidationError
, submitTxToNodeLocal
, SubmitResult (..)
, LocalStateQueryClient (..)
, AcquiringFailure (..)
, QueryInMode (..)
, QueryInEra (..)
, QueryInShelleyBasedEra (..)
, queryNodeLocalState
, LocalTxMonitorClient (..)
, LocalTxMonitoringQuery (..)
, LocalTxMonitoringResult (..)
, Consensus.MempoolSizeAndCapacity (..)
, queryTxMonitoringLocal
, EraHistory (..)
, getProgress
, getLocalChainTip
, toAcquiringFailure
, NodeToClientVersion (..)
, UnsupportedNtcVersionError (..)
)
where
import Cardano.Api.Block
import Cardano.Api.HasTypeProxy
import Cardano.Api.InMode
import Cardano.Api.IO
import Cardano.Api.IPC.Version
import Cardano.Api.Modes
import Cardano.Api.Monad.Error (ExceptT (..))
import Cardano.Api.NetworkId
import Cardano.Api.Protocol
import Cardano.Api.Query
import Cardano.Api.Tx.Body
import Cardano.Api.Tx.Sign
import qualified Cardano.Ledger.Api as L
import qualified Ouroboros.Consensus.Block as Consensus
import qualified Ouroboros.Consensus.Cardano.Block as Consensus
import Ouroboros.Consensus.Cardano.CanHardFork
import qualified Ouroboros.Consensus.Ledger.Query as Consensus
import qualified Ouroboros.Consensus.Ledger.SupportsMempool as Consensus
import qualified Ouroboros.Consensus.Ledger.SupportsProtocol as Consensus
import qualified Ouroboros.Consensus.Network.NodeToClient as Consensus
import qualified Ouroboros.Consensus.Node.NetworkProtocolVersion as Consensus
import qualified Ouroboros.Consensus.Node.ProtocolInfo as Consensus
import qualified Ouroboros.Consensus.Protocol.TPraos as Consensus
import qualified Ouroboros.Consensus.Shelley.Ledger.Block as Consensus
import Ouroboros.Consensus.Shelley.Ledger.SupportsProtocol ()
import qualified Ouroboros.Network.Block as Net
import qualified Ouroboros.Network.Mux as Net
import Ouroboros.Network.NodeToClient (NodeToClientProtocols (..),
NodeToClientVersionData (..))
import qualified Ouroboros.Network.NodeToClient as Net
import Ouroboros.Network.NodeToClient.Version (NodeToClientVersion (..))
import Ouroboros.Network.Protocol.ChainSync.Client as Net.Sync
import Ouroboros.Network.Protocol.ChainSync.ClientPipelined as Net.SyncP
import Ouroboros.Network.Protocol.LocalStateQuery.Client (LocalStateQueryClient (..))
import qualified Ouroboros.Network.Protocol.LocalStateQuery.Client as Net.Query
import Ouroboros.Network.Protocol.LocalStateQuery.Type (AcquireFailure (..))
import qualified Ouroboros.Network.Protocol.LocalStateQuery.Type as Net.Query
import Ouroboros.Network.Protocol.LocalTxMonitor.Client (LocalTxMonitorClient (..),
localTxMonitorClientPeer)
import qualified Ouroboros.Network.Protocol.LocalTxMonitor.Client as CTxMon
import qualified Ouroboros.Network.Protocol.LocalTxMonitor.Type as Consensus
import Ouroboros.Network.Protocol.LocalTxSubmission.Client (LocalTxSubmissionClient (..),
SubmitResult (..))
import qualified Ouroboros.Network.Protocol.LocalTxSubmission.Client as Net.Tx
import Control.Concurrent.STM (TMVar, atomically, newEmptyTMVarIO, putTMVar, takeTMVar,
tryPutTMVar)
import Control.Exception (throwIO)
import Control.Monad (void)
import Control.Monad.IO.Class
import Control.Tracer (nullTracer)
import Data.Aeson (ToJSON, object, toJSON, (.=))
import qualified Data.ByteString.Lazy as LBS
import Data.Void (Void)
import GHC.Exts (IsList (..))
import qualified Network.Mux as Net
data LocalNodeClientProtocols block point tip slot tx txid txerr query m
= LocalNodeClientProtocols
{ forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> LocalChainSyncClient block point tip m
localChainSyncClient :: LocalChainSyncClient block point tip m
, forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> Maybe (LocalTxSubmissionClient tx txerr m ())
localTxSubmissionClient :: Maybe (LocalTxSubmissionClient tx txerr m ())
, forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> Maybe (LocalStateQueryClient block point query m ())
localStateQueryClient :: Maybe (LocalStateQueryClient block point query m ())
, forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> Maybe (LocalTxMonitorClient txid tx slot m ())
localTxMonitoringClient :: Maybe (LocalTxMonitorClient txid tx slot m ())
}
data LocalChainSyncClient block point tip m
= NoLocalChainSyncClient
| LocalChainSyncClientPipelined (ChainSyncClientPipelined block point tip m ())
| LocalChainSyncClient (ChainSyncClient block point tip m ())
type LocalNodeClientProtocolsInMode =
LocalNodeClientProtocols
BlockInMode
ChainPoint
ChainTip
SlotNo
TxInMode
TxIdInMode
TxValidationErrorInCardanoMode
QueryInMode
IO
data LocalNodeConnectInfo
= LocalNodeConnectInfo
{ LocalNodeConnectInfo -> ConsensusModeParams
localConsensusModeParams :: ConsensusModeParams
, LocalNodeConnectInfo -> NetworkId
localNodeNetworkId :: NetworkId
, LocalNodeConnectInfo -> SocketPath
localNodeSocketPath :: SocketPath
}
connectToLocalNode
:: MonadIO m
=> LocalNodeConnectInfo
-> LocalNodeClientProtocolsInMode
-> m ()
connectToLocalNode :: forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
connectToLocalNode LocalNodeConnectInfo
localNodeConnectInfo LocalNodeClientProtocolsInMode
handlers =
LocalNodeConnectInfo
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode) -> m ()
forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode) -> m ()
connectToLocalNodeWithVersion LocalNodeConnectInfo
localNodeConnectInfo (LocalNodeClientProtocolsInMode
-> NodeToClientVersion -> LocalNodeClientProtocolsInMode
forall a b. a -> b -> a
const LocalNodeClientProtocolsInMode
handlers)
connectToLocalNodeWithVersion
:: MonadIO m
=> LocalNodeConnectInfo
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode)
-> m ()
connectToLocalNodeWithVersion :: forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode) -> m ()
connectToLocalNodeWithVersion
LocalNodeConnectInfo
{ SocketPath
localNodeSocketPath :: LocalNodeConnectInfo -> SocketPath
localNodeSocketPath :: SocketPath
localNodeSocketPath
, NetworkId
localNodeNetworkId :: LocalNodeConnectInfo -> NetworkId
localNodeNetworkId :: NetworkId
localNodeNetworkId
, ConsensusModeParams
localConsensusModeParams :: LocalNodeConnectInfo -> ConsensusModeParams
localConsensusModeParams :: ConsensusModeParams
localConsensusModeParams
}
NodeToClientVersion -> LocalNodeClientProtocolsInMode
clients =
IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ (IOManager -> IO ()) -> IO ()
WithIOManager
Net.withIOManager ((IOManager -> IO ()) -> IO ()) -> (IOManager -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \IOManager
iomgr -> do
Either SomeException ()
r <-
LocalSnocket
-> NetworkConnectTracers LocalAddress NodeToClientVersion
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
-> FilePath
-> IO (Either SomeException ())
forall a.
LocalSnocket
-> NetworkConnectTracers LocalAddress NodeToClientVersion
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a Void)
-> FilePath
-> IO (Either SomeException a)
Net.connectTo
(IOManager -> LocalSnocket
Net.localSnocket IOManager
iomgr)
Net.NetworkConnectTracers
{ nctMuxTracer :: Tracer IO (WithBearer (ConnectionId LocalAddress) Trace)
Net.nctMuxTracer = Tracer IO (WithBearer (ConnectionId LocalAddress) Trace)
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer
, nctHandshakeTracer :: Tracer
IO
(WithBearer
(ConnectionId LocalAddress)
(TraceSendRecv (Handshake NodeToClientVersion Term)))
Net.nctHandshakeTracer = Tracer
IO
(WithBearer
(ConnectionId LocalAddress)
(TraceSendRecv (Handshake NodeToClientVersion Term)))
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer
}
Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
versionedProtocls
(SocketPath -> FilePath
forall content (direction :: FileDirection).
File content direction -> FilePath
unFile SocketPath
localNodeSocketPath)
case Either SomeException ()
r of
Left SomeException
e -> SomeException -> IO ()
forall e a. Exception e => e -> IO a
throwIO SomeException
e
Right ()
_ -> () -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ()
where
versionedProtocls :: Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
versionedProtocls =
case ConsensusModeParams
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode)
-> LocalNodeClientParams
mkLocalNodeClientParams ConsensusModeParams
localConsensusModeParams NodeToClientVersion -> LocalNodeClientProtocolsInMode
clients of
LocalNodeClientParamsSingleBlock ProtocolClientInfoArgs block
ptcl NodeToClientVersion -> LocalNodeClientProtocolsForBlock block
clients' ->
NetworkId
-> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
forall block.
(ShowQuery (Query block), ProtocolClient block) =>
NetworkId
-> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
mkVersionedProtocols NetworkId
localNodeNetworkId ProtocolClientInfoArgs block
ptcl NodeToClientVersion -> LocalNodeClientProtocolsForBlock block
clients'
LocalNodeClientParamsCardano ProtocolClientInfoArgs block
ptcl NodeToClientVersion -> LocalNodeClientProtocolsForBlock block
clients' ->
NetworkId
-> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
forall block.
(ShowQuery (Query block), ProtocolClient block) =>
NetworkId
-> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
mkVersionedProtocols NetworkId
localNodeNetworkId ProtocolClientInfoArgs block
ptcl NodeToClientVersion -> LocalNodeClientProtocolsForBlock block
clients'
mkVersionedProtocols
:: forall block
. ( Consensus.ShowQuery (Consensus.Query block)
, ProtocolClient block
)
=> NetworkId
-> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> Net.Versions
Net.NodeToClientVersion
Net.NodeToClientVersionData
( Net.OuroborosApplicationWithMinimalCtx
Net.InitiatorMode
Net.LocalAddress
LBS.ByteString
IO
()
Void
)
mkVersionedProtocols :: forall block.
(ShowQuery (Query block), ProtocolClient block) =>
NetworkId
-> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
mkVersionedProtocols NetworkId
networkid ProtocolClientInfoArgs block
ptcl NodeToClientVersion -> LocalNodeClientProtocolsForBlock block
unversionedClients =
((NodeToClientVersion, BlockNodeToClientVersion block)
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void))
-> [(NodeToClientVersion, BlockNodeToClientVersion block)]
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
forall vNum (f :: * -> *) x extra r.
(Ord vNum, Foldable f, HasCallStack) =>
(x -> Versions vNum extra r) -> f x -> Versions vNum extra r
Net.foldMapVersions
( \(NodeToClientVersion
ptclVersion, BlockNodeToClientVersion block
ptclBlockVersion) ->
NodeToClientVersion
-> NodeToClientVersionData
-> NodeToClientProtocols
'InitiatorMode LocalAddress ByteString IO () Void
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
forall (appType :: Mode) bytes (m :: * -> *) a b.
NodeToClientVersion
-> NodeToClientVersionData
-> NodeToClientProtocols appType LocalAddress bytes m a b
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
appType LocalAddress bytes m a b)
Net.versionedNodeToClientProtocols
NodeToClientVersion
ptclVersion
NodeToClientVersionData
{ networkMagic :: NetworkMagic
networkMagic = NetworkId -> NetworkMagic
toNetworkMagic NetworkId
networkid
, query :: Bool
query = Bool
False
}
(LocalNodeClientProtocolsForBlock block
-> BlockNodeToClientVersion block
-> NodeToClientVersion
-> NodeToClientProtocols
'InitiatorMode LocalAddress ByteString IO () Void
protocols (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block
unversionedClients NodeToClientVersion
ptclVersion) BlockNodeToClientVersion block
ptclBlockVersion NodeToClientVersion
ptclVersion)
)
(Map NodeToClientVersion (BlockNodeToClientVersion block)
-> [Item
(Map NodeToClientVersion (BlockNodeToClientVersion block))]
forall l. IsList l => l -> [Item l]
toList (Proxy block
-> Map NodeToClientVersion (BlockNodeToClientVersion block)
forall blk.
SupportedNetworkProtocolVersion blk =>
Proxy blk -> Map NodeToClientVersion (BlockNodeToClientVersion blk)
Consensus.supportedNodeToClientVersions Proxy block
proxy))
where
proxy :: Proxy block
proxy :: Proxy block
proxy = Proxy block
forall {k} (t :: k). Proxy t
Proxy
protocols
:: LocalNodeClientProtocolsForBlock block
-> Consensus.BlockNodeToClientVersion block
-> NodeToClientVersion
-> NodeToClientProtocols Net.InitiatorMode Net.LocalAddress LBS.ByteString IO () Void
protocols :: LocalNodeClientProtocolsForBlock block
-> BlockNodeToClientVersion block
-> NodeToClientVersion
-> NodeToClientProtocols
'InitiatorMode LocalAddress ByteString IO () Void
protocols
LocalNodeClientProtocolsForBlock
{ LocalChainSyncClient block (Point block) (Tip block) IO
localChainSyncClientForBlock :: LocalChainSyncClient block (Point block) (Tip block) IO
localChainSyncClientForBlock :: forall block.
LocalNodeClientProtocolsForBlock block
-> LocalChainSyncClient block (Point block) (Tip block) IO
localChainSyncClientForBlock
, Maybe
(LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ())
localTxSubmissionClientForBlock :: Maybe
(LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ())
localTxSubmissionClientForBlock :: forall block.
LocalNodeClientProtocolsForBlock block
-> Maybe
(LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ())
localTxSubmissionClientForBlock
, Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
localStateQueryClientForBlock :: Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
localStateQueryClientForBlock :: forall block.
LocalNodeClientProtocolsForBlock block
-> Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
localStateQueryClientForBlock
, Maybe
(LocalTxMonitorClient (GenTxId block) (GenTx block) SlotNo IO ())
localTxMonitoringClientForBlock :: Maybe
(LocalTxMonitorClient (GenTxId block) (GenTx block) SlotNo IO ())
localTxMonitoringClientForBlock :: forall block.
LocalNodeClientProtocolsForBlock block
-> Maybe
(LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo IO ())
localTxMonitoringClientForBlock
}
BlockNodeToClientVersion block
ptclBlockVersion
NodeToClientVersion
ptclVersion =
NodeToClientProtocols
{ localChainSyncProtocol :: RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
localChainSyncProtocol =
MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall initiatorCtx bytes (m :: * -> *) a responderCtx.
MiniProtocolCb initiatorCtx bytes m a
-> RunMiniProtocol
'InitiatorMode initiatorCtx responderCtx bytes m a Void
Net.InitiatorProtocolOnly (MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall a b. (a -> b) -> a -> b
$ case LocalChainSyncClient block (Point block) (Tip block) IO
localChainSyncClientForBlock of
LocalChainSyncClient block (Point block) (Tip block) IO
NoLocalChainSyncClient ->
(MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall (pr :: PeerRole) ps (st :: ps) failure bytes ctx
(m :: * -> *) a.
(MonadThrow m, ShowProxy ps,
forall (st' :: ps) stok. (stok ~ StateToken st') => Show stok,
Show failure) =>
(ctx
-> (Tracer m (TraceSendRecv ps), Codec ps failure m bytes,
Peer ps pr 'NonPipelined st m a))
-> MiniProtocolCb ctx bytes m a
Net.mkMiniProtocolCbFromPeer ((MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ())
-> (MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall a b. (a -> b) -> a -> b
$
(Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
())
-> MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
())
forall a b. a -> b -> a
const
(Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block)))
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer, Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString
cChainSyncCodec, Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()
forall header point tip (m :: * -> *) a.
MonadDelay m =>
Client (ChainSync header point tip) 'NonPipelined 'StIdle m a
Net.chainSyncPeerNull)
LocalChainSyncClient ChainSyncClient block (Point block) (Tip block) IO ()
client ->
(MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall (pr :: PeerRole) ps (st :: ps) failure bytes ctx
(m :: * -> *) a.
(MonadThrow m, ShowProxy ps,
forall (st' :: ps) stok. (stok ~ StateToken st') => Show stok,
Show failure) =>
(ctx
-> (Tracer m (TraceSendRecv ps), Codec ps failure m bytes,
Peer ps pr 'NonPipelined st m a))
-> MiniProtocolCb ctx bytes m a
Net.mkMiniProtocolCbFromPeer ((MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ())
-> (MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall a b. (a -> b) -> a -> b
$
(Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
())
-> MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
())
forall a b. a -> b -> a
const
(Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block)))
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer, Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString
cChainSyncCodec, ChainSyncClient block (Point block) (Tip block) IO ()
-> Peer
(ChainSync block (Point block) (Tip block))
'AsClient
'NonPipelined
'StIdle
IO
()
forall header point tip (m :: * -> *) a.
Monad m =>
ChainSyncClient header point tip m a
-> Client (ChainSync header point tip) 'NonPipelined 'StIdle m a
Net.Sync.chainSyncClientPeer ChainSyncClient block (Point block) (Tip block) IO ()
client)
LocalChainSyncClientPipelined ChainSyncClientPipelined block (Point block) (Tip block) IO ()
clientPipelined ->
(MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
PeerPipelined
(ChainSync block (Point block) (Tip block))
'AsClient
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall (pr :: PeerRole) ps (st :: ps) failure ctx bytes
(m :: * -> *) a.
(MonadAsync m, MonadThrow m, ShowProxy ps,
forall (st' :: ps) stok. (stok ~ StateToken st') => Show stok,
Show failure) =>
(ctx
-> (Tracer m (TraceSendRecv ps), Codec ps failure m bytes,
PeerPipelined ps pr st m a))
-> MiniProtocolCb ctx bytes m a
Net.mkMiniProtocolCbFromPeerPipelined ((MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
PeerPipelined
(ChainSync block (Point block) (Tip block))
'AsClient
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ())
-> (MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
PeerPipelined
(ChainSync block (Point block) (Tip block))
'AsClient
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall a b. (a -> b) -> a -> b
$
(Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
PeerPipelined
(ChainSync block (Point block) (Tip block))
'AsClient
'StIdle
IO
())
-> MinimalInitiatorContext LocalAddress
-> (Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block))),
Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString,
PeerPipelined
(ChainSync block (Point block) (Tip block))
'AsClient
'StIdle
IO
())
forall a b. a -> b -> a
const
(Tracer
IO (TraceSendRecv (ChainSync block (Point block) (Tip block)))
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer, Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString
cChainSyncCodec, ChainSyncClientPipelined block (Point block) (Tip block) IO ()
-> PeerPipelined
(ChainSync block (Point block) (Tip block)) 'AsClient 'StIdle IO ()
forall header point tip (m :: * -> *) a.
Monad m =>
ChainSyncClientPipelined header point tip m a
-> ClientPipelined (ChainSync header point tip) 'StIdle m a
Net.SyncP.chainSyncClientPeerPipelined ChainSyncClientPipelined block (Point block) (Tip block) IO ()
clientPipelined)
, localTxSubmissionProtocol :: RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
localTxSubmissionProtocol =
MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall initiatorCtx bytes (m :: * -> *) a responderCtx.
MiniProtocolCb initiatorCtx bytes m a
-> RunMiniProtocol
'InitiatorMode initiatorCtx responderCtx bytes m a Void
Net.InitiatorProtocolOnly (MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall a b. (a -> b) -> a -> b
$
(MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxSubmission (GenTx block) (ApplyTxErr block))),
Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall (pr :: PeerRole) ps (st :: ps) failure bytes ctx
(m :: * -> *) a.
(MonadThrow m, ShowProxy ps,
forall (st' :: ps) stok. (stok ~ StateToken st') => Show stok,
Show failure) =>
(ctx
-> (Tracer m (TraceSendRecv ps), Codec ps failure m bytes,
Peer ps pr 'NonPipelined st m a))
-> MiniProtocolCb ctx bytes m a
Net.mkMiniProtocolCbFromPeer ((MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxSubmission (GenTx block) (ApplyTxErr block))),
Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ())
-> (MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxSubmission (GenTx block) (ApplyTxErr block))),
Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall a b. (a -> b) -> a -> b
$
(Tracer
IO
(TraceSendRecv
(LocalTxSubmission (GenTx block) (ApplyTxErr block))),
Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
())
-> MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxSubmission (GenTx block) (ApplyTxErr block))),
Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
())
forall a b. a -> b -> a
const
( Tracer
IO
(TraceSendRecv
(LocalTxSubmission (GenTx block) (ApplyTxErr block)))
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer
, Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString
cTxSubmissionCodec
, Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
()
-> (LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ()
-> Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
())
-> Maybe
(LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ())
-> Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
()
forall b a. b -> (a -> b) -> Maybe a -> b
maybe
Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
()
forall tx reject (m :: * -> *) a.
MonadDelay m =>
Client (LocalTxSubmission tx reject) 'NonPipelined 'StIdle m a
Net.localTxSubmissionPeerNull
LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ()
-> Peer
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
'AsClient
'NonPipelined
'StIdle
IO
()
forall tx reject (m :: * -> *) a.
Monad m =>
LocalTxSubmissionClient tx reject m a
-> Client (LocalTxSubmission tx reject) 'NonPipelined 'StIdle m a
Net.Tx.localTxSubmissionClientPeer
Maybe
(LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ())
localTxSubmissionClientForBlock
)
, localStateQueryProtocol :: RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
localStateQueryProtocol =
MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall initiatorCtx bytes (m :: * -> *) a responderCtx.
MiniProtocolCb initiatorCtx bytes m a
-> RunMiniProtocol
'InitiatorMode initiatorCtx responderCtx bytes m a Void
Net.InitiatorProtocolOnly (MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall a b. (a -> b) -> a -> b
$
(MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalStateQuery block (Point block) (Query block)) State),
Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString,
State 'StIdle,
Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall (pr :: PeerRole) ps (f :: ps -> *) (st :: ps) failure bytes
ctx (m :: * -> *) a.
(MonadAsync m, MonadMask m, ShowProxy ps,
forall (st' :: ps) stok. (stok ~ StateToken st') => Show stok,
Show failure) =>
(ctx
-> (Tracer m (TraceSendRecv ps f), Codec ps failure f m bytes,
f st, Peer ps pr st f m a))
-> MiniProtocolCb ctx bytes m a
Net.mkMiniProtocolCbFromPeerSt ((MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalStateQuery block (Point block) (Query block)) State),
Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString,
State 'StIdle,
Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ())
-> (MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalStateQuery block (Point block) (Query block)) State),
Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString,
State 'StIdle,
Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall a b. (a -> b) -> a -> b
$
(Tracer
IO
(TraceSendRecv
(LocalStateQuery block (Point block) (Query block)) State),
Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString,
State 'StIdle,
Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
())
-> MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalStateQuery block (Point block) (Query block)) State),
Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString,
State 'StIdle,
Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
())
forall a b. a -> b -> a
const
( Tracer
IO
(TraceSendRecv
(LocalStateQuery block (Point block) (Query block)) State)
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer
, Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString
cStateQueryCodec
, State 'StIdle
forall {block} {point} {query :: * -> *}. State 'StIdle
Net.Query.StateIdle
, Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
()
-> (LocalStateQueryClient block (Point block) (Query block) IO ()
-> Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
())
-> Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
-> Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
()
forall b a. b -> (a -> b) -> Maybe a -> b
maybe
Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
()
forall block point (query :: * -> *) (m :: * -> *) a.
MonadDelay m =>
Client (LocalStateQuery block point query) 'StIdle State m a
Net.localStateQueryPeerNull
LocalStateQueryClient block (Point block) (Query block) IO ()
-> Peer
(LocalStateQuery block (Point block) (Query block))
'AsClient
'StIdle
State
IO
()
forall block point (query :: * -> *) (m :: * -> *) a.
Monad m =>
LocalStateQueryClient block point query m a
-> Client (LocalStateQuery block point query) 'StIdle State m a
Net.Query.localStateQueryClientPeer
Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
localStateQueryClientForBlock
)
, localTxMonitorProtocol :: RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
localTxMonitorProtocol =
MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall initiatorCtx bytes (m :: * -> *) a responderCtx.
MiniProtocolCb initiatorCtx bytes m a
-> RunMiniProtocol
'InitiatorMode initiatorCtx responderCtx bytes m a Void
Net.InitiatorProtocolOnly (MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void)
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
-> RunMiniProtocolWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO () Void
forall a b. (a -> b) -> a -> b
$
(MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)),
Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall (pr :: PeerRole) ps (st :: ps) failure bytes ctx
(m :: * -> *) a.
(MonadThrow m, ShowProxy ps,
forall (st' :: ps) stok. (stok ~ StateToken st') => Show stok,
Show failure) =>
(ctx
-> (Tracer m (TraceSendRecv ps), Codec ps failure m bytes,
Peer ps pr 'NonPipelined st m a))
-> MiniProtocolCb ctx bytes m a
Net.mkMiniProtocolCbFromPeer ((MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)),
Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ())
-> (MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)),
Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
()))
-> MiniProtocolCb
(MinimalInitiatorContext LocalAddress) ByteString IO ()
forall a b. (a -> b) -> a -> b
$
(Tracer
IO
(TraceSendRecv
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)),
Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
())
-> MinimalInitiatorContext LocalAddress
-> (Tracer
IO
(TraceSendRecv
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)),
Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString,
Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
())
forall a b. a -> b -> a
const
( Tracer
IO
(TraceSendRecv
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo))
forall (m :: * -> *) a. Applicative m => Tracer m a
nullTracer
, Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString
cTxMonitorCodec
, Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
()
-> (LocalTxMonitorClient (GenTxId block) (GenTx block) SlotNo IO ()
-> Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
())
-> Maybe
(LocalTxMonitorClient (GenTxId block) (GenTx block) SlotNo IO ())
-> Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
()
forall b a. b -> (a -> b) -> Maybe a -> b
maybe
Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
()
forall txid tx slot (m :: * -> *) a.
MonadDelay m =>
Client (LocalTxMonitor txid tx slot) 'NonPipelined 'StIdle m a
Net.localTxMonitorPeerNull
LocalTxMonitorClient (GenTxId block) (GenTx block) SlotNo IO ()
-> Peer
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
'AsClient
'NonPipelined
'StIdle
IO
()
forall txid tx slot (m :: * -> *) a.
Monad m =>
LocalTxMonitorClient txid tx slot m a
-> Client (LocalTxMonitor txid tx slot) 'NonPipelined 'StIdle m a
localTxMonitorClientPeer
Maybe
(LocalTxMonitorClient (GenTxId block) (GenTx block) SlotNo IO ())
localTxMonitoringClientForBlock
)
}
where
Consensus.Codecs
{ Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString
cChainSyncCodec :: Codec
(ChainSync block (Point block) (Tip block))
DeserialiseFailure
IO
ByteString
cChainSyncCodec :: forall {k} blk (serialisedBlk :: k) e (m :: * -> *) bCS bTX bSQ
bTM.
Codecs' blk serialisedBlk e m bCS bTX bSQ bTM
-> Codec (ChainSync serialisedBlk (Point blk) (Tip blk)) e m bCS
Consensus.cChainSyncCodec
, Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString
cTxMonitorCodec :: Codec
(LocalTxMonitor (GenTxId block) (GenTx block) SlotNo)
DeserialiseFailure
IO
ByteString
cTxMonitorCodec :: forall {k} blk (serialisedBlk :: k) e (m :: * -> *) bCS bTX bSQ
bTM.
Codecs' blk serialisedBlk e m bCS bTX bSQ bTM
-> Codec (LocalTxMonitor (GenTxId blk) (GenTx blk) SlotNo) e m bTM
Consensus.cTxMonitorCodec
, Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString
cTxSubmissionCodec :: Codec
(LocalTxSubmission (GenTx block) (ApplyTxErr block))
DeserialiseFailure
IO
ByteString
cTxSubmissionCodec :: forall {k} blk (serialisedBlk :: k) e (m :: * -> *) bCS bTX bSQ
bTM.
Codecs' blk serialisedBlk e m bCS bTX bSQ bTM
-> Codec (LocalTxSubmission (GenTx blk) (ApplyTxErr blk)) e m bTX
Consensus.cTxSubmissionCodec
, Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString
cStateQueryCodec :: Codec
(LocalStateQuery block (Point block) (Query block))
DeserialiseFailure
State
IO
ByteString
cStateQueryCodec :: forall {k} blk (serialisedBlk :: k) e (m :: * -> *) bCS bTX bSQ
bTM.
Codecs' blk serialisedBlk e m bCS bTX bSQ bTM
-> Codec
(LocalStateQuery blk (Point blk) (Query blk)) e State m bSQ
Consensus.cStateQueryCodec
} = CodecConfig block
-> BlockNodeToClientVersion block
-> NodeToClientVersion
-> Codecs'
block
block
DeserialiseFailure
IO
ByteString
ByteString
ByteString
ByteString
forall (m :: * -> *) blk.
(MonadST m, SerialiseNodeToClientConstraints blk,
ShowQuery (BlockQuery blk), StandardHash blk,
Serialise (HeaderHash blk)) =>
CodecConfig blk
-> BlockNodeToClientVersion blk
-> NodeToClientVersion
-> ClientCodecs blk m
Consensus.clientCodecs CodecConfig block
codecConfig BlockNodeToClientVersion block
ptclBlockVersion NodeToClientVersion
ptclVersion
codecConfig :: Consensus.CodecConfig block
codecConfig :: CodecConfig block
codecConfig =
ProtocolClientInfo block -> CodecConfig block
forall b. ProtocolClientInfo b -> CodecConfig b
Consensus.pClientInfoCodecConfig
(ProtocolClientInfoArgs block -> ProtocolClientInfo block
forall blk.
ProtocolClient blk =>
ProtocolClientInfoArgs blk -> ProtocolClientInfo blk
protocolClientInfo ProtocolClientInfoArgs block
ptcl)
data LocalNodeClientParams where
LocalNodeClientParamsSingleBlock
:: ( ProtocolClient block
, Consensus.LedgerSupportsProtocol
( Consensus.ShelleyBlock
(Consensus.TPraos Consensus.StandardCrypto)
(Consensus.ShelleyEra Consensus.StandardCrypto)
)
)
=> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> LocalNodeClientParams
LocalNodeClientParamsCardano
:: (ProtocolClient block, CardanoHardForkConstraints (ConsensusCryptoForBlock block))
=> ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> LocalNodeClientParams
data LocalNodeClientProtocolsForBlock block
= LocalNodeClientProtocolsForBlock
{ forall block.
LocalNodeClientProtocolsForBlock block
-> LocalChainSyncClient block (Point block) (Tip block) IO
localChainSyncClientForBlock
:: LocalChainSyncClient
block
(Consensus.Point block)
(Net.Tip block)
IO
, forall block.
LocalNodeClientProtocolsForBlock block
-> Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
localStateQueryClientForBlock
:: Maybe
( LocalStateQueryClient
block
(Consensus.Point block)
(Consensus.Query block)
IO
()
)
, forall block.
LocalNodeClientProtocolsForBlock block
-> Maybe
(LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ())
localTxSubmissionClientForBlock
:: Maybe
( LocalTxSubmissionClient
(Consensus.GenTx block)
(Consensus.ApplyTxErr block)
IO
()
)
, forall block.
LocalNodeClientProtocolsForBlock block
-> Maybe
(LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo IO ())
localTxMonitoringClientForBlock
:: Maybe
( LocalTxMonitorClient
(Consensus.TxId (Consensus.GenTx block))
(Consensus.GenTx block)
SlotNo
IO
()
)
}
mkLocalNodeClientParams
:: ConsensusModeParams
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode)
-> LocalNodeClientParams
mkLocalNodeClientParams :: ConsensusModeParams
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode)
-> LocalNodeClientParams
mkLocalNodeClientParams ConsensusModeParams
modeparams NodeToClientVersion -> LocalNodeClientProtocolsInMode
clients =
case ConsensusModeParams
modeparams of
CardanoModeParams EpochSlots
epochSlots ->
ProtocolClientInfoArgs (CardanoBlock StandardCrypto)
-> (NodeToClientVersion
-> LocalNodeClientProtocolsForBlock (CardanoBlock StandardCrypto))
-> LocalNodeClientParams
forall block.
(ProtocolClient block,
CardanoHardForkConstraints (ConsensusCryptoForBlock block)) =>
ProtocolClientInfoArgs block
-> (NodeToClientVersion -> LocalNodeClientProtocolsForBlock block)
-> LocalNodeClientParams
LocalNodeClientParamsCardano
(EpochSlots -> ProtocolClientInfoArgs (CardanoBlock StandardCrypto)
ProtocolClientInfoArgsCardano EpochSlots
epochSlots)
(LocalNodeClientProtocolsInMode
-> LocalNodeClientProtocolsForBlock (CardanoBlock StandardCrypto)
forall block.
(CardanoBlock StandardCrypto ~ block) =>
LocalNodeClientProtocolsInMode
-> LocalNodeClientProtocolsForBlock block
convLocalNodeClientProtocols (LocalNodeClientProtocolsInMode
-> LocalNodeClientProtocolsForBlock (CardanoBlock StandardCrypto))
-> (NodeToClientVersion -> LocalNodeClientProtocolsInMode)
-> NodeToClientVersion
-> LocalNodeClientProtocolsForBlock (CardanoBlock StandardCrypto)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. NodeToClientVersion -> LocalNodeClientProtocolsInMode
clients)
convLocalNodeClientProtocols
:: ()
=> Consensus.CardanoBlock L.StandardCrypto ~ block
=> LocalNodeClientProtocolsInMode
-> LocalNodeClientProtocolsForBlock block
convLocalNodeClientProtocols :: forall block.
(CardanoBlock StandardCrypto ~ block) =>
LocalNodeClientProtocolsInMode
-> LocalNodeClientProtocolsForBlock block
convLocalNodeClientProtocols
LocalNodeClientProtocols
{ LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
localChainSyncClient :: forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> LocalChainSyncClient block point tip m
localChainSyncClient :: LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
localChainSyncClient
, Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
localTxSubmissionClient :: forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> Maybe (LocalTxSubmissionClient tx txerr m ())
localTxSubmissionClient :: Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
localTxSubmissionClient
, Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
localStateQueryClient :: forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> Maybe (LocalStateQueryClient block point query m ())
localStateQueryClient :: Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
localStateQueryClient
, Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
localTxMonitoringClient :: forall block point tip slot tx txid txerr (query :: * -> *)
(m :: * -> *).
LocalNodeClientProtocols block point tip slot tx txid txerr query m
-> Maybe (LocalTxMonitorClient txid tx slot m ())
localTxMonitoringClient :: Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
localTxMonitoringClient
} =
LocalNodeClientProtocolsForBlock
{ localChainSyncClientForBlock :: LocalChainSyncClient block (Point block) (Tip block) IO
localChainSyncClientForBlock = case LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
localChainSyncClient of
LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
NoLocalChainSyncClient -> LocalChainSyncClient block (Point block) (Tip block) IO
forall block point tip (m :: * -> *).
LocalChainSyncClient block point tip m
NoLocalChainSyncClient
LocalChainSyncClientPipelined ChainSyncClientPipelined BlockInMode ChainPoint ChainTip IO ()
clientPipelined -> ChainSyncClientPipelined block (Point block) (Tip block) IO ()
-> LocalChainSyncClient block (Point block) (Tip block) IO
forall block point tip (m :: * -> *).
ChainSyncClientPipelined block point tip m ()
-> LocalChainSyncClient block point tip m
LocalChainSyncClientPipelined (ChainSyncClientPipelined block (Point block) (Tip block) IO ()
-> LocalChainSyncClient block (Point block) (Tip block) IO)
-> ChainSyncClientPipelined block (Point block) (Tip block) IO ()
-> LocalChainSyncClient block (Point block) (Tip block) IO
forall a b. (a -> b) -> a -> b
$ ChainSyncClientPipelined BlockInMode ChainPoint ChainTip IO ()
-> ChainSyncClientPipelined block (Point block) (Tip block) IO ()
forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
ChainSyncClientPipelined BlockInMode ChainPoint ChainTip m a
-> ChainSyncClientPipelined block (Point block) (Tip block) m a
convLocalChainSyncClientPipelined ChainSyncClientPipelined BlockInMode ChainPoint ChainTip IO ()
clientPipelined
LocalChainSyncClient ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
client -> ChainSyncClient block (Point block) (Tip block) IO ()
-> LocalChainSyncClient block (Point block) (Tip block) IO
forall block point tip (m :: * -> *).
ChainSyncClient block point tip m ()
-> LocalChainSyncClient block point tip m
LocalChainSyncClient (ChainSyncClient block (Point block) (Tip block) IO ()
-> LocalChainSyncClient block (Point block) (Tip block) IO)
-> ChainSyncClient block (Point block) (Tip block) IO ()
-> LocalChainSyncClient block (Point block) (Tip block) IO
forall a b. (a -> b) -> a -> b
$ ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
-> ChainSyncClient block (Point block) (Tip block) IO ()
forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
ChainSyncClient BlockInMode ChainPoint ChainTip m a
-> ChainSyncClient block (Point block) (Tip block) m a
convLocalChainSyncClient ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
client
, localTxSubmissionClientForBlock :: Maybe
(LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) IO ())
localTxSubmissionClientForBlock = LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
-> LocalTxSubmissionClient
(GenTx (CardanoBlock StandardCrypto))
(ApplyTxErr (CardanoBlock StandardCrypto))
IO
()
LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
-> LocalTxSubmissionClient
(GenTx (CardanoBlock StandardCrypto))
(HardForkApplyTxErr
(ByronBlock : CardanoShelleyEras StandardCrypto))
IO
()
forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
LocalTxSubmissionClient TxInMode TxValidationErrorInCardanoMode m a
-> LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) m a
convLocalTxSubmissionClient (LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
-> LocalTxSubmissionClient
(GenTx (CardanoBlock StandardCrypto))
(HardForkApplyTxErr
(ByronBlock : CardanoShelleyEras StandardCrypto))
IO
())
-> Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
-> Maybe
(LocalTxSubmissionClient
(GenTx (CardanoBlock StandardCrypto))
(HardForkApplyTxErr
(ByronBlock : CardanoShelleyEras StandardCrypto))
IO
())
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
localTxSubmissionClient
, localStateQueryClientForBlock :: Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
localStateQueryClientForBlock = LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
-> LocalStateQueryClient block (Point block) (Query block) IO ()
forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
LocalStateQueryClient BlockInMode ChainPoint QueryInMode m a
-> LocalStateQueryClient block (Point block) (Query block) m a
convLocalStateQueryClient (LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
-> LocalStateQueryClient block (Point block) (Query block) IO ())
-> Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
-> Maybe
(LocalStateQueryClient block (Point block) (Query block) IO ())
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
localStateQueryClient
, localTxMonitoringClientForBlock :: Maybe
(LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo IO ())
localTxMonitoringClientForBlock = LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
-> LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo IO ()
forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
LocalTxMonitorClient TxIdInMode TxInMode SlotNo m a
-> LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo m a
convLocalTxMonitoringClient (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
-> LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo IO ())
-> Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
-> Maybe
(LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo IO ())
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
localTxMonitoringClient
}
convLocalTxMonitoringClient
:: forall block m a
. ()
=> Consensus.CardanoBlock L.StandardCrypto ~ block
=> Functor m
=> LocalTxMonitorClient TxIdInMode TxInMode SlotNo m a
-> LocalTxMonitorClient (Consensus.TxId (Consensus.GenTx block)) (Consensus.GenTx block) SlotNo m a
convLocalTxMonitoringClient :: forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
LocalTxMonitorClient TxIdInMode TxInMode SlotNo m a
-> LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo m a
convLocalTxMonitoringClient =
(TxIdInMode -> TxId (GenTx block))
-> (GenTx block -> TxInMode)
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo m a
-> LocalTxMonitorClient
(TxId (GenTx block)) (GenTx block) SlotNo m a
forall txid txid' tx tx' (m :: * -> *) a.
Functor m =>
(txid -> txid')
-> (tx' -> tx)
-> LocalTxMonitorClient txid tx SlotNo m a
-> LocalTxMonitorClient txid' tx' SlotNo m a
mapLocalTxMonitoringClient
TxIdInMode -> TxId (GenTx block)
forall block.
(CardanoBlock StandardCrypto ~ block) =>
TxIdInMode -> TxId (GenTx block)
toConsensusTxId
GenTx block -> TxInMode
forall block.
(CardanoBlock StandardCrypto ~ block) =>
GenTx block -> TxInMode
fromConsensusGenTx
convLocalChainSyncClient
:: forall block m a
. ()
=> Consensus.CardanoBlock L.StandardCrypto ~ block
=> Functor m
=> ChainSyncClient BlockInMode ChainPoint ChainTip m a
-> ChainSyncClient block (Net.Point block) (Net.Tip block) m a
convLocalChainSyncClient :: forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
ChainSyncClient BlockInMode ChainPoint ChainTip m a
-> ChainSyncClient block (Point block) (Tip block) m a
convLocalChainSyncClient =
(ChainPoint -> Point block)
-> (Point block -> ChainPoint)
-> (block -> BlockInMode)
-> (Tip block -> ChainTip)
-> ChainSyncClient BlockInMode ChainPoint ChainTip m a
-> ChainSyncClient block (Point block) (Tip block) m a
forall header header' point point' tip tip' (m :: * -> *) a.
Functor m =>
(point -> point')
-> (point' -> point)
-> (header' -> header)
-> (tip' -> tip)
-> ChainSyncClient header point tip m a
-> ChainSyncClient header' point' tip' m a
Net.Sync.mapChainSyncClient
ChainPoint -> Point block
forall block (xs :: [*]).
(HeaderHash block ~ OneEraHash xs) =>
ChainPoint -> Point block
toConsensusPointHF
Point block -> ChainPoint
forall block (xs :: [*]).
(HeaderHash block ~ OneEraHash xs) =>
Point block -> ChainPoint
fromConsensusPointHF
block -> BlockInMode
forall block.
(CardanoBlock StandardCrypto ~ block) =>
block -> BlockInMode
fromConsensusBlock
Tip block -> ChainTip
forall block.
(CardanoBlock StandardCrypto ~ block) =>
Tip block -> ChainTip
fromConsensusTip
convLocalChainSyncClientPipelined
:: forall block m a
. ()
=> Consensus.CardanoBlock L.StandardCrypto ~ block
=> Functor m
=> ChainSyncClientPipelined BlockInMode ChainPoint ChainTip m a
-> ChainSyncClientPipelined block (Net.Point block) (Net.Tip block) m a
convLocalChainSyncClientPipelined :: forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
ChainSyncClientPipelined BlockInMode ChainPoint ChainTip m a
-> ChainSyncClientPipelined block (Point block) (Tip block) m a
convLocalChainSyncClientPipelined =
(ChainPoint -> Point block)
-> (Point block -> ChainPoint)
-> (block -> BlockInMode)
-> (Tip block -> ChainTip)
-> ChainSyncClientPipelined BlockInMode ChainPoint ChainTip m a
-> ChainSyncClientPipelined block (Point block) (Tip block) m a
forall header header' point point' tip tip' (m :: * -> *) a.
Functor m =>
(point -> point')
-> (point' -> point)
-> (header' -> header)
-> (tip' -> tip)
-> ChainSyncClientPipelined header point tip m a
-> ChainSyncClientPipelined header' point' tip' m a
mapChainSyncClientPipelined
ChainPoint -> Point block
forall block (xs :: [*]).
(HeaderHash block ~ OneEraHash xs) =>
ChainPoint -> Point block
toConsensusPointHF
Point block -> ChainPoint
forall block (xs :: [*]).
(HeaderHash block ~ OneEraHash xs) =>
Point block -> ChainPoint
fromConsensusPointHF
block -> BlockInMode
forall block.
(CardanoBlock StandardCrypto ~ block) =>
block -> BlockInMode
fromConsensusBlock
Tip block -> ChainTip
forall block.
(CardanoBlock StandardCrypto ~ block) =>
Tip block -> ChainTip
fromConsensusTip
convLocalTxSubmissionClient
:: forall block m a
. ()
=> Consensus.CardanoBlock L.StandardCrypto ~ block
=> Functor m
=> LocalTxSubmissionClient TxInMode TxValidationErrorInCardanoMode m a
-> LocalTxSubmissionClient (Consensus.GenTx block) (Consensus.ApplyTxErr block) m a
convLocalTxSubmissionClient :: forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
LocalTxSubmissionClient TxInMode TxValidationErrorInCardanoMode m a
-> LocalTxSubmissionClient (GenTx block) (ApplyTxErr block) m a
convLocalTxSubmissionClient =
(TxInMode -> GenTx block)
-> (HardForkApplyTxErr
(ByronBlock : CardanoShelleyEras StandardCrypto)
-> TxValidationErrorInCardanoMode)
-> LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode m a
-> LocalTxSubmissionClient
(GenTx block)
(HardForkApplyTxErr
(ByronBlock : CardanoShelleyEras StandardCrypto))
m
a
forall tx tx' reject reject' (m :: * -> *) a.
Functor m =>
(tx -> tx')
-> (reject' -> reject)
-> LocalTxSubmissionClient tx reject m a
-> LocalTxSubmissionClient tx' reject' m a
Net.Tx.mapLocalTxSubmissionClient TxInMode -> GenTx block
forall block.
(CardanoBlock StandardCrypto ~ block) =>
TxInMode -> GenTx block
toConsensusGenTx ApplyTxErr (CardanoBlock StandardCrypto)
-> TxValidationErrorInCardanoMode
HardForkApplyTxErr (ByronBlock : CardanoShelleyEras StandardCrypto)
-> TxValidationErrorInCardanoMode
forall block.
(CardanoBlock StandardCrypto ~ block) =>
ApplyTxErr block -> TxValidationErrorInCardanoMode
fromConsensusApplyTxErr
convLocalStateQueryClient
:: forall block m a
. ()
=> Consensus.CardanoBlock L.StandardCrypto ~ block
=> Functor m
=> LocalStateQueryClient BlockInMode ChainPoint QueryInMode m a
-> LocalStateQueryClient block (Consensus.Point block) (Consensus.Query block) m a
convLocalStateQueryClient :: forall block (m :: * -> *) a.
(CardanoBlock StandardCrypto ~ block, Functor m) =>
LocalStateQueryClient BlockInMode ChainPoint QueryInMode m a
-> LocalStateQueryClient block (Point block) (Query block) m a
convLocalStateQueryClient =
(ChainPoint -> Point block)
-> (forall result. QueryInMode result -> Some (Query block))
-> (forall result result'.
QueryInMode result -> Query block result' -> result' -> result)
-> LocalStateQueryClient BlockInMode ChainPoint QueryInMode m a
-> LocalStateQueryClient block (Point block) (Query block) m a
forall block block' point point' (query :: * -> *)
(query' :: * -> *) (m :: * -> *) a.
Functor m =>
(point -> point')
-> (forall result. query result -> Some query')
-> (forall result result'.
query result -> query' result' -> result' -> result)
-> LocalStateQueryClient block point query m a
-> LocalStateQueryClient block' point' query' m a
Net.Query.mapLocalStateQueryClient
ChainPoint -> Point block
forall block (xs :: [*]).
(HeaderHash block ~ OneEraHash xs) =>
ChainPoint -> Point block
toConsensusPointHF
QueryInMode result -> Some (Query block)
forall result. QueryInMode result -> Some (Query block)
forall block result.
(CardanoBlock StandardCrypto ~ block) =>
QueryInMode result -> Some (Query block)
toConsensusQuery
QueryInMode result -> Query block result' -> result' -> result
forall result result'.
QueryInMode result -> Query block result' -> result' -> result
forall block result result'.
(HasCallStack, CardanoBlock StandardCrypto ~ block) =>
QueryInMode result -> Query block result' -> result' -> result
fromConsensusQueryResult
mapLocalTxMonitoringClient
:: forall txid txid' tx tx' m a
. ()
=> Functor m
=> (txid -> txid')
-> (tx' -> tx)
-> LocalTxMonitorClient txid tx SlotNo m a
-> LocalTxMonitorClient txid' tx' SlotNo m a
mapLocalTxMonitoringClient :: forall txid txid' tx tx' (m :: * -> *) a.
Functor m =>
(txid -> txid')
-> (tx' -> tx)
-> LocalTxMonitorClient txid tx SlotNo m a
-> LocalTxMonitorClient txid' tx' SlotNo m a
mapLocalTxMonitoringClient txid -> txid'
convTxid tx' -> tx
convTx LocalTxMonitorClient txid tx SlotNo m a
ltxmc =
let LocalTxMonitorClient m (ClientStIdle txid tx SlotNo m a)
idleEff = LocalTxMonitorClient txid tx SlotNo m a
ltxmc
in m (ClientStIdle txid' tx' SlotNo m a)
-> LocalTxMonitorClient txid' tx' SlotNo m a
forall txid tx slot (m :: * -> *) a.
m (ClientStIdle txid tx slot m a)
-> LocalTxMonitorClient txid tx slot m a
LocalTxMonitorClient ((ClientStIdle txid tx SlotNo m a
-> ClientStIdle txid' tx' SlotNo m a)
-> m (ClientStIdle txid tx SlotNo m a)
-> m (ClientStIdle txid' tx' SlotNo m a)
forall a b. (a -> b) -> m a -> m b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ClientStIdle txid tx SlotNo m a
-> ClientStIdle txid' tx' SlotNo m a
convClientStateIdle m (ClientStIdle txid tx SlotNo m a)
idleEff)
where
convClientStateIdle
:: CTxMon.ClientStIdle txid tx SlotNo m a
-> CTxMon.ClientStIdle txid' tx' SlotNo m a
convClientStateIdle :: ClientStIdle txid tx SlotNo m a
-> ClientStIdle txid' tx' SlotNo m a
convClientStateIdle (CTxMon.SendMsgAcquire SlotNo -> m (ClientStAcquired txid tx SlotNo m a)
f) =
(SlotNo -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStIdle txid' tx' SlotNo m a
forall slot (m :: * -> *) txid tx a.
(slot -> m (ClientStAcquired txid tx slot m a))
-> ClientStIdle txid tx slot m a
CTxMon.SendMsgAcquire ((SlotNo -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStIdle txid' tx' SlotNo m a)
-> (SlotNo -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStIdle txid' tx' SlotNo m a
forall a b. (a -> b) -> a -> b
$ ((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (SlotNo -> m (ClientStAcquired txid tx SlotNo m a))
-> SlotNo
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b. (a -> b) -> (SlotNo -> a) -> SlotNo -> b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (SlotNo -> m (ClientStAcquired txid tx SlotNo m a))
-> SlotNo
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> ((ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> (SlotNo -> m (ClientStAcquired txid tx SlotNo m a))
-> SlotNo
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b. (a -> b) -> m a -> m b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap) ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a
convClientStateAcquired SlotNo -> m (ClientStAcquired txid tx SlotNo m a)
f
convClientStateIdle (CTxMon.SendMsgDone a
a) = a -> ClientStIdle txid' tx' SlotNo m a
forall a txid tx slot (m :: * -> *).
a -> ClientStIdle txid tx slot m a
CTxMon.SendMsgDone a
a
convClientStateAcquired
:: CTxMon.ClientStAcquired txid tx SlotNo m a
-> CTxMon.ClientStAcquired txid' tx' SlotNo m a
convClientStateAcquired :: ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a
convClientStateAcquired (CTxMon.SendMsgNextTx Maybe tx -> m (ClientStAcquired txid tx SlotNo m a)
f) =
(Maybe tx' -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a
forall tx (m :: * -> *) txid slot a.
(Maybe tx -> m (ClientStAcquired txid tx slot m a))
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgNextTx (\Maybe tx'
mTx -> ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a
convClientStateAcquired (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe tx -> m (ClientStAcquired txid tx SlotNo m a)
f (tx' -> tx
convTx (tx' -> tx) -> Maybe tx' -> Maybe tx
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe tx'
mTx))
convClientStateAcquired (CTxMon.SendMsgHasTx txid
txid Bool -> m (ClientStAcquired txid tx SlotNo m a)
f) =
txid'
-> (Bool -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a
forall txid (m :: * -> *) tx slot a.
txid
-> (Bool -> m (ClientStAcquired txid tx slot m a))
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgHasTx (txid -> txid'
convTxid txid
txid) (((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (Bool -> m (ClientStAcquired txid tx SlotNo m a))
-> Bool
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b. (a -> b) -> (Bool -> a) -> Bool -> b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (Bool -> m (ClientStAcquired txid tx SlotNo m a))
-> Bool
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> ((ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> (Bool -> m (ClientStAcquired txid tx SlotNo m a))
-> Bool
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b. (a -> b) -> m a -> m b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap) ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a
convClientStateAcquired Bool -> m (ClientStAcquired txid tx SlotNo m a)
f)
convClientStateAcquired (CTxMon.SendMsgGetSizes MempoolSizeAndCapacity -> m (ClientStAcquired txid tx SlotNo m a)
f) =
(MempoolSizeAndCapacity
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a
forall (m :: * -> *) txid tx slot a.
(MempoolSizeAndCapacity -> m (ClientStAcquired txid tx slot m a))
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgGetSizes ((MempoolSizeAndCapacity
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a)
-> (MempoolSizeAndCapacity
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a
forall a b. (a -> b) -> a -> b
$ ((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (MempoolSizeAndCapacity
-> m (ClientStAcquired txid tx SlotNo m a))
-> MempoolSizeAndCapacity
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b.
(a -> b)
-> (MempoolSizeAndCapacity -> a) -> MempoolSizeAndCapacity -> b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (MempoolSizeAndCapacity
-> m (ClientStAcquired txid tx SlotNo m a))
-> MempoolSizeAndCapacity
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> ((ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> (MempoolSizeAndCapacity
-> m (ClientStAcquired txid tx SlotNo m a))
-> MempoolSizeAndCapacity
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b. (a -> b) -> m a -> m b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap) ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a
convClientStateAcquired MempoolSizeAndCapacity -> m (ClientStAcquired txid tx SlotNo m a)
f
convClientStateAcquired (CTxMon.SendMsgAwaitAcquire SlotNo -> m (ClientStAcquired txid tx SlotNo m a)
f) =
(SlotNo -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a
forall slot (m :: * -> *) txid tx a.
(slot -> m (ClientStAcquired txid tx slot m a))
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgAwaitAcquire ((SlotNo -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a)
-> (SlotNo -> m (ClientStAcquired txid' tx' SlotNo m a))
-> ClientStAcquired txid' tx' SlotNo m a
forall a b. (a -> b) -> a -> b
$ ((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (SlotNo -> m (ClientStAcquired txid tx SlotNo m a))
-> SlotNo
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b. (a -> b) -> (SlotNo -> a) -> SlotNo -> b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (SlotNo -> m (ClientStAcquired txid tx SlotNo m a))
-> SlotNo
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> ((ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a))
-> (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> (SlotNo -> m (ClientStAcquired txid tx SlotNo m a))
-> SlotNo
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a)
-> m (ClientStAcquired txid tx SlotNo m a)
-> m (ClientStAcquired txid' tx' SlotNo m a)
forall a b. (a -> b) -> m a -> m b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap) ClientStAcquired txid tx SlotNo m a
-> ClientStAcquired txid' tx' SlotNo m a
convClientStateAcquired SlotNo -> m (ClientStAcquired txid tx SlotNo m a)
f
convClientStateAcquired (CTxMon.SendMsgRelease m (ClientStIdle txid tx SlotNo m a)
eff) =
m (ClientStIdle txid' tx' SlotNo m a)
-> ClientStAcquired txid' tx' SlotNo m a
forall (m :: * -> *) txid tx slot a.
m (ClientStIdle txid tx slot m a)
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgRelease (ClientStIdle txid tx SlotNo m a
-> ClientStIdle txid' tx' SlotNo m a
convClientStateIdle (ClientStIdle txid tx SlotNo m a
-> ClientStIdle txid' tx' SlotNo m a)
-> m (ClientStIdle txid tx SlotNo m a)
-> m (ClientStIdle txid' tx' SlotNo m a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> m (ClientStIdle txid tx SlotNo m a)
eff)
data AcquiringFailure
= AFPointTooOld
| AFPointNotOnChain
deriving (AcquiringFailure -> AcquiringFailure -> Bool
(AcquiringFailure -> AcquiringFailure -> Bool)
-> (AcquiringFailure -> AcquiringFailure -> Bool)
-> Eq AcquiringFailure
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: AcquiringFailure -> AcquiringFailure -> Bool
== :: AcquiringFailure -> AcquiringFailure -> Bool
$c/= :: AcquiringFailure -> AcquiringFailure -> Bool
/= :: AcquiringFailure -> AcquiringFailure -> Bool
Eq, Int -> AcquiringFailure -> ShowS
[AcquiringFailure] -> ShowS
AcquiringFailure -> FilePath
(Int -> AcquiringFailure -> ShowS)
-> (AcquiringFailure -> FilePath)
-> ([AcquiringFailure] -> ShowS)
-> Show AcquiringFailure
forall a.
(Int -> a -> ShowS) -> (a -> FilePath) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> AcquiringFailure -> ShowS
showsPrec :: Int -> AcquiringFailure -> ShowS
$cshow :: AcquiringFailure -> FilePath
show :: AcquiringFailure -> FilePath
$cshowList :: [AcquiringFailure] -> ShowS
showList :: [AcquiringFailure] -> ShowS
Show)
toAcquiringFailure :: Net.Query.AcquireFailure -> AcquiringFailure
toAcquiringFailure :: AcquireFailure -> AcquiringFailure
toAcquiringFailure AcquireFailure
AcquireFailurePointTooOld = AcquiringFailure
AFPointTooOld
toAcquiringFailure AcquireFailure
AcquireFailurePointNotOnChain = AcquiringFailure
AFPointNotOnChain
queryNodeLocalState
:: forall result
. ()
=> LocalNodeConnectInfo
-> Net.Query.Target ChainPoint
-> QueryInMode result
-> ExceptT AcquiringFailure IO result
queryNodeLocalState :: forall result.
LocalNodeConnectInfo
-> Target ChainPoint
-> QueryInMode result
-> ExceptT AcquiringFailure IO result
queryNodeLocalState LocalNodeConnectInfo
connctInfo Target ChainPoint
mpoint QueryInMode result
query = do
TMVar (Either AcquiringFailure result)
resultVar <- IO (TMVar (Either AcquiringFailure result))
-> ExceptT
AcquiringFailure IO (TMVar (Either AcquiringFailure result))
forall a. IO a -> ExceptT AcquiringFailure IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO (TMVar (Either AcquiringFailure result))
forall a. IO (TMVar a)
newEmptyTMVarIO
LocalNodeConnectInfo
-> LocalNodeClientProtocolsInMode -> ExceptT AcquiringFailure IO ()
forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
connectToLocalNode
LocalNodeConnectInfo
connctInfo
LocalNodeClientProtocols
{ localChainSyncClient :: LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
localChainSyncClient = LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
forall block point tip (m :: * -> *).
LocalChainSyncClient block point tip m
NoLocalChainSyncClient
, localStateQueryClient :: Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
localStateQueryClient = LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
-> Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
forall a. a -> Maybe a
Just (Target ChainPoint
-> TMVar (Either AcquiringFailure result)
-> LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
singleQuery Target ChainPoint
mpoint TMVar (Either AcquiringFailure result)
resultVar)
, localTxSubmissionClient :: Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
localTxSubmissionClient = Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
forall a. Maybe a
Nothing
, localTxMonitoringClient :: Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
localTxMonitoringClient = Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
forall a. Maybe a
Nothing
}
IO (Either AcquiringFailure result)
-> ExceptT AcquiringFailure IO result
forall e (m :: * -> *) a. m (Either e a) -> ExceptT e m a
ExceptT (IO (Either AcquiringFailure result)
-> ExceptT AcquiringFailure IO result)
-> IO (Either AcquiringFailure result)
-> ExceptT AcquiringFailure IO result
forall a b. (a -> b) -> a -> b
$ STM (Either AcquiringFailure result)
-> IO (Either AcquiringFailure result)
forall a. STM a -> IO a
atomically (TMVar (Either AcquiringFailure result)
-> STM (Either AcquiringFailure result)
forall a. TMVar a -> STM a
takeTMVar TMVar (Either AcquiringFailure result)
resultVar)
where
singleQuery
:: Net.Query.Target ChainPoint
-> TMVar (Either AcquiringFailure result)
-> Net.Query.LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
singleQuery :: Target ChainPoint
-> TMVar (Either AcquiringFailure result)
-> LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
singleQuery Target ChainPoint
mPointVar' TMVar (Either AcquiringFailure result)
resultVar' =
IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
-> LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
forall block point (query :: * -> *) (m :: * -> *) a.
m (ClientStIdle block point query m a)
-> LocalStateQueryClient block point query m a
LocalStateQueryClient (IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
-> LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
-> LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ()
forall a b. (a -> b) -> a -> b
$ do
ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ()))
-> ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
forall a b. (a -> b) -> a -> b
$
Target ChainPoint
-> ClientStAcquiring BlockInMode ChainPoint QueryInMode IO ()
-> ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
forall point block (query :: * -> *) (m :: * -> *) a.
Target point
-> ClientStAcquiring block point query m a
-> ClientStIdle block point query m a
Net.Query.SendMsgAcquire Target ChainPoint
mPointVar' (ClientStAcquiring BlockInMode ChainPoint QueryInMode IO ()
-> ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
-> ClientStAcquiring BlockInMode ChainPoint QueryInMode IO ()
-> ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
forall a b. (a -> b) -> a -> b
$
Net.Query.ClientStAcquiring
{ recvMsgAcquired :: IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
Net.Query.recvMsgAcquired =
ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()))
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
forall a b. (a -> b) -> a -> b
$
QueryInMode result
-> ClientStQuerying BlockInMode ChainPoint QueryInMode IO () result
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
forall (query :: * -> *) result block point (m :: * -> *) a.
query result
-> ClientStQuerying block point query m a result
-> ClientStAcquired block point query m a
Net.Query.SendMsgQuery QueryInMode result
query (ClientStQuerying BlockInMode ChainPoint QueryInMode IO () result
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
-> ClientStQuerying BlockInMode ChainPoint QueryInMode IO () result
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
forall a b. (a -> b) -> a -> b
$
Net.Query.ClientStQuerying
{ recvMsgResult :: result
-> IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
Net.Query.recvMsgResult = \result
result -> do
STM () -> IO ()
forall a. STM a -> IO a
atomically (STM () -> IO ()) -> STM () -> IO ()
forall a b. (a -> b) -> a -> b
$ TMVar (Either AcquiringFailure result)
-> Either AcquiringFailure result -> STM ()
forall a. TMVar a -> a -> STM ()
putTMVar TMVar (Either AcquiringFailure result)
resultVar' (result -> Either AcquiringFailure result
forall a b. b -> Either a b
Right result
result)
ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()))
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
forall a b. (a -> b) -> a -> b
$
IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
forall (m :: * -> *) block point (query :: * -> *) a.
m (ClientStIdle block point query m a)
-> ClientStAcquired block point query m a
Net.Query.SendMsgRelease (IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ())
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
-> ClientStAcquired BlockInMode ChainPoint QueryInMode IO ()
forall a b. (a -> b) -> a -> b
$
ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ()))
-> ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
forall a b. (a -> b) -> a -> b
$
() -> ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
forall a block point (query :: * -> *) (m :: * -> *).
a -> ClientStIdle block point query m a
Net.Query.SendMsgDone ()
}
, recvMsgFailure :: AcquireFailure
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
Net.Query.recvMsgFailure = \AcquireFailure
failure -> do
STM () -> IO ()
forall a. STM a -> IO a
atomically (STM () -> IO ()) -> STM () -> IO ()
forall a b. (a -> b) -> a -> b
$ TMVar (Either AcquiringFailure result)
-> Either AcquiringFailure result -> STM ()
forall a. TMVar a -> a -> STM ()
putTMVar TMVar (Either AcquiringFailure result)
resultVar' (AcquiringFailure -> Either AcquiringFailure result
forall a b. a -> Either a b
Left (AcquireFailure -> AcquiringFailure
toAcquiringFailure AcquireFailure
failure))
ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ()))
-> ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
-> IO (ClientStIdle BlockInMode ChainPoint QueryInMode IO ())
forall a b. (a -> b) -> a -> b
$ () -> ClientStIdle BlockInMode ChainPoint QueryInMode IO ()
forall a block point (query :: * -> *) (m :: * -> *).
a -> ClientStIdle block point query m a
Net.Query.SendMsgDone ()
}
submitTxToNodeLocal
:: MonadIO m
=> LocalNodeConnectInfo
-> TxInMode
-> m (Net.Tx.SubmitResult TxValidationErrorInCardanoMode)
submitTxToNodeLocal :: forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo
-> TxInMode -> m (SubmitResult TxValidationErrorInCardanoMode)
submitTxToNodeLocal LocalNodeConnectInfo
connctInfo TxInMode
tx = do
TMVar (SubmitResult TxValidationErrorInCardanoMode)
resultVar <- IO (TMVar (SubmitResult TxValidationErrorInCardanoMode))
-> m (TMVar (SubmitResult TxValidationErrorInCardanoMode))
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO (TMVar (SubmitResult TxValidationErrorInCardanoMode))
forall a. IO (TMVar a)
newEmptyTMVarIO
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
connectToLocalNode
LocalNodeConnectInfo
connctInfo
LocalNodeClientProtocols
{ localChainSyncClient :: LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
localChainSyncClient = LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
forall block point tip (m :: * -> *).
LocalChainSyncClient block point tip m
NoLocalChainSyncClient
, localTxSubmissionClient :: Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
localTxSubmissionClient = LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
-> Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
forall a. a -> Maybe a
Just (TMVar (SubmitResult TxValidationErrorInCardanoMode)
-> LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
localTxSubmissionClientSingle TMVar (SubmitResult TxValidationErrorInCardanoMode)
resultVar)
, localStateQueryClient :: Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
localStateQueryClient = Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
forall a. Maybe a
Nothing
, localTxMonitoringClient :: Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
localTxMonitoringClient = Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
forall a. Maybe a
Nothing
}
IO (SubmitResult TxValidationErrorInCardanoMode)
-> m (SubmitResult TxValidationErrorInCardanoMode)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (SubmitResult TxValidationErrorInCardanoMode)
-> m (SubmitResult TxValidationErrorInCardanoMode))
-> IO (SubmitResult TxValidationErrorInCardanoMode)
-> m (SubmitResult TxValidationErrorInCardanoMode)
forall a b. (a -> b) -> a -> b
$ STM (SubmitResult TxValidationErrorInCardanoMode)
-> IO (SubmitResult TxValidationErrorInCardanoMode)
forall a. STM a -> IO a
atomically (TMVar (SubmitResult TxValidationErrorInCardanoMode)
-> STM (SubmitResult TxValidationErrorInCardanoMode)
forall a. TMVar a -> STM a
takeTMVar TMVar (SubmitResult TxValidationErrorInCardanoMode)
resultVar)
where
localTxSubmissionClientSingle
:: ()
=> TMVar (Net.Tx.SubmitResult TxValidationErrorInCardanoMode)
-> Net.Tx.LocalTxSubmissionClient TxInMode TxValidationErrorInCardanoMode IO ()
localTxSubmissionClientSingle :: TMVar (SubmitResult TxValidationErrorInCardanoMode)
-> LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
localTxSubmissionClientSingle TMVar (SubmitResult TxValidationErrorInCardanoMode)
resultVar =
IO
(LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ())
-> LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
forall tx reject (m :: * -> *) a.
m (LocalTxClientStIdle tx reject m a)
-> LocalTxSubmissionClient tx reject m a
LocalTxSubmissionClient (IO
(LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ())
-> LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
-> IO
(LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ())
-> LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ()
forall a b. (a -> b) -> a -> b
$
LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ()
-> IO
(LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ()
-> IO
(LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()))
-> LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()
-> IO
(LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ())
forall a b. (a -> b) -> a -> b
$
TxInMode
-> (SubmitResult TxValidationErrorInCardanoMode
-> IO
(LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()))
-> LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()
forall tx reject (m :: * -> *) a.
tx
-> (SubmitResult reject -> m (LocalTxClientStIdle tx reject m a))
-> LocalTxClientStIdle tx reject m a
Net.Tx.SendMsgSubmitTx TxInMode
tx ((SubmitResult TxValidationErrorInCardanoMode
-> IO
(LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()))
-> LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ())
-> (SubmitResult TxValidationErrorInCardanoMode
-> IO
(LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()))
-> LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()
forall a b. (a -> b) -> a -> b
$ \SubmitResult TxValidationErrorInCardanoMode
result -> do
STM () -> IO ()
forall a. STM a -> IO a
atomically (STM () -> IO ()) -> STM () -> IO ()
forall a b. (a -> b) -> a -> b
$ TMVar (SubmitResult TxValidationErrorInCardanoMode)
-> SubmitResult TxValidationErrorInCardanoMode -> STM ()
forall a. TMVar a -> a -> STM ()
putTMVar TMVar (SubmitResult TxValidationErrorInCardanoMode)
resultVar SubmitResult TxValidationErrorInCardanoMode
result
LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ()
-> IO
(LocalTxClientStIdle TxInMode TxValidationErrorInCardanoMode IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (()
-> LocalTxClientStIdle
TxInMode TxValidationErrorInCardanoMode IO ()
forall a tx reject (m :: * -> *).
a -> LocalTxClientStIdle tx reject m a
Net.Tx.SendMsgDone ())
data LocalTxMonitoringResult
=
LocalTxMonitoringTxExists
TxId
SlotNo
|
LocalTxMonitoringTxDoesNotExist
TxId
SlotNo
|
LocalTxMonitoringNextTx
(Maybe TxInMode)
SlotNo
|
LocalTxMonitoringMempoolSizeAndCapacity
Consensus.MempoolSizeAndCapacity
SlotNo
instance ToJSON LocalTxMonitoringResult where
toJSON :: LocalTxMonitoringResult -> Value
toJSON LocalTxMonitoringResult
result =
[Pair] -> Value
object ([Pair] -> Value) -> [Pair] -> Value
forall a b. (a -> b) -> a -> b
$ case LocalTxMonitoringResult
result of
LocalTxMonitoringTxExists TxId
tx SlotNo
slot ->
[ Key
"exists" Key -> Bool -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= Bool
True
, Key
"txId" Key -> TxId -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= TxId
tx
, Key
"slot" Key -> SlotNo -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= SlotNo
slot
]
LocalTxMonitoringTxDoesNotExist TxId
tx SlotNo
slot ->
[ Key
"exists" Key -> Bool -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= Bool
False
, Key
"txId" Key -> TxId -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= TxId
tx
, Key
"slot" Key -> SlotNo -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= SlotNo
slot
]
LocalTxMonitoringNextTx Maybe TxInMode
txInMode SlotNo
slot ->
[ Key
"nextTx" Key -> Maybe TxId -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= Maybe TxId
txId
, Key
"slot" Key -> SlotNo -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= SlotNo
slot
]
where
txId :: Maybe TxId
txId = case Maybe TxInMode
txInMode of
Just (TxInMode ShelleyBasedEra era
_ Tx era
tx) -> TxId -> Maybe TxId
forall a. a -> Maybe a
Just (TxId -> Maybe TxId) -> TxId -> Maybe TxId
forall a b. (a -> b) -> a -> b
$ TxBody era -> TxId
forall era. TxBody era -> TxId
getTxId (TxBody era -> TxId) -> TxBody era -> TxId
forall a b. (a -> b) -> a -> b
$ Tx era -> TxBody era
forall era. Tx era -> TxBody era
getTxBody Tx era
tx
Maybe TxInMode
_ -> Maybe TxId
forall a. Maybe a
Nothing
LocalTxMonitoringMempoolSizeAndCapacity MempoolSizeAndCapacity
mempool SlotNo
slot ->
[ Key
"capacityInBytes" Key -> Word32 -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= MempoolSizeAndCapacity -> Word32
Consensus.capacityInBytes MempoolSizeAndCapacity
mempool
, Key
"sizeInBytes" Key -> Word32 -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= MempoolSizeAndCapacity -> Word32
Consensus.sizeInBytes MempoolSizeAndCapacity
mempool
, Key
"numberOfTxs" Key -> Word32 -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= MempoolSizeAndCapacity -> Word32
Consensus.numberOfTxs MempoolSizeAndCapacity
mempool
, Key
"slot" Key -> SlotNo -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
.= SlotNo
slot
]
data LocalTxMonitoringQuery
=
LocalTxMonitoringQueryTx TxIdInMode
|
LocalTxMonitoringSendNextTx
|
LocalTxMonitoringMempoolInformation
queryTxMonitoringLocal
:: MonadIO m
=> LocalNodeConnectInfo
-> LocalTxMonitoringQuery
-> m LocalTxMonitoringResult
queryTxMonitoringLocal :: forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo
-> LocalTxMonitoringQuery -> m LocalTxMonitoringResult
queryTxMonitoringLocal LocalNodeConnectInfo
connectInfo LocalTxMonitoringQuery
localTxMonitoringQuery = do
TMVar LocalTxMonitoringResult
resultVar <- IO (TMVar LocalTxMonitoringResult)
-> m (TMVar LocalTxMonitoringResult)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO (TMVar LocalTxMonitoringResult)
forall a. IO (TMVar a)
newEmptyTMVarIO
let client :: LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
client = case LocalTxMonitoringQuery
localTxMonitoringQuery of
LocalTxMonitoringQueryTx TxIdInMode
txidInMode ->
TxIdInMode
-> TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorClientTxExists TxIdInMode
txidInMode TMVar LocalTxMonitoringResult
resultVar
LocalTxMonitoringQuery
LocalTxMonitoringSendNextTx ->
TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorNextTx TMVar LocalTxMonitoringResult
resultVar
LocalTxMonitoringQuery
LocalTxMonitoringMempoolInformation ->
TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorMempoolInfo TMVar LocalTxMonitoringResult
resultVar
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
connectToLocalNode
LocalNodeConnectInfo
connectInfo
LocalNodeClientProtocols
{ localChainSyncClient :: LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
localChainSyncClient = LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
forall block point tip (m :: * -> *).
LocalChainSyncClient block point tip m
NoLocalChainSyncClient
, localTxSubmissionClient :: Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
localTxSubmissionClient = Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
forall a. Maybe a
Nothing
, localStateQueryClient :: Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
localStateQueryClient = Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
forall a. Maybe a
Nothing
, localTxMonitoringClient :: Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
localTxMonitoringClient = LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
-> Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
forall a. a -> Maybe a
Just LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
client
}
IO LocalTxMonitoringResult -> m LocalTxMonitoringResult
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO LocalTxMonitoringResult -> m LocalTxMonitoringResult)
-> IO LocalTxMonitoringResult -> m LocalTxMonitoringResult
forall a b. (a -> b) -> a -> b
$ STM LocalTxMonitoringResult -> IO LocalTxMonitoringResult
forall a. STM a -> IO a
atomically (TMVar LocalTxMonitoringResult -> STM LocalTxMonitoringResult
forall a. TMVar a -> STM a
takeTMVar TMVar LocalTxMonitoringResult
resultVar)
where
localTxMonitorClientTxExists
:: ()
=> TxIdInMode
-> TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorClientTxExists :: TxIdInMode
-> TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorClientTxExists tIdInMode :: TxIdInMode
tIdInMode@(TxIdInMode CardanoEra era
_ TxId
txid) TMVar LocalTxMonitoringResult
resultVar = do
IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
forall txid tx slot (m :: * -> *) a.
m (ClientStIdle txid tx slot m a)
-> LocalTxMonitorClient txid tx slot m a
LocalTxMonitorClient (IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$
ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$
(SlotNo -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall slot (m :: * -> *) txid tx a.
(slot -> m (ClientStAcquired txid tx slot m a))
-> ClientStIdle txid tx slot m a
CTxMon.SendMsgAcquire ((SlotNo -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> (SlotNo
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ \SlotNo
slt -> do
ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ TxIdInMode
-> (Bool -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall txid (m :: * -> *) tx slot a.
txid
-> (Bool -> m (ClientStAcquired txid tx slot m a))
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgHasTx TxIdInMode
tIdInMode ((Bool -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
-> (Bool -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ \Bool
txPresentBool -> do
if Bool
txPresentBool
then STM () -> IO ()
forall a. STM a -> IO a
atomically (STM () -> IO ())
-> (LocalTxMonitoringResult -> STM ())
-> LocalTxMonitoringResult
-> IO ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. TMVar LocalTxMonitoringResult -> LocalTxMonitoringResult -> STM ()
forall a. TMVar a -> a -> STM ()
putTMVar TMVar LocalTxMonitoringResult
resultVar (LocalTxMonitoringResult -> IO ())
-> LocalTxMonitoringResult -> IO ()
forall a b. (a -> b) -> a -> b
$ TxId -> SlotNo -> LocalTxMonitoringResult
LocalTxMonitoringTxExists TxId
txid SlotNo
slt
else STM () -> IO ()
forall a. STM a -> IO a
atomically (STM () -> IO ())
-> (LocalTxMonitoringResult -> STM ())
-> LocalTxMonitoringResult
-> IO ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. TMVar LocalTxMonitoringResult -> LocalTxMonitoringResult -> STM ()
forall a. TMVar a -> a -> STM ()
putTMVar TMVar LocalTxMonitoringResult
resultVar (LocalTxMonitoringResult -> IO ())
-> LocalTxMonitoringResult -> IO ()
forall a b. (a -> b) -> a -> b
$ TxId -> SlotNo -> LocalTxMonitoringResult
LocalTxMonitoringTxDoesNotExist TxId
txid SlotNo
slt
ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall (m :: * -> *) txid tx slot a.
m (ClientStIdle txid tx slot m a)
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgRelease (IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ () -> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall a txid tx slot (m :: * -> *).
a -> ClientStIdle txid tx slot m a
CTxMon.SendMsgDone ()
localTxMonitorNextTx
:: ()
=> TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorNextTx :: TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorNextTx TMVar LocalTxMonitoringResult
resultVar =
IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
forall txid tx slot (m :: * -> *) a.
m (ClientStIdle txid tx slot m a)
-> LocalTxMonitorClient txid tx slot m a
LocalTxMonitorClient (IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ do
(SlotNo -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall slot (m :: * -> *) txid tx a.
(slot -> m (ClientStAcquired txid tx slot m a))
-> ClientStIdle txid tx slot m a
CTxMon.SendMsgAcquire ((SlotNo -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> (SlotNo
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ \SlotNo
slt -> do
ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ (Maybe TxInMode
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall tx (m :: * -> *) txid slot a.
(Maybe tx -> m (ClientStAcquired txid tx slot m a))
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgNextTx ((Maybe TxInMode
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
-> (Maybe TxInMode
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ \Maybe TxInMode
mTx -> do
STM () -> IO ()
forall a. STM a -> IO a
atomically (STM () -> IO ()) -> STM () -> IO ()
forall a b. (a -> b) -> a -> b
$ TMVar LocalTxMonitoringResult -> LocalTxMonitoringResult -> STM ()
forall a. TMVar a -> a -> STM ()
putTMVar TMVar LocalTxMonitoringResult
resultVar (LocalTxMonitoringResult -> STM ())
-> LocalTxMonitoringResult -> STM ()
forall a b. (a -> b) -> a -> b
$ Maybe TxInMode -> SlotNo -> LocalTxMonitoringResult
LocalTxMonitoringNextTx Maybe TxInMode
mTx SlotNo
slt
ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall (m :: * -> *) txid tx slot a.
m (ClientStIdle txid tx slot m a)
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgRelease (IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ () -> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall a txid tx slot (m :: * -> *).
a -> ClientStIdle txid tx slot m a
CTxMon.SendMsgDone ()
localTxMonitorMempoolInfo
:: ()
=> TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorMempoolInfo :: TMVar LocalTxMonitoringResult
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
localTxMonitorMempoolInfo TMVar LocalTxMonitoringResult
resultVar =
IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
forall txid tx slot (m :: * -> *) a.
m (ClientStIdle txid tx slot m a)
-> LocalTxMonitorClient txid tx slot m a
LocalTxMonitorClient (IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ do
(SlotNo -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall slot (m :: * -> *) txid tx a.
(slot -> m (ClientStAcquired txid tx slot m a))
-> ClientStIdle txid tx slot m a
CTxMon.SendMsgAcquire ((SlotNo -> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> (SlotNo
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ \SlotNo
slt -> do
ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ (MempoolSizeAndCapacity
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall (m :: * -> *) txid tx slot a.
(MempoolSizeAndCapacity -> m (ClientStAcquired txid tx slot m a))
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgGetSizes ((MempoolSizeAndCapacity
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
-> (MempoolSizeAndCapacity
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ \MempoolSizeAndCapacity
mempoolCapacity -> do
STM () -> IO ()
forall a. STM a -> IO a
atomically (STM () -> IO ()) -> STM () -> IO ()
forall a b. (a -> b) -> a -> b
$ TMVar LocalTxMonitoringResult -> LocalTxMonitoringResult -> STM ()
forall a. TMVar a -> a -> STM ()
putTMVar TMVar LocalTxMonitoringResult
resultVar (LocalTxMonitoringResult -> STM ())
-> LocalTxMonitoringResult -> STM ()
forall a b. (a -> b) -> a -> b
$ MempoolSizeAndCapacity -> SlotNo -> LocalTxMonitoringResult
LocalTxMonitoringMempoolSizeAndCapacity MempoolSizeAndCapacity
mempoolCapacity SlotNo
slt
ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ()))
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall (m :: * -> *) txid tx slot a.
m (ClientStIdle txid tx slot m a)
-> ClientStAcquired txid tx slot m a
CTxMon.SendMsgRelease (IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ())
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
-> ClientStAcquired TxIdInMode TxInMode SlotNo IO ()
forall a b. (a -> b) -> a -> b
$ ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ()))
-> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
-> IO (ClientStIdle TxIdInMode TxInMode SlotNo IO ())
forall a b. (a -> b) -> a -> b
$ () -> ClientStIdle TxIdInMode TxInMode SlotNo IO ()
forall a txid tx slot (m :: * -> *).
a -> ClientStIdle txid tx slot m a
CTxMon.SendMsgDone ()
getLocalChainTip
:: MonadIO m
=> LocalNodeConnectInfo
-> m ChainTip
getLocalChainTip :: forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo -> m ChainTip
getLocalChainTip LocalNodeConnectInfo
localNodeConInfo = do
TMVar ChainTip
resultVar <- IO (TMVar ChainTip) -> m (TMVar ChainTip)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO (TMVar ChainTip)
forall a. IO (TMVar a)
newEmptyTMVarIO
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
forall (m :: * -> *).
MonadIO m =>
LocalNodeConnectInfo -> LocalNodeClientProtocolsInMode -> m ()
connectToLocalNode
LocalNodeConnectInfo
localNodeConInfo
LocalNodeClientProtocols
{ localChainSyncClient :: LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
localChainSyncClient = ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
-> LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
forall block point tip (m :: * -> *).
ChainSyncClient block point tip m ()
-> LocalChainSyncClient block point tip m
LocalChainSyncClient (ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
-> LocalChainSyncClient BlockInMode ChainPoint ChainTip IO)
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
-> LocalChainSyncClient BlockInMode ChainPoint ChainTip IO
forall a b. (a -> b) -> a -> b
$ TMVar ChainTip
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
chainSyncGetCurrentTip TMVar ChainTip
resultVar
, localTxSubmissionClient :: Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
localTxSubmissionClient = Maybe
(LocalTxSubmissionClient
TxInMode TxValidationErrorInCardanoMode IO ())
forall a. Maybe a
Nothing
, localStateQueryClient :: Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
localStateQueryClient = Maybe
(LocalStateQueryClient BlockInMode ChainPoint QueryInMode IO ())
forall a. Maybe a
Nothing
, localTxMonitoringClient :: Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
localTxMonitoringClient = Maybe (LocalTxMonitorClient TxIdInMode TxInMode SlotNo IO ())
forall a. Maybe a
Nothing
}
IO ChainTip -> m ChainTip
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ChainTip -> m ChainTip)
-> (STM ChainTip -> IO ChainTip) -> STM ChainTip -> m ChainTip
forall b c a. (b -> c) -> (a -> b) -> a -> c
. STM ChainTip -> IO ChainTip
forall a. STM a -> IO a
atomically (STM ChainTip -> m ChainTip) -> STM ChainTip -> m ChainTip
forall a b. (a -> b) -> a -> b
$ TMVar ChainTip -> STM ChainTip
forall a. TMVar a -> STM a
takeTMVar TMVar ChainTip
resultVar
chainSyncGetCurrentTip
:: ()
=> TMVar ChainTip
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
chainSyncGetCurrentTip :: TMVar ChainTip
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
chainSyncGetCurrentTip TMVar ChainTip
tipVar =
IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
forall header point tip (m :: * -> *) a.
m (ClientStIdle header point tip m a)
-> ChainSyncClient header point tip m a
ChainSyncClient (IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ())
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
forall a b. (a -> b) -> a -> b
$ ClientStIdle BlockInMode ChainPoint ChainTip IO ()
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ClientStIdle BlockInMode ChainPoint ChainTip IO ()
clientStIdle
where
clientStIdle :: Net.Sync.ClientStIdle BlockInMode ChainPoint ChainTip IO ()
clientStIdle :: ClientStIdle BlockInMode ChainPoint ChainTip IO ()
clientStIdle =
IO ()
-> ClientStNext BlockInMode ChainPoint ChainTip IO ()
-> ClientStIdle BlockInMode ChainPoint ChainTip IO ()
forall (m :: * -> *) header point tip a.
m ()
-> ClientStNext header point tip m a
-> ClientStIdle header point tip m a
Net.Sync.SendMsgRequestNext (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ()) ClientStNext BlockInMode ChainPoint ChainTip IO ()
clientStNext
clientStNext :: Net.Sync.ClientStNext BlockInMode ChainPoint ChainTip IO ()
clientStNext :: ClientStNext BlockInMode ChainPoint ChainTip IO ()
clientStNext =
Net.Sync.ClientStNext
{ recvMsgRollForward :: BlockInMode
-> ChainTip
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
Net.Sync.recvMsgRollForward = \BlockInMode
_block ChainTip
tip -> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
forall header point tip (m :: * -> *) a.
m (ClientStIdle header point tip m a)
-> ChainSyncClient header point tip m a
ChainSyncClient (IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ())
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
forall a b. (a -> b) -> a -> b
$ do
IO Bool -> IO ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (IO Bool -> IO ()) -> IO Bool -> IO ()
forall a b. (a -> b) -> a -> b
$ STM Bool -> IO Bool
forall a. STM a -> IO a
atomically (STM Bool -> IO Bool) -> STM Bool -> IO Bool
forall a b. (a -> b) -> a -> b
$ TMVar ChainTip -> ChainTip -> STM Bool
forall a. TMVar a -> a -> STM Bool
tryPutTMVar TMVar ChainTip
tipVar ChainTip
tip
ClientStIdle BlockInMode ChainPoint ChainTip IO ()
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ClientStIdle BlockInMode ChainPoint ChainTip IO ()
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ()))
-> ClientStIdle BlockInMode ChainPoint ChainTip IO ()
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
forall a b. (a -> b) -> a -> b
$ () -> ClientStIdle BlockInMode ChainPoint ChainTip IO ()
forall a header point tip (m :: * -> *).
a -> ClientStIdle header point tip m a
Net.Sync.SendMsgDone ()
, recvMsgRollBackward :: ChainPoint
-> ChainTip
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
Net.Sync.recvMsgRollBackward = \ChainPoint
_point ChainTip
tip -> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
forall header point tip (m :: * -> *) a.
m (ClientStIdle header point tip m a)
-> ChainSyncClient header point tip m a
ChainSyncClient (IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ())
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
-> ChainSyncClient BlockInMode ChainPoint ChainTip IO ()
forall a b. (a -> b) -> a -> b
$ do
IO Bool -> IO ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (IO Bool -> IO ()) -> IO Bool -> IO ()
forall a b. (a -> b) -> a -> b
$ STM Bool -> IO Bool
forall a. STM a -> IO a
atomically (STM Bool -> IO Bool) -> STM Bool -> IO Bool
forall a b. (a -> b) -> a -> b
$ TMVar ChainTip -> ChainTip -> STM Bool
forall a. TMVar a -> a -> STM Bool
tryPutTMVar TMVar ChainTip
tipVar ChainTip
tip
ClientStIdle BlockInMode ChainPoint ChainTip IO ()
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ClientStIdle BlockInMode ChainPoint ChainTip IO ()
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ()))
-> ClientStIdle BlockInMode ChainPoint ChainTip IO ()
-> IO (ClientStIdle BlockInMode ChainPoint ChainTip IO ())
forall a b. (a -> b) -> a -> b
$ () -> ClientStIdle BlockInMode ChainPoint ChainTip IO ()
forall a header point tip (m :: * -> *).
a -> ClientStIdle header point tip m a
Net.Sync.SendMsgDone ()
}