nimbus-eth1/nimbus/rpc/common.nim

67 lines
2.0 KiB
Nim
Raw Normal View History

2018-06-20 17:27:32 +00: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.
import
std/[strutils, tables],
2022-06-07 10:20:02 +00:00
nimcrypto, eth/common as eth_common, stint, json_rpc/server, json_rpc/errors,
eth/p2p, eth/p2p/enode, eth/p2p/peer_pool,
../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 17:27:32 +00:00
2022-04-08 04:54:11 +00:00
proc setupCommonRpc*(node: EthereumNode, conf: NimbusConf, server: RpcServer) =
2018-06-20 17:27:32 +00:00
server.rpc("web3_clientVersion") do() -> string:
result = conf.agentString
2018-06-20 17:27:32 +00:00
server.rpc("web3_sha3") do(data: HexDataStr) -> string:
2019-04-24 13:35:29 +00:00
var rawdata = nimcrypto.fromHex(data.string[2 .. ^1])
2022-04-08 04:54:11 +00:00
result = "0x" & $keccak256.digest(rawdata)
server.rpc("net_version") do() -> string:
result = $conf.networkId
server.rpc("net_listening") do() -> bool:
let numPeers = node.peerPool.connectedNodes.len
result = numPeers < conf.maxPeers
server.rpc("net_peerCount") do() -> HexQuantityStr:
let peerCount = uint node.peerPool.connectedNodes.len
result = encodeQuantity(peerCount)
server.rpc("net_nodeInfo") do() -> NodeInfo:
2022-04-08 04:54:11 +00:00
let enode = toENode(node)
let nodeId = toNodeId(node.keys.pubkey)
result = NodeInfo(
id: nodeId.toHex,
name: conf.agentString,
enode: $enode,
ip: $enode.address.ip,
ports: NodePorts(
discovery: $enode.address.udpPort,
listener: $enode.address.tcpPort
)
)
2022-06-07 10:20:02 +00:00
server.rpc("nimbus_addPeer") do(enode: string) -> bool:
var res = ENode.fromString(enode)
if res.isOk:
asyncSpawn node.peerPool.connectToNode(newNode(res.get()))
2022-06-07 10:20:02 +00:00
return true
raise (ref InvalidRequest)(code: -32602, msg: "Invalid ENode")