{-# LANGUAGE DataKinds #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
module Ouroboros.Network.NodeToClient
( nodeToClientProtocols
, NodeToClientProtocols (..)
, NodeToClientVersion (..)
, NodeToClientVersionData (..)
, NetworkConnectTracers (..)
, nullNetworkConnectTracers
, connectTo
, connectToWithMux
, chainSyncPeerNull
, localStateQueryPeerNull
, localTxSubmissionPeerNull
, localTxMonitorPeerNull
, IOManager (..)
, AssociateWithIOCP
, withIOManager
, LocalSnocket
, localSnocket
, LocalSocket (..)
, LocalAddress (..)
, LocalConnectionId
, Versions (..)
, versionedNodeToClientProtocols
, simpleSingletonVersions
, foldMapVersions
, combineVersions
, nodeToClientHandshakeCodec
, nodeToClientVersionCodec
, nodeToClientCodecCBORTerm
, ConnectionId (..)
, MinimalInitiatorContext (..)
, ResponderContext (..)
, TraceSendRecv (..)
, ProtocolLimitFailure
, Handshake
, HandshakeTr
) where
import Control.Concurrent.Async qualified as Async
import Control.Exception (SomeException)
import Control.Monad (forever)
import Control.Monad.Class.MonadTimer.SI
import Codec.CBOR.Term qualified as CBOR
import Data.ByteString.Lazy qualified as BL
import Data.Kind (Type)
import Data.Void (Void, absurd)
import Network.Mux qualified as Mx
import Network.TypedProtocol.Peer.Client
import Network.TypedProtocol.Stateful.Peer.Client qualified as Stateful
import Ouroboros.Network.Context
import Ouroboros.Network.Driver (TraceSendRecv (..))
import Ouroboros.Network.Driver.Limits (ProtocolLimitFailure (..))
import Ouroboros.Network.IOManager
import Ouroboros.Network.Mux
import Ouroboros.Network.NodeToClient.Version
import Ouroboros.Network.Protocol.ChainSync.Client as ChainSync
import Ouroboros.Network.Protocol.ChainSync.Type qualified as ChainSync
import Ouroboros.Network.Protocol.Handshake.Codec
import Ouroboros.Network.Protocol.Handshake.Type
import Ouroboros.Network.Protocol.Handshake.Version hiding (Accept)
import Ouroboros.Network.Protocol.LocalStateQuery.Client as LocalStateQuery
import Ouroboros.Network.Protocol.LocalStateQuery.Type qualified as LocalStateQuery
import Ouroboros.Network.Protocol.LocalTxMonitor.Client as LocalTxMonitor
import Ouroboros.Network.Protocol.LocalTxMonitor.Type qualified as LocalTxMonitor
import Ouroboros.Network.Protocol.LocalTxSubmission.Client as LocalTxSubmission
import Ouroboros.Network.Protocol.LocalTxSubmission.Type qualified as LocalTxSubmission
import Ouroboros.Network.Snocket
import Ouroboros.Network.Socket
type HandshakeTr ntcAddr ntcVersion =
Mx.WithBearer (ConnectionId ntcAddr)
(TraceSendRecv (Handshake ntcVersion CBOR.Term))
data NodeToClientProtocols appType ntcAddr bytes m a b = NodeToClientProtocols {
forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localChainSyncProtocol :: RunMiniProtocolWithMinimalCtx
appType ntcAddr bytes m a b,
forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localTxSubmissionProtocol :: RunMiniProtocolWithMinimalCtx
appType ntcAddr bytes m a b,
forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localStateQueryProtocol :: RunMiniProtocolWithMinimalCtx
appType ntcAddr bytes m a b,
forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localTxMonitorProtocol :: RunMiniProtocolWithMinimalCtx
appType ntcAddr bytes m a b
}
nodeToClientProtocols
:: NodeToClientProtocols appType addr bytes m a b
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx appType addr bytes m a b
nodeToClientProtocols :: forall (appType :: Mode) addr bytes (m :: * -> *) a b.
NodeToClientProtocols appType addr bytes m a b
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx appType addr bytes m a b
nodeToClientProtocols NodeToClientProtocols appType addr bytes m a b
protocols NodeToClientVersion
_version NodeToClientVersionData
_versionData =
[MiniProtocol
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b]
-> OuroborosApplication
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b
forall (mode :: Mode) initiatorCtx responderCtx bytes (m :: * -> *)
a b.
[MiniProtocol mode initiatorCtx responderCtx bytes m a b]
-> OuroborosApplication mode initiatorCtx responderCtx bytes m a b
OuroborosApplication ([MiniProtocol
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b]
-> OuroborosApplication
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b)
-> [MiniProtocol
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b]
-> OuroborosApplication
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b
forall a b. (a -> b) -> a -> b
$
case NodeToClientProtocols appType addr bytes m a b
protocols of
NodeToClientProtocols {
RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localChainSyncProtocol :: forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localChainSyncProtocol :: RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localChainSyncProtocol,
RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localTxSubmissionProtocol :: forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localTxSubmissionProtocol :: RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localTxSubmissionProtocol,
RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localStateQueryProtocol :: forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localStateQueryProtocol :: RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localStateQueryProtocol,
RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localTxMonitorProtocol :: forall (appType :: Mode) ntcAddr bytes (m :: * -> *) a b.
NodeToClientProtocols appType ntcAddr bytes m a b
-> RunMiniProtocolWithMinimalCtx appType ntcAddr bytes m a b
localTxMonitorProtocol :: RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localTxMonitorProtocol
} ->
[ RunMiniProtocolWithMinimalCtx appType addr bytes m a b
-> MiniProtocol
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b
forall {mode :: Mode} {initiatorCtx} {responderCtx} {bytes}
{m :: * -> *} {a} {b}.
RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localChainSyncMiniProtocol RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localChainSyncProtocol
, RunMiniProtocolWithMinimalCtx appType addr bytes m a b
-> MiniProtocol
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b
forall {mode :: Mode} {initiatorCtx} {responderCtx} {bytes}
{m :: * -> *} {a} {b}.
RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxSubmissionMiniProtocol RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localTxSubmissionProtocol
, RunMiniProtocolWithMinimalCtx appType addr bytes m a b
-> MiniProtocol
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b
forall {mode :: Mode} {initiatorCtx} {responderCtx} {bytes}
{m :: * -> *} {a} {b}.
RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localStateQueryMiniProtocol RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localStateQueryProtocol
, RunMiniProtocolWithMinimalCtx appType addr bytes m a b
-> MiniProtocol
appType
(MinimalInitiatorContext addr)
(ResponderContext addr)
bytes
m
a
b
forall {mode :: Mode} {initiatorCtx} {responderCtx} {bytes}
{m :: * -> *} {a} {b}.
RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxMonitorMiniProtocol RunMiniProtocolWithMinimalCtx appType addr bytes m a b
localTxMonitorProtocol
]
where
localChainSyncMiniProtocol :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localChainSyncMiniProtocol RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localChainSyncProtocol = MiniProtocol {
miniProtocolNum :: MiniProtocolNum
miniProtocolNum = Word16 -> MiniProtocolNum
MiniProtocolNum Word16
5,
miniProtocolStart :: StartOnDemandOrEagerly
miniProtocolStart = StartOnDemandOrEagerly
StartOnDemand,
miniProtocolLimits :: MiniProtocolLimits
miniProtocolLimits = MiniProtocolLimits
maximumMiniProtocolLimits,
miniProtocolRun :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
miniProtocolRun = RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localChainSyncProtocol
}
localTxSubmissionMiniProtocol :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxSubmissionMiniProtocol RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxSubmissionProtocol = MiniProtocol {
miniProtocolNum :: MiniProtocolNum
miniProtocolNum = Word16 -> MiniProtocolNum
MiniProtocolNum Word16
6,
miniProtocolStart :: StartOnDemandOrEagerly
miniProtocolStart = StartOnDemandOrEagerly
StartOnDemand,
miniProtocolLimits :: MiniProtocolLimits
miniProtocolLimits = MiniProtocolLimits
maximumMiniProtocolLimits,
miniProtocolRun :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
miniProtocolRun = RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxSubmissionProtocol
}
localStateQueryMiniProtocol :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localStateQueryMiniProtocol RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localStateQueryProtocol = MiniProtocol {
miniProtocolNum :: MiniProtocolNum
miniProtocolNum = Word16 -> MiniProtocolNum
MiniProtocolNum Word16
7,
miniProtocolStart :: StartOnDemandOrEagerly
miniProtocolStart = StartOnDemandOrEagerly
StartOnDemand,
miniProtocolLimits :: MiniProtocolLimits
miniProtocolLimits = MiniProtocolLimits
maximumMiniProtocolLimits,
miniProtocolRun :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
miniProtocolRun = RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localStateQueryProtocol
}
localTxMonitorMiniProtocol :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
-> MiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxMonitorMiniProtocol RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxMonitorProtocol = MiniProtocol {
miniProtocolNum :: MiniProtocolNum
miniProtocolNum = Word16 -> MiniProtocolNum
MiniProtocolNum Word16
9,
miniProtocolStart :: StartOnDemandOrEagerly
miniProtocolStart = StartOnDemandOrEagerly
StartOnDemand,
miniProtocolLimits :: MiniProtocolLimits
miniProtocolLimits = MiniProtocolLimits
maximumMiniProtocolLimits,
miniProtocolRun :: RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
miniProtocolRun = RunMiniProtocol mode initiatorCtx responderCtx bytes m a b
localTxMonitorProtocol
}
maximumMiniProtocolLimits :: MiniProtocolLimits
maximumMiniProtocolLimits :: MiniProtocolLimits
maximumMiniProtocolLimits =
MiniProtocolLimits {
maximumIngressQueue :: Int
maximumIngressQueue = Int
0xffffffff
}
versionedNodeToClientProtocols
:: NodeToClientVersion
-> NodeToClientVersionData
-> NodeToClientProtocols appType LocalAddress bytes m a b
-> Versions NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx appType LocalAddress bytes m a b)
versionedNodeToClientProtocols :: 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)
versionedNodeToClientProtocols NodeToClientVersion
versionNumber NodeToClientVersionData
versionData NodeToClientProtocols appType LocalAddress bytes m a b
protocols =
NodeToClientVersion
-> NodeToClientVersionData
-> (NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx
appType LocalAddress bytes m a b)
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
appType LocalAddress bytes m a b)
forall vNum vData r.
vNum -> vData -> (vData -> r) -> Versions vNum vData r
simpleSingletonVersions
NodeToClientVersion
versionNumber
NodeToClientVersionData
versionData
(NodeToClientProtocols appType LocalAddress bytes m a b
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx
appType LocalAddress bytes m a b
forall (appType :: Mode) addr bytes (m :: * -> *) a b.
NodeToClientProtocols appType addr bytes m a b
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx appType addr bytes m a b
nodeToClientProtocols NodeToClientProtocols appType LocalAddress bytes m a b
protocols NodeToClientVersion
versionNumber)
connectTo
:: LocalSnocket
-> NetworkConnectTracers LocalAddress NodeToClientVersion
-> Versions NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
Mx.InitiatorMode LocalAddress BL.ByteString IO a Void)
-> FilePath
-> IO (Either SomeException a)
connectTo :: forall a.
LocalSnocket
-> NetworkConnectTracers LocalAddress NodeToClientVersion
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a Void)
-> FilePath
-> IO (Either SomeException a)
connectTo LocalSnocket
snocket NetworkConnectTracers LocalAddress NodeToClientVersion
tracers Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a Void)
versions FilePath
path =
(Either a Void -> a)
-> Either SomeException (Either a Void) -> Either SomeException a
forall a b.
(a -> b) -> Either SomeException a -> Either SomeException b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap Either a Void -> a
forall x. Either x Void -> x
fn (Either SomeException (Either a Void) -> Either SomeException a)
-> IO (Either SomeException (Either a Void))
-> IO (Either SomeException a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$>
LocalSnocket
-> MakeBearer IO LocalSocket
-> ConnectToArgs
LocalSocket
LocalAddress
NodeToClientVersion
NodeToClientVersionData
-> (LocalSocket -> IO ())
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a Void)
-> Maybe LocalAddress
-> LocalAddress
-> IO (Either SomeException (Either a Void))
forall (muxMode :: Mode) vNumber vData fd addr a b.
(Ord vNumber, Typeable vNumber, Show vNumber,
HasInitiator muxMode ~ 'True) =>
Snocket IO fd addr
-> MakeBearer IO fd
-> ConnectToArgs fd addr vNumber vData
-> (fd -> IO ())
-> Versions
vNumber
vData
(OuroborosApplicationWithMinimalCtx muxMode addr ByteString IO a b)
-> Maybe addr
-> addr
-> IO (Either SomeException (Either a b))
connectToNode
LocalSnocket
snocket
MakeBearer IO LocalSocket
makeLocalBearer
ConnectToArgs {
ctaHandshakeCodec :: Codec
(Handshake NodeToClientVersion Term)
DeserialiseFailure
IO
ByteString
ctaHandshakeCodec = Codec
(Handshake NodeToClientVersion Term)
DeserialiseFailure
IO
ByteString
forall (m :: * -> *).
MonadST m =>
Codec
(Handshake NodeToClientVersion Term)
DeserialiseFailure
m
ByteString
nodeToClientHandshakeCodec,
ctaHandshakeTimeLimits :: ProtocolTimeLimits (Handshake NodeToClientVersion Term)
ctaHandshakeTimeLimits = ProtocolTimeLimits (Handshake NodeToClientVersion Term)
forall {k} (vNumber :: k).
ProtocolTimeLimits (Handshake vNumber Term)
noTimeLimitsHandshake,
ctaVersionDataCodec :: VersionDataCodec Term NodeToClientVersion NodeToClientVersionData
ctaVersionDataCodec = (NodeToClientVersion -> CodecCBORTerm Text NodeToClientVersionData)
-> VersionDataCodec
Term NodeToClientVersion NodeToClientVersionData
forall vNumber vData.
(vNumber -> CodecCBORTerm Text vData)
-> VersionDataCodec Term vNumber vData
cborTermVersionDataCodec NodeToClientVersion -> CodecCBORTerm Text NodeToClientVersionData
nodeToClientCodecCBORTerm,
ctaConnectTracers :: NetworkConnectTracers LocalAddress NodeToClientVersion
ctaConnectTracers = NetworkConnectTracers LocalAddress NodeToClientVersion
tracers,
ctaHandshakeCallbacks :: HandshakeCallbacks NodeToClientVersionData
ctaHandshakeCallbacks = (NodeToClientVersionData
-> NodeToClientVersionData -> Accept NodeToClientVersionData)
-> (NodeToClientVersionData -> Bool)
-> HandshakeCallbacks NodeToClientVersionData
forall vData.
(vData -> vData -> Accept vData)
-> (vData -> Bool) -> HandshakeCallbacks vData
HandshakeCallbacks NodeToClientVersionData
-> NodeToClientVersionData -> Accept NodeToClientVersionData
forall v. Acceptable v => v -> v -> Accept v
acceptableVersion NodeToClientVersionData -> Bool
forall v. Queryable v => v -> Bool
queryVersion
}
LocalSocket -> IO ()
forall a. Monoid a => a
mempty
Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a Void)
versions
Maybe LocalAddress
forall a. Maybe a
Nothing
(FilePath -> LocalAddress
localAddressFromPath FilePath
path)
where
fn :: forall x. Either x Void -> x
fn :: forall x. Either x Void -> x
fn = (x -> x) -> (Void -> x) -> Either x Void -> x
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either x -> x
forall a. a -> a
id Void -> x
forall a. Void -> a
absurd
connectToWithMux
:: LocalSnocket
-> NetworkConnectTracers LocalAddress NodeToClientVersion
-> Versions NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
Mx.InitiatorMode LocalAddress BL.ByteString IO a b)
-> FilePath
-> ( ConnectionId LocalAddress
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx Mx.InitiatorMode LocalAddress BL.ByteString IO a b
-> Mx.Mux Mx.InitiatorMode IO
-> Async.Async ()
-> IO x)
-> IO x
connectToWithMux :: forall a b x.
LocalSnocket
-> NetworkConnectTracers LocalAddress NodeToClientVersion
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b)
-> FilePath
-> (ConnectionId LocalAddress
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b
-> Mux 'InitiatorMode IO
-> Async ()
-> IO x)
-> IO x
connectToWithMux LocalSnocket
snocket NetworkConnectTracers LocalAddress NodeToClientVersion
tracers Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b)
versions FilePath
path ConnectionId LocalAddress
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b
-> Mux 'InitiatorMode IO
-> Async ()
-> IO x
k =
LocalSnocket
-> MakeBearer IO LocalSocket
-> ConnectToArgs
LocalSocket
LocalAddress
NodeToClientVersion
NodeToClientVersionData
-> (LocalSocket -> IO ())
-> Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b)
-> Maybe LocalAddress
-> LocalAddress
-> (ConnectionId LocalAddress
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b
-> Mux 'InitiatorMode IO
-> Async IO ()
-> IO x)
-> IO x
forall (muxMode :: Mode) vNumber vData fd addr a b x.
(Ord vNumber, Typeable vNumber, Show vNumber,
HasInitiator muxMode ~ 'True) =>
Snocket IO fd addr
-> MakeBearer IO fd
-> ConnectToArgs fd addr vNumber vData
-> (fd -> IO ())
-> Versions
vNumber
vData
(OuroborosApplicationWithMinimalCtx muxMode addr ByteString IO a b)
-> Maybe addr
-> addr
-> (ConnectionId addr
-> vNumber
-> vData
-> OuroborosApplicationWithMinimalCtx
muxMode addr ByteString IO a b
-> Mux muxMode IO
-> Async IO ()
-> IO x)
-> IO x
connectToNodeWithMux
LocalSnocket
snocket
MakeBearer IO LocalSocket
makeLocalBearer
ConnectToArgs {
ctaHandshakeCodec :: Codec
(Handshake NodeToClientVersion Term)
DeserialiseFailure
IO
ByteString
ctaHandshakeCodec = Codec
(Handshake NodeToClientVersion Term)
DeserialiseFailure
IO
ByteString
forall (m :: * -> *).
MonadST m =>
Codec
(Handshake NodeToClientVersion Term)
DeserialiseFailure
m
ByteString
nodeToClientHandshakeCodec,
ctaHandshakeTimeLimits :: ProtocolTimeLimits (Handshake NodeToClientVersion Term)
ctaHandshakeTimeLimits = ProtocolTimeLimits (Handshake NodeToClientVersion Term)
forall {k} (vNumber :: k).
ProtocolTimeLimits (Handshake vNumber Term)
noTimeLimitsHandshake,
ctaVersionDataCodec :: VersionDataCodec Term NodeToClientVersion NodeToClientVersionData
ctaVersionDataCodec = (NodeToClientVersion -> CodecCBORTerm Text NodeToClientVersionData)
-> VersionDataCodec
Term NodeToClientVersion NodeToClientVersionData
forall vNumber vData.
(vNumber -> CodecCBORTerm Text vData)
-> VersionDataCodec Term vNumber vData
cborTermVersionDataCodec NodeToClientVersion -> CodecCBORTerm Text NodeToClientVersionData
nodeToClientCodecCBORTerm,
ctaConnectTracers :: NetworkConnectTracers LocalAddress NodeToClientVersion
ctaConnectTracers = NetworkConnectTracers LocalAddress NodeToClientVersion
tracers,
ctaHandshakeCallbacks :: HandshakeCallbacks NodeToClientVersionData
ctaHandshakeCallbacks = (NodeToClientVersionData
-> NodeToClientVersionData -> Accept NodeToClientVersionData)
-> (NodeToClientVersionData -> Bool)
-> HandshakeCallbacks NodeToClientVersionData
forall vData.
(vData -> vData -> Accept vData)
-> (vData -> Bool) -> HandshakeCallbacks vData
HandshakeCallbacks NodeToClientVersionData
-> NodeToClientVersionData -> Accept NodeToClientVersionData
forall v. Acceptable v => v -> v -> Accept v
acceptableVersion NodeToClientVersionData -> Bool
forall v. Queryable v => v -> Bool
queryVersion
}
LocalSocket -> IO ()
forall a. Monoid a => a
mempty
Versions
NodeToClientVersion
NodeToClientVersionData
(OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b)
versions
Maybe LocalAddress
forall a. Maybe a
Nothing
(FilePath -> LocalAddress
localAddressFromPath FilePath
path)
ConnectionId LocalAddress
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b
-> Mux 'InitiatorMode IO
-> Async ()
-> IO x
ConnectionId LocalAddress
-> NodeToClientVersion
-> NodeToClientVersionData
-> OuroborosApplicationWithMinimalCtx
'InitiatorMode LocalAddress ByteString IO a b
-> Mux 'InitiatorMode IO
-> Async IO ()
-> IO x
k
type LocalConnectionId = ConnectionId LocalAddress
chainSyncPeerNull
:: forall (header :: Type) (point :: Type) (tip :: Type) m a. MonadDelay m
=> Client (ChainSync.ChainSync header point tip)
NonPipelined ChainSync.StIdle m a
chainSyncPeerNull :: forall header point tip (m :: * -> *) a.
MonadDelay m =>
Client (ChainSync header point tip) 'NonPipelined 'StIdle m a
chainSyncPeerNull =
ChainSyncClient header point tip m a
-> Client (ChainSync header point tip) 'NonPipelined 'StIdle m a
forall header point tip (m :: * -> *) a.
Monad m =>
ChainSyncClient header point tip m a
-> Client (ChainSync header point tip) 'NonPipelined 'StIdle m a
ChainSync.chainSyncClientPeer
(m (ClientStIdle header point tip m a)
-> ChainSyncClient header point tip m a
forall header point tip (m :: * -> *) a.
m (ClientStIdle header point tip m a)
-> ChainSyncClient header point tip m a
ChainSync.ChainSyncClient m (ClientStIdle header point tip m a)
forall (m :: * -> *) a. MonadDelay m => m a
untilTheCowsComeHome )
localStateQueryPeerNull
:: forall (block :: Type) (point :: Type) (query :: Type -> Type) m a.
MonadDelay m
=> Stateful.Client (LocalStateQuery.LocalStateQuery block point query)
LocalStateQuery.StIdle LocalStateQuery.State m a
localStateQueryPeerNull :: forall block point (query :: * -> *) (m :: * -> *) a.
MonadDelay m =>
Client (LocalStateQuery block point query) 'StIdle State m a
localStateQueryPeerNull =
LocalStateQueryClient block point query m a
-> Client (LocalStateQuery block point query) 'StIdle State m a
forall block point (query :: * -> *) (m :: * -> *) a.
Monad m =>
LocalStateQueryClient block point query m a
-> Client (LocalStateQuery block point query) 'StIdle State m a
LocalStateQuery.localStateQueryClientPeer
(m (ClientStIdle block point query m a)
-> LocalStateQueryClient block point query m a
forall block point (query :: * -> *) (m :: * -> *) a.
m (ClientStIdle block point query m a)
-> LocalStateQueryClient block point query m a
LocalStateQuery.LocalStateQueryClient m (ClientStIdle block point query m a)
forall (m :: * -> *) a. MonadDelay m => m a
untilTheCowsComeHome)
localTxSubmissionPeerNull
:: forall (tx :: Type) (reject :: Type) m a. MonadDelay m
=> Client (LocalTxSubmission.LocalTxSubmission tx reject)
NonPipelined LocalTxSubmission.StIdle m a
localTxSubmissionPeerNull :: forall tx reject (m :: * -> *) a.
MonadDelay m =>
Client (LocalTxSubmission tx reject) 'NonPipelined 'StIdle m a
localTxSubmissionPeerNull =
LocalTxSubmissionClient tx reject m a
-> Client (LocalTxSubmission tx reject) 'NonPipelined 'StIdle m a
forall tx reject (m :: * -> *) a.
Monad m =>
LocalTxSubmissionClient tx reject m a
-> Client (LocalTxSubmission tx reject) 'NonPipelined 'StIdle m a
LocalTxSubmission.localTxSubmissionClientPeer
(m (LocalTxClientStIdle tx reject m a)
-> LocalTxSubmissionClient tx reject m a
forall tx reject (m :: * -> *) a.
m (LocalTxClientStIdle tx reject m a)
-> LocalTxSubmissionClient tx reject m a
LocalTxSubmission.LocalTxSubmissionClient m (LocalTxClientStIdle tx reject m a)
forall (m :: * -> *) a. MonadDelay m => m a
untilTheCowsComeHome)
localTxMonitorPeerNull
:: forall (txid :: Type) (tx :: Type) (slot :: Type) m a. MonadDelay m
=> Client (LocalTxMonitor.LocalTxMonitor txid tx slot)
NonPipelined LocalTxMonitor.StIdle m a
localTxMonitorPeerNull :: forall txid tx slot (m :: * -> *) a.
MonadDelay m =>
Client (LocalTxMonitor txid tx slot) 'NonPipelined 'StIdle m a
localTxMonitorPeerNull =
LocalTxMonitorClient txid tx slot m a
-> Client (LocalTxMonitor txid tx slot) 'NonPipelined 'StIdle m a
forall txid tx slot (m :: * -> *) a.
Monad m =>
LocalTxMonitorClient txid tx slot m a
-> Client (LocalTxMonitor txid tx slot) 'NonPipelined 'StIdle m a
LocalTxMonitor.localTxMonitorClientPeer
(m (ClientStIdle txid tx slot m a)
-> LocalTxMonitorClient txid tx slot m a
forall txid tx slot (m :: * -> *) a.
m (ClientStIdle txid tx slot m a)
-> LocalTxMonitorClient txid tx slot m a
LocalTxMonitor.LocalTxMonitorClient m (ClientStIdle txid tx slot m a)
forall (m :: * -> *) a. MonadDelay m => m a
untilTheCowsComeHome)
untilTheCowsComeHome :: MonadDelay m => m a
untilTheCowsComeHome :: forall (m :: * -> *) a. MonadDelay m => m a
untilTheCowsComeHome = m () -> m a
forall (f :: * -> *) a b. Applicative f => f a -> f b
forever (m () -> m a) -> m () -> m a
forall a b. (a -> b) -> a -> b
$ DiffTime -> m ()
forall (m :: * -> *). MonadDelay m => DiffTime -> m ()
threadDelay DiffTime
43200