{.push raises: [Exception, Defect].} import std/[options,sequtils], json_rpc/rpcserver, libp2p/[peerinfo, switch], ../../waku_types, ../../protocol/waku_store/[waku_store_types, waku_store], ../../protocol/waku_swap/[waku_swap_types, waku_swap], ../../protocol/waku_filter, ../wakunode2, ./jsonrpc_types proc constructMultiaddrStr*(peerInfo: PeerInfo): string = # Constructs a multiaddress with both location address and p2p identity $peerInfo.addrs[0] & "/p2p/" & $peerInfo.peerId proc installAdminApiHandlers*(node: WakuNode, rpcsrv: RpcServer) = ## Admin API version 1 definitions rpcsrv.rpc("get_waku_v2_admin_v1_peers") do() -> seq[WakuPeer]: ## Returns history for a list of content topics with optional paging debug "get_waku_v2_admin_v1_peers" # Create a single list of peers from mounted protocols. # @TODO since the switch does not expose its connections, retrieving the connected peers requires a peer store/peer management var wPeers: seq[WakuPeer] = @[] if not node.wakuSwap.isNil: # Map WakuSwap peers to WakuPeers and add to return list wPeers.insert(node.wakuSwap.peers.mapIt(WakuPeer(multiaddr: constructMultiaddrStr(it.peerInfo), protocol: WakuSwapCodec, connected: node.switch.isConnected(it.peerInfo))), wPeers.len) # Append to the end of the sequence if not node.wakuFilter.isNil: # Map WakuFilter peers to WakuPeers and add to return list wPeers.insert(node.wakuFilter.peers.mapIt(WakuPeer(multiaddr: constructMultiaddrStr(it.peerInfo), protocol: WakuFilterCodec, connected: node.switch.isConnected(it.peerInfo))), wPeers.len) # Append to the end of the sequence if not node.wakuStore.isNil: # Map WakuStore peers to WakuPeers and add to return list wPeers.insert(node.wakuStore.peers.mapIt(WakuPeer(multiaddr: constructMultiaddrStr(it.peerInfo), protocol: WakuStoreCodec, connected: node.switch.isConnected(it.peerInfo))), wPeers.len) # Append to the end of the sequence # @TODO filter output on protocol/connected-status return wPeers