From 3a35809a02b4fbe23b2dc843806ec81f67521c6d Mon Sep 17 00:00:00 2001 From: Zahary Karadjov Date: Tue, 14 Mar 2023 14:02:50 +0200 Subject: [PATCH] Backwards-compatible handling of Engine URLs that don't include a specified protocol --- beacon_chain/eth1/el_conf.nim | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/beacon_chain/eth1/el_conf.nim b/beacon_chain/eth1/el_conf.nim index c3aefa9fc..287ad7b6f 100644 --- a/beacon_chain/eth1/el_conf.nim +++ b/beacon_chain/eth1/el_conf.nim @@ -126,6 +126,15 @@ proc parseCmdArg*(T: type EngineApiUrlConfigValue, input: string): T jwtSecretFile: jwtSecretFile, roles: roles) +proc fixupWeb3Urls*(web3Url: var string) = + var normalizedUrl = toLowerAscii(web3Url) + if not (normalizedUrl.startsWith("https://") or + normalizedUrl.startsWith("http://") or + normalizedUrl.startsWith("wss://") or + normalizedUrl.startsWith("ws://")): + warn "The Web3 URL does not specify a protocol. Assuming a WebSocket server", web3Url + web3Url = "ws://" & web3Url + proc toFinalUrl*(confValue: EngineApiUrlConfigValue, confJwtSecret: Option[seq[byte]]): Result[EngineApiUrl, cstring] = if confValue.jwtSecret.isSome and confValue.jwtSecretFile.isSome: @@ -138,8 +147,11 @@ proc toFinalUrl*(confValue: EngineApiUrlConfigValue, else: confJwtSecret + var url = confValue.url + fixupWeb3Urls(url) + ok EngineApiUrl.init( - url = confValue.url, + url = url, jwtSecret = jwtSecret, roles = confValue.roles.get(defaultEngineApiRoles)) @@ -163,12 +175,3 @@ proc toFinalEngineApiUrls*(elUrls: seq[EngineApiUrlConfigValue], fatal "Invalid EL configuration", err = error quit 1 result.add engineApiUrl - -proc fixupWeb3Urls*(web3Url: var string) = - var normalizedUrl = toLowerAscii(web3Url) - if not (normalizedUrl.startsWith("https://") or - normalizedUrl.startsWith("http://") or - normalizedUrl.startsWith("wss://") or - normalizedUrl.startsWith("ws://")): - warn "The Web3 URL does not specify a protocol. Assuming a WebSocket server", web3Url - web3Url = "ws://" & web3Url