gossipsub fixes

This commit is contained in:
Dmitriy Ryajov 2020-05-21 09:01:36 -06:00
parent 6112de746d
commit d4bdb42046
3 changed files with 55 additions and 74 deletions

View File

@ -135,24 +135,27 @@ method handleConn*(p: PubSub,
## that we're interested in ## that we're interested in
## ##
if isNil(conn.peerInfo): try:
trace "no valid PeerId for peer" if isNil(conn.peerInfo):
await conn.close() trace "no valid PeerId for peer"
return await conn.close()
return
proc handler(peer: PubSubPeer, msgs: seq[RPCMsg]) {.async.} = proc handler(peer: PubSubPeer, msgs: seq[RPCMsg]) {.async.} =
# call pubsub rpc handler # call pubsub rpc handler
await p.rpcHandler(peer, msgs) await p.rpcHandler(peer, msgs)
let peer = p.getPeer(conn.peerInfo, proto) let peer = p.getPeer(conn.peerInfo, proto)
let topics = toSeq(p.topics.keys) let topics = toSeq(p.topics.keys)
if topics.len > 0: if topics.len > 0:
await p.sendSubs(peer, topics, true) await p.sendSubs(peer, topics, true)
peer.handler = handler peer.handler = handler
await peer.handle(conn) # spawn peer read loop await peer.handle(conn) # spawn peer read loop
trace "pubsub peer handler ended, cleaning up" trace "pubsub peer handler ended, cleaning up"
await p.internalCleanup(conn) await p.internalClenaup(conn)
except CatchableError as exc:
trace "exception ocurred in pubsub handle", exc = exc.msg
method subscribeToPeer*(p: PubSub, method subscribeToPeer*(p: PubSub,
conn: Connection) {.base, async.} = conn: Connection) {.base, async.} =

View File

@ -436,35 +436,24 @@ method write*(sconn: NoiseConnection, message: seq[byte]): Future[void] {.async.
if message.len == 0: if message.len == 0:
return return
try: var
left = message.len
offset = 0
while left > 0:
let
chunkSize = if left > MaxPlainSize: MaxPlainSize else: left
packed = packNoisePayload(message.toOpenArray(offset, offset + chunkSize - 1))
cipher = sconn.writeCs.encryptWithAd([], packed)
left = left - chunkSize
offset = offset + chunkSize
var var
left = message.len lesize = cipher.len.uint16
offset = 0 besize = lesize.toBytesBE
while left > 0: outbuf = newSeqOfCap[byte](cipher.len + 2)
let trace "sendEncryptedMessage", size = lesize, peer = $sconn.peerInfo, left, offset
chunkSize = if left > MaxPlainSize: MaxPlainSize else: left outbuf &= besize
packed = packNoisePayload(message.toOpenArray(offset, offset + chunkSize - 1)) outbuf &= cipher
cipher = sconn.writeCs.encryptWithAd([], packed) await sconn.stream.write(outbuf)
left = left - chunkSize
offset = offset + chunkSize
var
lesize = cipher.len.uint16
besize = lesize.toBytesBE
outbuf = newSeqOfCap[byte](cipher.len + 2)
trace "sendEncryptedMessage", size = lesize, peer = $sconn.peerInfo, left, offset
outbuf &= besize
outbuf &= cipher
await sconn.stream.write(outbuf)
except LPStreamEOFError:
trace "Ignoring EOF while writing"
except CancelledError as exc:
raise exc
except CatchableError as exc:
# TODO these exceptions are ignored since it's likely that if writes are
# are failing, the underlying connection is already closed - this needs
# more cleanup though
debug "Could not write to connection", error = exc.name
trace "Could not write to connection - verbose", msg = exc.msg
method handshake*(p: Noise, conn: Connection, initiator: bool = false): Future[SecureConn] {.async.} = method handshake*(p: Noise, conn: Connection, initiator: bool = false): Future[SecureConn] {.async.} =
trace "Starting Noise handshake", initiator trace "Starting Noise handshake", initiator

View File

@ -212,40 +212,29 @@ method write*(sconn: SecioConn, message: seq[byte]) {.async.} =
if message.len == 0: if message.len == 0:
return return
try: var
var left = message.len
left = message.len offset = 0
offset = 0 while left > 0:
while left > 0: let
let chunkSize = if left > SecioMaxMessageSize - 64: SecioMaxMessageSize - 64 else: left
chunkSize = if left > SecioMaxMessageSize - 64: SecioMaxMessageSize - 64 else: left macsize = sconn.writerMac.sizeDigest()
macsize = sconn.writerMac.sizeDigest() length = chunkSize + macsize
length = chunkSize + macsize
var msg = newSeq[byte](chunkSize + 4 + macsize) var msg = newSeq[byte](chunkSize + 4 + macsize)
msg[0..<4] = uint32(length).toBytesBE() msg[0..<4] = uint32(length).toBytesBE()
sconn.writerCoder.encrypt(message.toOpenArray(offset, offset + chunkSize - 1), sconn.writerCoder.encrypt(message.toOpenArray(offset, offset + chunkSize - 1),
msg.toOpenArray(4, 4 + chunkSize - 1)) msg.toOpenArray(4, 4 + chunkSize - 1))
left = left - chunkSize left = left - chunkSize
offset = offset + chunkSize offset = offset + chunkSize
let mo = 4 + chunkSize let mo = 4 + chunkSize
sconn.writerMac.update(msg.toOpenArray(4, 4 + chunkSize - 1)) sconn.writerMac.update(msg.toOpenArray(4, 4 + chunkSize - 1))
sconn.writerMac.finish(msg.toOpenArray(mo, mo + macsize - 1)) sconn.writerMac.finish(msg.toOpenArray(mo, mo + macsize - 1))
sconn.writerMac.reset() sconn.writerMac.reset()
trace "Writing message", message = msg.shortLog, left, offset trace "Writing message", message = msg.shortLog, left, offset
await sconn.stream.write(msg) await sconn.stream.write(msg)
except LPStreamEOFError:
trace "Ignoring EOF while writing"
except CancelledError as exc:
raise exc
except CatchableError as exc:
# TODO these exceptions are ignored since it's likely that if writes are
# are failing, the underlying connection is already closed - this needs
# more cleanup though
debug "Could not write to connection", error = exc.name
trace "Could not write to connection - verbose", msg = exc.msg
proc newSecioConn(conn: Connection, proc newSecioConn(conn: Connection,
hash: string, hash: string,