From 991240d4ee9241d2c2da38f6730b8581a1280a32 Mon Sep 17 00:00:00 2001 From: ssadler Date: Tue, 19 May 2020 22:05:00 -0300 Subject: [PATCH] fix disconnect remote endpoints --- src/Network/Transport/InMemory/Internal.hs | 46 +++++++++++++--------- 1 file changed, 28 insertions(+), 18 deletions(-) diff --git a/src/Network/Transport/InMemory/Internal.hs b/src/Network/Transport/InMemory/Internal.hs index 6ba184a..347e3b0 100644 --- a/src/Network/Transport/InMemory/Internal.hs +++ b/src/Network/Transport/InMemory/Internal.hs @@ -156,24 +156,34 @@ apiNewEndPoint state = handle (return . Left) $ atomically $ do TransportError ResolveMulticastGroupUnsupported "Multicast not supported" apiCloseEndPoint :: TVar TransportState -> EndPointAddress -> IO () -apiCloseEndPoint state addr = atomically $ whenValidTransportState state $ \vst -> - forM_ (vst ^. localEndPointAt addr) $ \lep -> do - old <- swapTVar (localEndPointState lep) LocalEndPointClosed - case old of - LocalEndPointClosed -> return () - LocalEndPointValid lepvst -> do - forM_ (Map.elems (lepvst ^. connections)) $ \lconn -> do - st <- swapTVar (localConnectionState lconn) LocalConnectionClosed - case st of - LocalConnectionClosed -> return () - LocalConnectionFailed -> return () - _ -> forM_ (vst ^. localEndPointAt (localConnectionRemoteAddress lconn)) $ \thep -> - whenValidLocalEndPointState thep $ \_ -> do - writeTChan (localEndPointChannel thep) - (ConnectionClosed (localConnectionId lconn)) - writeTChan (localEndPointChannel lep) EndPointClosed - writeTVar (localEndPointState lep) LocalEndPointClosed - writeTVar state (TransportValid $ (localEndPoints ^: Map.delete addr) vst) +apiCloseEndPoint state addr = atomically $ whenValidTransportState state $ \vst -> do + + forM_ (Map.toList $ _localEndPoints vst) $ + \(theirAddr, lep) -> do + + if theirAddr == addr + then do + old <- swapTVar (localEndPointState lep) LocalEndPointClosed + case old of + LocalEndPointClosed -> return () + LocalEndPointValid lepvst -> do + forM_ (Map.elems (lepvst ^. connections)) $ \lconn -> do + st <- swapTVar (localConnectionState lconn) LocalConnectionClosed + case st of + LocalConnectionClosed -> return () + LocalConnectionFailed -> return () + _ -> do + forM_ (vst ^. localEndPointAt (localConnectionRemoteAddress lconn)) $ \thep -> + whenValidLocalEndPointState thep $ \_ -> do + writeTChan (localEndPointChannel thep) + (ConnectionClosed (localConnectionId lconn)) + writeTChan (localEndPointChannel lep) EndPointClosed + writeTVar (localEndPointState lep) LocalEndPointClosed + + else do + apiBreakConnection state addr theirAddr "remote endpoint disconnected" + + writeTVar state (TransportValid $ (localEndPoints ^: Map.delete addr) vst) -- | Tear down functions that should be called in case if conncetion fails. apiBreakConnection :: TVar TransportState