2021-10-06 01:31:35 +02:00
|
|
|
# Nimbus
|
2024-02-21 16:14:20 +07:00
|
|
|
# Copyright (c) 2021-2024 Status Research & Development GmbH
|
2021-10-06 01:31:35 +02:00
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
|
|
|
# at your option.
|
|
|
|
# This file may not be copied, modified, or distributed except according to
|
|
|
|
# those terms.
|
|
|
|
|
|
|
|
import
|
2023-08-27 08:23:45 +07:00
|
|
|
std/[typetraits, sequtils, sets],
|
2023-01-31 01:32:17 +00:00
|
|
|
json_rpc/rpcserver,
|
2023-12-08 16:35:50 +07:00
|
|
|
web3/[conversions, execution_types],
|
2023-08-27 08:23:45 +07:00
|
|
|
../beacon/api_handler,
|
|
|
|
../beacon/beacon_engine,
|
2024-05-29 14:20:50 +07:00
|
|
|
../version
|
2021-10-06 01:31:35 +02:00
|
|
|
|
2024-10-16 07:04:12 +05:30
|
|
|
from ../beacon/web3_eth_conv import Hash32
|
|
|
|
|
2023-01-31 01:32:17 +00:00
|
|
|
{.push raises: [].}
|
|
|
|
|
2023-03-09 18:40:55 -05:00
|
|
|
const supportedMethods: HashSet[string] =
|
|
|
|
toHashSet([
|
|
|
|
"engine_newPayloadV1",
|
|
|
|
"engine_newPayloadV2",
|
2023-08-08 10:44:29 +07:00
|
|
|
"engine_newPayloadV3",
|
2024-03-28 18:59:23 +07:00
|
|
|
"engine_newPayloadV4",
|
2023-03-09 18:40:55 -05:00
|
|
|
"engine_getPayloadV1",
|
|
|
|
"engine_getPayloadV2",
|
2023-08-08 10:44:29 +07:00
|
|
|
"engine_getPayloadV3",
|
2024-03-28 18:59:23 +07:00
|
|
|
"engine_getPayloadV4",
|
2023-03-09 18:40:55 -05:00
|
|
|
"engine_exchangeTransitionConfigurationV1",
|
|
|
|
"engine_forkchoiceUpdatedV1",
|
|
|
|
"engine_forkchoiceUpdatedV2",
|
2023-08-08 14:29:23 +07:00
|
|
|
"engine_forkchoiceUpdatedV3",
|
2023-08-17 07:27:34 +07:00
|
|
|
"engine_getPayloadBodiesByHashV1",
|
|
|
|
"engine_getPayloadBodiesByRangeV1",
|
2024-05-29 14:20:50 +07:00
|
|
|
"engine_getClientVersionV1",
|
2023-03-09 18:40:55 -05:00
|
|
|
])
|
|
|
|
|
|
|
|
# I'm trying to keep the handlers below very thin, and move the
|
|
|
|
# bodies up to the various procs above. Once we have multiple
|
|
|
|
# versions, they'll need to be able to share code.
|
2023-08-27 08:23:45 +07:00
|
|
|
proc setupEngineAPI*(engine: BeaconEngineRef, server: RpcServer) =
|
2021-10-06 01:31:35 +02:00
|
|
|
|
2023-03-09 18:40:55 -05:00
|
|
|
server.rpc("engine_exchangeCapabilities") do(methods: seq[string]) -> seq[string]:
|
|
|
|
return methods.filterIt(supportedMethods.contains(it))
|
2022-12-10 08:32:55 +07:00
|
|
|
|
2023-03-09 18:40:55 -05:00
|
|
|
server.rpc("engine_newPayloadV1") do(payload: ExecutionPayloadV1) -> PayloadStatusV1:
|
2023-10-23 09:25:03 +07:00
|
|
|
return engine.newPayload(Version.V1, payload.executionPayload)
|
2023-05-16 14:52:44 +01:00
|
|
|
|
2023-08-08 14:29:23 +07:00
|
|
|
server.rpc("engine_newPayloadV2") do(payload: ExecutionPayload) -> PayloadStatusV1:
|
2023-10-23 09:25:03 +07:00
|
|
|
return engine.newPayload(Version.V2, payload)
|
2023-08-08 14:29:23 +07:00
|
|
|
|
|
|
|
server.rpc("engine_newPayloadV3") do(payload: ExecutionPayload,
|
2024-10-16 07:04:12 +05:30
|
|
|
expectedBlobVersionedHashes: Opt[seq[Hash32]],
|
|
|
|
parentBeaconBlockRoot: Opt[Hash32]) -> PayloadStatusV1:
|
2024-04-20 02:43:13 +07:00
|
|
|
return engine.newPayload(Version.V3, payload, expectedBlobVersionedHashes, parentBeaconBlockRoot)
|
2022-12-10 08:32:55 +07:00
|
|
|
|
2024-03-28 18:59:23 +07:00
|
|
|
server.rpc("engine_newPayloadV4") do(payload: ExecutionPayload,
|
2024-10-16 07:04:12 +05:30
|
|
|
expectedBlobVersionedHashes: Opt[seq[Hash32]],
|
2024-10-18 16:38:18 +07:00
|
|
|
parentBeaconBlockRoot: Opt[Hash32],
|
|
|
|
executionRequests: Opt[array[3, seq[byte]]]) -> PayloadStatusV1:
|
|
|
|
return engine.newPayload(Version.V4, payload,
|
|
|
|
expectedBlobVersionedHashes, parentBeaconBlockRoot, executionRequests)
|
2024-03-28 18:59:23 +07:00
|
|
|
|
2024-10-16 07:04:12 +05:30
|
|
|
server.rpc("engine_getPayloadV1") do(payloadId: Bytes8) -> ExecutionPayloadV1:
|
2023-10-23 20:59:57 +07:00
|
|
|
return engine.getPayload(Version.V1, payloadId).executionPayload.V1
|
2021-10-06 01:31:35 +02:00
|
|
|
|
2024-10-16 07:04:12 +05:30
|
|
|
server.rpc("engine_getPayloadV2") do(payloadId: Bytes8) -> GetPayloadV2Response:
|
2023-10-23 20:59:57 +07:00
|
|
|
return engine.getPayload(Version.V2, payloadId)
|
2021-10-06 01:31:35 +02:00
|
|
|
|
2024-10-16 07:04:12 +05:30
|
|
|
server.rpc("engine_getPayloadV3") do(payloadId: Bytes8) -> GetPayloadV3Response:
|
2023-08-27 08:23:45 +07:00
|
|
|
return engine.getPayloadV3(payloadId)
|
2023-08-08 14:29:23 +07:00
|
|
|
|
2024-10-16 07:04:12 +05:30
|
|
|
server.rpc("engine_getPayloadV4") do(payloadId: Bytes8) -> GetPayloadV4Response:
|
2024-03-28 18:59:23 +07:00
|
|
|
return engine.getPayloadV4(payloadId)
|
|
|
|
|
2023-08-27 08:23:45 +07:00
|
|
|
server.rpc("engine_exchangeTransitionConfigurationV1") do(
|
|
|
|
conf: TransitionConfigurationV1) -> TransitionConfigurationV1:
|
|
|
|
return engine.exchangeConf(conf)
|
2021-10-06 01:31:35 +02:00
|
|
|
|
2023-08-27 08:23:45 +07:00
|
|
|
server.rpc("engine_forkchoiceUpdatedV1") do(update: ForkchoiceStateV1,
|
2024-06-14 14:31:08 +07:00
|
|
|
attrs: Opt[PayloadAttributesV1]) -> ForkchoiceUpdatedResponse:
|
2023-10-23 09:25:03 +07:00
|
|
|
return engine.forkchoiceUpdated(Version.V1, update, attrs.payloadAttributes)
|
2022-02-22 15:55:04 +07:00
|
|
|
|
2023-08-27 08:23:45 +07:00
|
|
|
server.rpc("engine_forkchoiceUpdatedV2") do(update: ForkchoiceStateV1,
|
2024-06-14 14:31:08 +07:00
|
|
|
attrs: Opt[PayloadAttributes]) -> ForkchoiceUpdatedResponse:
|
2023-10-23 09:25:03 +07:00
|
|
|
return engine.forkchoiceUpdated(Version.V2, update, attrs)
|
2023-08-08 14:29:23 +07:00
|
|
|
|
2023-08-27 08:23:45 +07:00
|
|
|
server.rpc("engine_forkchoiceUpdatedV3") do(update: ForkchoiceStateV1,
|
2024-06-14 14:31:08 +07:00
|
|
|
attrs: Opt[PayloadAttributes]) -> ForkchoiceUpdatedResponse:
|
2023-10-23 09:25:03 +07:00
|
|
|
return engine.forkchoiceUpdated(Version.V3, update, attrs)
|
2023-03-09 18:40:55 -05:00
|
|
|
|
2024-10-16 07:04:12 +05:30
|
|
|
server.rpc("engine_getPayloadBodiesByHashV1") do(hashes: seq[Hash32]) ->
|
2024-06-14 14:31:08 +07:00
|
|
|
seq[Opt[ExecutionPayloadBodyV1]]:
|
2023-08-27 08:23:45 +07:00
|
|
|
return engine.getPayloadBodiesByHash(hashes)
|
2022-02-22 15:55:04 +07:00
|
|
|
|
2023-08-17 07:27:34 +07:00
|
|
|
server.rpc("engine_getPayloadBodiesByRangeV1") do(
|
2024-06-14 14:31:08 +07:00
|
|
|
start: Quantity, count: Quantity) -> seq[Opt[ExecutionPayloadBodyV1]]:
|
2023-08-27 08:23:45 +07:00
|
|
|
return engine.getPayloadBodiesByRange(start.uint64, count.uint64)
|
2024-05-29 14:20:50 +07:00
|
|
|
|
|
|
|
server.rpc("engine_getClientVersionV1") do(version: ClientVersionV1) ->
|
|
|
|
seq[ClientVersionV1]:
|
|
|
|
# TODO: what should we do with the `version` parameter?
|
|
|
|
return @[ClientVersionV1(
|
|
|
|
code: "NB",
|
|
|
|
name: NimbusName,
|
|
|
|
version: NimbusVersion,
|
|
|
|
commit: FixedBytes[4](GitRevisionBytes),
|
|
|
|
)]
|