Eip8 auth

This commit is contained in:
Yuriy Glukhov 2018-05-15 21:31:56 +03:00
parent d22c8251dc
commit 74f0b705f0
2 changed files with 20 additions and 8 deletions

View File

@ -334,14 +334,16 @@ proc decodeAuthMessageV4(h: var Handshake, m: openarray[byte]): AuthStatus =
h.remoteHPubkey = pubkey
result = Success
proc expectedAuthMsgLenEip8*(input: openarray[byte]): uint16 {.inline.} =
bigEndian16(addr result, unsafeAddr input[0])
proc decodeAuthMessageEip8(h: var Handshake, m: openarray[byte]): AuthStatus =
## Decodes EIP-8 AuthMessage.
var
pubkey: PublicKey
nonce: Nonce
size: uint16
secret: SharedSecret
bigEndian16(addr size, unsafeAddr m[0])
let size = expectedAuthMsgLenEip8(m)
if 2 + int(size) > len(m):
return(IncompleteError)
var buffer = newSeq[byte](eciesDecryptedLength(int(size)))
@ -434,9 +436,10 @@ proc decodeAuthMessage*(h: var Handshake, input: openarray[byte]): AuthStatus =
if len(input) < AuthMessageV4Length:
result = IncompleteError
elif len(input) == AuthMessageV4Length:
let res = h.decodeAuthMessageV4(input)
var res = h.decodeAuthMessageV4(input)
if res != Success:
res = h.decodeAuthMessageEip8(input)
if res != Success:
if h.decodeAuthMessageEip8(input) != Success:
result = res
else:
h.flags.incl(EIP8)

View File

@ -358,7 +358,6 @@ macro rlpxProtocol*(protoIdentifier: untyped,
error("The only type that can be defined inside a RLPx protocol is the protocol's State type.")
of nnkProcDef:
inc nextId
let
msgIdent = n.name.ident
msgName = $msgIdent
@ -464,6 +463,7 @@ macro rlpxProtocol*(protoIdentifier: untyped,
newStrLitNode($n.name),
thunkName)
inc nextId
else:
error("illegal syntax in a RLPx protocol definition", n)
@ -574,11 +574,20 @@ proc rlpxConnectIncoming*(myKeys: KeyPair, listenPort: Port, address: IpAddress,
var handshake = newHandshake({Responder})
handshake.host = myKeys
var authMsg: array[1024, byte]
var authMsg: array[4086, byte]
var authMsgLen = AuthMessageV4Length
# TODO: Handle both auth methods
await s.fullRecvInto(addr authMsg[0], authMsgLen)
check handshake.decodeAuthMessage(^authMsg)
var ret = handshake.decodeAuthMessage(^authMsg)
if ret == AuthStatus.IncompleteError: # Eip8 auth message is likely
let expectedLen = expectedAuthMsgLenEip8(authMsg).int + 2
if expectedLen > authMsg.len:
raise newException(Exception, "Auth message too big: " & $authMsgLen)
await s.fullRecvInto(addr authMsg[authMsgLen], expectedLen - authMsgLen)
authMsgLen = expectedLen
ret = handshake.decodeAuthMessage(^authMsg)
check ret
var ackMsg: array[AckMessageMaxEIP8, byte]
var ackMsgLen: int