testing mplex
This commit is contained in:
parent
b7f999d316
commit
8338a16aab
|
@ -7,10 +7,12 @@
|
|||
## This file may not be copied, modified, or distributed except according to
|
||||
## those terms.
|
||||
|
||||
import chronos
|
||||
import chronos, strformat
|
||||
import ../../stream/bufferstream,
|
||||
../../stream/lpstream,
|
||||
types, coder, ../../connection
|
||||
../../connection,
|
||||
nimcrypto/utils,
|
||||
types, coder
|
||||
|
||||
type
|
||||
Channel* = ref object of BufferStream
|
||||
|
@ -45,7 +47,7 @@ proc newChannel*(id: int,
|
|||
result.initBufferStream(writeHandler, size)
|
||||
|
||||
proc closeMessage(s: Channel) {.async, gcsafe.} =
|
||||
await s.conn.writeHeader(s.id, s.closeCode, 0) # write header
|
||||
await s.conn.writeHeader(s.id, s.closeCode) # write header
|
||||
|
||||
proc closed*(s: Channel): bool =
|
||||
s.closedLocal
|
||||
|
@ -58,7 +60,7 @@ method close*(s: Channel) {.async, gcsafe.} =
|
|||
await s.closeMessage()
|
||||
|
||||
proc resetMessage(s: Channel) {.async, gcsafe.} =
|
||||
await s.conn.writeHeader(s.id, s.resetCode, 0)
|
||||
await s.conn.writeHeader(s.id, s.resetCode)
|
||||
|
||||
proc resetByRemote*(s: Channel) {.async, gcsafe.} =
|
||||
await allFutures(s.close(), s.closedByRemote())
|
||||
|
|
|
@ -8,9 +8,12 @@
|
|||
## those terms.
|
||||
|
||||
import chronos
|
||||
import ../../connection, ../../varint,
|
||||
../../vbuffer, types,
|
||||
../../stream/lpstream
|
||||
import types,
|
||||
../../connection,
|
||||
../../varint,
|
||||
../../vbuffer,
|
||||
../../stream/lpstream,
|
||||
nimcrypto/utils
|
||||
|
||||
proc readHeader*(conn: Connection): Future[(uint, MessageType)] {.async, gcsafe.} =
|
||||
var
|
||||
|
@ -29,11 +32,12 @@ proc readHeader*(conn: Connection): Future[(uint, MessageType)] {.async, gcsafe.
|
|||
return
|
||||
except LPStreamIncompleteError:
|
||||
buffer.setLen(0)
|
||||
raise newException(CatchableError, "Could not decode header!")
|
||||
|
||||
proc writeHeader*(conn: Connection,
|
||||
id: int,
|
||||
msgType: MessageType,
|
||||
size: int) {.async, gcsafe.} =
|
||||
size: int = 0) {.async, gcsafe.} =
|
||||
## write lenght prefixed
|
||||
var buf = initVBuffer()
|
||||
buf.writeVarint(LPSomeUVarint(id.uint shl 3 or msgType.uint))
|
||||
|
|
|
@ -16,13 +16,16 @@
|
|||
## This still needs to be implemented properly - I'm leaving it
|
||||
## here to not forget that this needs to be fixed ASAP.
|
||||
|
||||
import tables, sequtils
|
||||
import tables, sequtils, strformat
|
||||
import chronos
|
||||
import ../../varint, ../../connection,
|
||||
../../vbuffer, ../../protocol,
|
||||
import coder, types, channel,
|
||||
../../varint,
|
||||
../../connection,
|
||||
../../vbuffer,
|
||||
../../protocols/protocol,
|
||||
../../stream/bufferstream,
|
||||
../../stream/lpstream, ../muxer,
|
||||
coder, types, channel
|
||||
../../stream/lpstream,
|
||||
../muxer
|
||||
|
||||
type
|
||||
Mplex* = ref object of Muxer
|
||||
|
@ -90,7 +93,7 @@ proc newMplex*(conn: Connection,
|
|||
|
||||
method newStream*(m: Mplex): Future[Connection] {.async, gcsafe.} =
|
||||
let channel = await m.newStreamInternal()
|
||||
await m.connection.writeHeader(channel.id, MessageType.New, 0)
|
||||
await m.connection.writeHeader(channel.id, MessageType.New)
|
||||
result = newConnection(channel)
|
||||
|
||||
method close*(m: Mplex) {.async, gcsafe.} =
|
||||
|
|
|
@ -8,7 +8,8 @@
|
|||
## those terms.
|
||||
|
||||
import chronos
|
||||
import ../protocol, ../connection
|
||||
import ../protocols/protocol,
|
||||
../connection
|
||||
|
||||
type
|
||||
StreamHandler* = proc(conn: Connection): Future[void] {.gcsafe.}
|
||||
|
@ -21,21 +22,28 @@ type
|
|||
# this wraps a creator proc that knows how to make muxers
|
||||
MuxerProvider* = ref object of LPProtocol
|
||||
newMuxer*: MuxerCreator
|
||||
streamHandler*: StreamHandler
|
||||
|
||||
method newStream*(m: Muxer): Future[Connection] {.base, async, gcsafe.} = discard
|
||||
method close*(m: Muxer) {.base, async, gcsafe.} = discard
|
||||
method handle*(m: Muxer): Future[void] {.base, async, gcsafe.} = discard
|
||||
method `=streamHandler`*(m: Muxer, handler: StreamHandler) {.base, gcsafe.} =
|
||||
m.streamHandler = handler
|
||||
|
||||
proc newMuxerProvider*(creator: MuxerCreator, codec: string): MuxerProvider {.gcsafe.} =
|
||||
new result
|
||||
result.newMuxer = creator
|
||||
result.codec = codec
|
||||
result.init()
|
||||
|
||||
method `=streamHandler`*(m: MuxerProvider, handler: StreamHandler) {.base, gcsafe.} =
|
||||
m.streamHandler = handler
|
||||
|
||||
method init(c: MuxerProvider) =
|
||||
proc handler(conn: Connection, proto: string) {.async, gcsafe, closure.} =
|
||||
let muxer = c.newMuxer(conn)
|
||||
if not isNil(c.streamHandler):
|
||||
muxer.streamHandler = c.streamHandler
|
||||
await muxer.handle()
|
||||
|
||||
c.handler = handler
|
||||
|
||||
method newStream*(m: Muxer): Future[Connection] {.base, async, gcsafe.} = discard
|
||||
method close*(m: Muxer) {.base, async, gcsafe.} = discard
|
||||
method handle*(m: Muxer): Future[void] {.base, async, gcsafe.} = discard
|
||||
|
||||
method `=streamHandler`*(m: Muxer, handler: StreamHandler) {.base, gcsafe.} =
|
||||
m.streamHandler = handler
|
||||
|
|
Loading…
Reference in New Issue