`proc` to `func` in engine authentication (#5718)
This commit is contained in:
parent
401d6bac91
commit
07455e67a9
|
@ -23,7 +23,7 @@ export rand, results
|
||||||
const
|
const
|
||||||
JWT_SECRET_LEN = 32
|
JWT_SECRET_LEN = 32
|
||||||
|
|
||||||
proc base64urlEncode(x: auto): string =
|
func base64urlEncode(x: auto): string =
|
||||||
# The only strings this gets are internally generated, and don't have
|
# The only strings this gets are internally generated, and don't have
|
||||||
# encoding quirks.
|
# encoding quirks.
|
||||||
base64.encode(x, safe = true).replace("=", "")
|
base64.encode(x, safe = true).replace("=", "")
|
||||||
|
@ -41,7 +41,7 @@ func getIatToken*(time: int64): JsonNode =
|
||||||
# an example of an iat claim: {"iat": 1371720939}
|
# an example of an iat claim: {"iat": 1371720939}
|
||||||
%* {"iat": time}
|
%* {"iat": time}
|
||||||
|
|
||||||
proc getSignedToken*(key: openArray[byte], payload: string): string =
|
func getSignedToken*(key: openArray[byte], payload: string): string =
|
||||||
# https://github.com/ethereum/execution-apis/blob/v1.0.0-beta.3/src/engine/authentication.md#jwt-specifications
|
# https://github.com/ethereum/execution-apis/blob/v1.0.0-beta.3/src/engine/authentication.md#jwt-specifications
|
||||||
# "The execution layer client **MUST** support at least the following `alg`
|
# "The execution layer client **MUST** support at least the following `alg`
|
||||||
# `HMAC + SHA256` (`HS256`)"
|
# `HMAC + SHA256` (`HS256`)"
|
||||||
|
@ -57,10 +57,10 @@ proc getSignedToken*(key: openArray[byte], payload: string): string =
|
||||||
|
|
||||||
signingInput & "." & base64urlEncode(sha256.hmac(key, signingInput).data)
|
signingInput & "." & base64urlEncode(sha256.hmac(key, signingInput).data)
|
||||||
|
|
||||||
proc getSignedIatToken*(key: openArray[byte], time: int64): string =
|
func getSignedIatToken*(key: openArray[byte], time: int64): string =
|
||||||
getSignedToken(key, $getIatToken(time))
|
getSignedToken(key, $getIatToken(time))
|
||||||
|
|
||||||
proc parseJwtTokenValue*(input: string): Result[seq[byte], cstring] =
|
func parseJwtTokenValue*(input: string): Result[seq[byte], cstring] =
|
||||||
# Secret JWT key is parsed in constant time using nimcrypto:
|
# Secret JWT key is parsed in constant time using nimcrypto:
|
||||||
# https://github.com/cheatfate/nimcrypto/pull/44
|
# https://github.com/cheatfate/nimcrypto/pull/44
|
||||||
let secret = utils.fromHex(input)
|
let secret = utils.fromHex(input)
|
||||||
|
|
Loading…
Reference in New Issue