mirror of
https://github.com/vacp2p/nim-libp2p-experimental.git
synced 2025-01-12 03:14:15 +00:00
proper connection cleanup
This commit is contained in:
parent
0c8dde15e7
commit
976164ba3c
@ -113,9 +113,10 @@ method closed*(s: Connection): bool =
|
||||
result = s.stream.closed
|
||||
|
||||
method close*(s: Connection) {.async, gcsafe.} =
|
||||
trace "closing connection", closed = s.closed,
|
||||
trace "about to close connection", closed = s.closed,
|
||||
peer = if not isNil(s.peerInfo):
|
||||
s.peerInfo.id else: ""
|
||||
|
||||
if not s.closed:
|
||||
if not isNil(s.stream) and not s.stream.closed:
|
||||
trace "closing connection", closed = s.closed,
|
||||
@ -125,6 +126,7 @@ method close*(s: Connection) {.async, gcsafe.} =
|
||||
|
||||
s.closeEvent.fire()
|
||||
s.isClosed = true
|
||||
|
||||
trace "connection closed", closed = s.closed,
|
||||
peer = if not isNil(s.peerInfo):
|
||||
s.peerInfo.id else: ""
|
||||
|
@ -21,6 +21,10 @@ logScope:
|
||||
type TcpTransport* = ref object of Transport
|
||||
server*: StreamServer
|
||||
|
||||
proc cleanup(t: Transport, conn: Connection) {.async.} =
|
||||
await conn.closeEvent.wait()
|
||||
t.connections.keepItIf(it != conn)
|
||||
|
||||
proc connHandler*(t: Transport,
|
||||
server: StreamServer,
|
||||
client: StreamTransport,
|
||||
@ -32,12 +36,10 @@ proc connHandler*(t: Transport,
|
||||
if not initiator:
|
||||
if not isNil(t.handler):
|
||||
asyncCheck t.handler(conn)
|
||||
# TODO: this needs rethinking,
|
||||
# currently it leaks since there
|
||||
# is no way to delete the conn on close
|
||||
# let connHolder: ConnHolder = ConnHolder(connection: conn,
|
||||
# connFuture: handlerFut)
|
||||
# t.connections.add(connHolder)
|
||||
|
||||
t.connections.add(conn)
|
||||
asyncCheck t.cleanup(conn)
|
||||
|
||||
result = conn
|
||||
|
||||
proc connCb(server: StreamServer,
|
||||
@ -55,9 +57,10 @@ method close*(t: TcpTransport): Future[void] {.async, gcsafe.} =
|
||||
await procCall Transport(t).close() # call base
|
||||
|
||||
# server can be nil
|
||||
if t.server != nil:
|
||||
if isNil(t.server):
|
||||
t.server.stop()
|
||||
t.server.close()
|
||||
await t.server.join()
|
||||
trace "transport stopped"
|
||||
|
||||
method listen*(t: TcpTransport,
|
||||
|
@ -16,13 +16,9 @@ import ../connection,
|
||||
type
|
||||
ConnHandler* = proc (conn: Connection): Future[void] {.gcsafe.}
|
||||
|
||||
ConnHolder* = object
|
||||
connection*: Connection
|
||||
connFuture*: Future[void]
|
||||
|
||||
Transport* = ref object of RootObj
|
||||
ma*: Multiaddress
|
||||
connections*: seq[ConnHolder]
|
||||
connections*: seq[Connection]
|
||||
handler*: ConnHandler
|
||||
multicodec*: MultiCodec
|
||||
|
||||
@ -37,7 +33,7 @@ proc newTransport*(t: typedesc[Transport]): t {.gcsafe.} =
|
||||
method close*(t: Transport) {.base, async, gcsafe.} =
|
||||
## stop and cleanup the transport
|
||||
## including all outstanding connections
|
||||
await allFutures(t.connections.mapIt(it.connection.close()))
|
||||
await allFutures(t.connections.mapIt(it.close()))
|
||||
|
||||
method listen*(t: Transport,
|
||||
ma: MultiAddress,
|
||||
|
Loading…
x
Reference in New Issue
Block a user