2018-06-20 20:27:32 +03:00
|
|
|
# Nimbus
|
|
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
|
|
# 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.
|
2018-10-05 03:20:12 +03:00
|
|
|
|
2018-07-26 22:48:01 +01:00
|
|
|
import
|
2021-05-19 16:35:13 +07:00
|
|
|
std/[strutils, tables],
|
2019-02-05 20:15:50 +01:00
|
|
|
nimcrypto, eth/common as eth_common, stint, json_rpc/server,
|
2021-05-19 16:35:13 +07:00
|
|
|
eth/p2p, eth/p2p/enode,
|
|
|
|
../config, ./hexstrings
|
|
|
|
|
|
|
|
type
|
|
|
|
NodePorts = object
|
|
|
|
discovery: string
|
|
|
|
listener : string
|
|
|
|
|
|
|
|
NodeInfo = object
|
|
|
|
id : string # UInt256 hex
|
|
|
|
name : string
|
|
|
|
enode : string # Enode string
|
|
|
|
ip : string # address string
|
|
|
|
ports : NodePorts
|
2018-06-20 20:27:32 +03:00
|
|
|
|
2022-04-08 11:54:11 +07:00
|
|
|
proc setupCommonRpc*(node: EthereumNode, conf: NimbusConf, server: RpcServer) =
|
2018-06-20 20:27:32 +03:00
|
|
|
server.rpc("web3_clientVersion") do() -> string:
|
2021-09-11 21:58:01 +07:00
|
|
|
result = conf.agentString
|
2018-06-20 20:27:32 +03:00
|
|
|
|
2018-08-22 22:40:05 +01:00
|
|
|
server.rpc("web3_sha3") do(data: HexDataStr) -> string:
|
2019-04-24 15:35:29 +02:00
|
|
|
var rawdata = nimcrypto.fromHex(data.string[2 .. ^1])
|
2022-04-08 11:54:11 +07:00
|
|
|
result = "0x" & $keccak256.digest(rawdata)
|
2020-07-22 23:51:26 +07:00
|
|
|
|
|
|
|
server.rpc("net_version") do() -> string:
|
2021-09-16 22:59:46 +07:00
|
|
|
result = $conf.networkId
|
2020-07-22 23:51:26 +07:00
|
|
|
|
|
|
|
server.rpc("net_listening") do() -> bool:
|
|
|
|
let numPeers = node.peerPool.connectedNodes.len
|
2021-09-11 21:58:01 +07:00
|
|
|
result = numPeers < conf.maxPeers
|
2020-07-22 23:51:26 +07:00
|
|
|
|
|
|
|
server.rpc("net_peerCount") do() -> HexQuantityStr:
|
|
|
|
let peerCount = uint node.peerPool.connectedNodes.len
|
|
|
|
result = encodeQuantity(peerCount)
|
2021-05-19 16:35:13 +07:00
|
|
|
|
|
|
|
server.rpc("net_nodeInfo") do() -> NodeInfo:
|
2022-04-08 11:54:11 +07:00
|
|
|
let enode = toENode(node)
|
2021-09-16 22:59:46 +07:00
|
|
|
let nodeId = toNodeId(node.keys.pubkey)
|
2021-05-19 16:35:13 +07:00
|
|
|
result = NodeInfo(
|
2021-09-16 22:59:46 +07:00
|
|
|
id: nodeId.toHex,
|
2021-09-11 21:58:01 +07:00
|
|
|
name: conf.agentString,
|
2021-05-19 16:35:13 +07:00
|
|
|
enode: $enode,
|
|
|
|
ip: $enode.address.ip,
|
|
|
|
ports: NodePorts(
|
|
|
|
discovery: $enode.address.udpPort,
|
|
|
|
listener: $enode.address.tcpPort
|
|
|
|
)
|
|
|
|
)
|