2024-06-28 16:04:57 +05:30
|
|
|
{.push raises: [].}
|
2023-10-05 14:00:09 +02:00
|
|
|
|
|
|
|
import
|
2024-04-25 09:09:52 -04:00
|
|
|
std/[strformat, sequtils, tables],
|
2023-10-05 14:00:09 +02:00
|
|
|
chronicles,
|
|
|
|
json_serialization,
|
|
|
|
presto/route,
|
|
|
|
libp2p/[peerinfo, switch]
|
|
|
|
|
|
|
|
import
|
|
|
|
../../../waku_core,
|
2024-04-25 09:09:52 -04:00
|
|
|
../../../waku_store_legacy/common,
|
2024-05-09 20:07:49 +02:00
|
|
|
../../../waku_store/common,
|
2023-11-22 10:56:23 +02:00
|
|
|
../../../waku_filter_v2,
|
2024-01-30 07:28:21 -05:00
|
|
|
../../../waku_lightpush/common,
|
2023-10-05 14:00:09 +02:00
|
|
|
../../../waku_relay,
|
2024-07-23 12:58:56 +02:00
|
|
|
../../../waku_peer_exchange,
|
2023-10-05 14:00:09 +02:00
|
|
|
../../../waku_node,
|
|
|
|
../../../node/peer_manager,
|
|
|
|
../responses,
|
|
|
|
../serdes,
|
2023-11-14 16:59:53 +01:00
|
|
|
../rest_serdes,
|
2023-10-05 14:00:09 +02:00
|
|
|
./types
|
|
|
|
|
|
|
|
export types
|
|
|
|
|
|
|
|
logScope:
|
|
|
|
topics = "waku node rest admin api"
|
|
|
|
|
|
|
|
const ROUTE_ADMIN_V1_PEERS* = "/admin/v1/peers"
|
2024-01-09 11:42:29 +01:00
|
|
|
const ROUTE_ADMIN_V1_FILTER_SUBS* = "/admin/v1/filter/subscriptions"
|
2023-10-05 14:00:09 +02:00
|
|
|
|
2024-06-26 17:59:12 +02:00
|
|
|
type PeerProtocolTuple =
|
|
|
|
tuple[multiaddr: string, protocol: string, connected: bool, origin: PeerOrigin]
|
2023-10-05 14:00:09 +02:00
|
|
|
|
|
|
|
proc tuplesToWakuPeers(peers: var WakuPeers, peersTup: seq[PeerProtocolTuple]) =
|
|
|
|
for peer in peersTup:
|
2024-06-26 17:59:12 +02:00
|
|
|
peers.add(peer.multiaddr, peer.protocol, peer.connected, peer.origin)
|
2023-10-05 14:00:09 +02:00
|
|
|
|
|
|
|
proc installAdminV1GetPeersHandler(router: var RestRouter, node: WakuNode) =
|
2024-03-16 00:08:47 +01:00
|
|
|
router.api(MethodGet, ROUTE_ADMIN_V1_PEERS) do() -> RestApiResponse:
|
|
|
|
var peers: WakuPeers = @[]
|
2023-10-05 14:00:09 +02:00
|
|
|
|
2024-09-27 18:16:46 +05:30
|
|
|
let relayPeers = node.peerManager.wakuPeerStore.peers(WakuRelayCodec).mapIt(
|
2024-07-23 12:58:56 +02:00
|
|
|
(
|
|
|
|
multiaddr: constructMultiaddrStr(it),
|
|
|
|
protocol: WakuRelayCodec,
|
|
|
|
connected: it.connectedness == Connectedness.Connected,
|
|
|
|
origin: it.origin,
|
2024-03-16 00:08:47 +01:00
|
|
|
)
|
2024-07-23 12:58:56 +02:00
|
|
|
)
|
|
|
|
tuplesToWakuPeers(peers, relayPeers)
|
|
|
|
|
2024-09-27 18:16:46 +05:30
|
|
|
let filterV2Peers = node.peerManager.wakuPeerStore
|
|
|
|
.peers(WakuFilterSubscribeCodec)
|
|
|
|
.mapIt(
|
2024-07-23 12:58:56 +02:00
|
|
|
(
|
|
|
|
multiaddr: constructMultiaddrStr(it),
|
|
|
|
protocol: WakuFilterSubscribeCodec,
|
|
|
|
connected: it.connectedness == Connectedness.Connected,
|
|
|
|
origin: it.origin,
|
2024-03-16 00:08:47 +01:00
|
|
|
)
|
2024-07-23 12:58:56 +02:00
|
|
|
)
|
|
|
|
tuplesToWakuPeers(peers, filterV2Peers)
|
|
|
|
|
2024-09-27 18:16:46 +05:30
|
|
|
let storePeers = node.peerManager.wakuPeerStore.peers(WakuStoreCodec).mapIt(
|
2024-07-23 12:58:56 +02:00
|
|
|
(
|
|
|
|
multiaddr: constructMultiaddrStr(it),
|
|
|
|
protocol: WakuStoreCodec,
|
|
|
|
connected: it.connectedness == Connectedness.Connected,
|
|
|
|
origin: it.origin,
|
2024-03-16 00:08:47 +01:00
|
|
|
)
|
2024-07-23 12:58:56 +02:00
|
|
|
)
|
|
|
|
tuplesToWakuPeers(peers, storePeers)
|
|
|
|
|
2024-09-27 18:16:46 +05:30
|
|
|
let legacyStorePeers = node.peerManager.wakuPeerStore
|
|
|
|
.peers(WakuLegacyStoreCodec)
|
|
|
|
.mapIt(
|
2024-07-23 12:58:56 +02:00
|
|
|
(
|
|
|
|
multiaddr: constructMultiaddrStr(it),
|
|
|
|
protocol: WakuLegacyStoreCodec,
|
|
|
|
connected: it.connectedness == Connectedness.Connected,
|
|
|
|
origin: it.origin,
|
2024-05-09 20:07:49 +02:00
|
|
|
)
|
2024-07-23 12:58:56 +02:00
|
|
|
)
|
|
|
|
tuplesToWakuPeers(peers, legacyStorePeers)
|
|
|
|
|
2024-09-27 18:16:46 +05:30
|
|
|
let lightpushPeers = node.peerManager.wakuPeerStore.peers(WakuLightPushCodec).mapIt(
|
2024-07-23 12:58:56 +02:00
|
|
|
(
|
|
|
|
multiaddr: constructMultiaddrStr(it),
|
|
|
|
protocol: WakuLightPushCodec,
|
|
|
|
connected: it.connectedness == Connectedness.Connected,
|
|
|
|
origin: it.origin,
|
2024-03-16 00:08:47 +01:00
|
|
|
)
|
2024-07-23 12:58:56 +02:00
|
|
|
)
|
|
|
|
tuplesToWakuPeers(peers, lightpushPeers)
|
|
|
|
|
2024-09-27 18:16:46 +05:30
|
|
|
let pxPeers = node.peerManager.wakuPeerStore.peers(WakuPeerExchangeCodec).mapIt(
|
2024-07-23 12:58:56 +02:00
|
|
|
(
|
|
|
|
multiaddr: constructMultiaddrStr(it),
|
|
|
|
protocol: WakuPeerExchangeCodec,
|
|
|
|
connected: it.connectedness == Connectedness.Connected,
|
|
|
|
origin: it.origin,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
tuplesToWakuPeers(peers, pxPeers)
|
2023-11-22 10:56:23 +02:00
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
let resp = RestApiResponse.jsonResponse(peers, status = Http200)
|
2023-10-05 14:00:09 +02:00
|
|
|
if resp.isErr():
|
2024-03-16 00:08:47 +01:00
|
|
|
error "An error ocurred while building the json respose: ", error = resp.error
|
|
|
|
return RestApiResponse.internalServerError(
|
|
|
|
fmt("An error ocurred while building the json respose: {resp.error}")
|
|
|
|
)
|
2023-10-05 14:00:09 +02:00
|
|
|
|
|
|
|
return resp.get()
|
|
|
|
|
|
|
|
proc installAdminV1PostPeersHandler(router: var RestRouter, node: WakuNode) =
|
2024-03-16 00:08:47 +01:00
|
|
|
router.api(MethodPost, ROUTE_ADMIN_V1_PEERS) do(
|
|
|
|
contentBody: Option[ContentBody]
|
|
|
|
) -> RestApiResponse:
|
2023-10-05 14:00:09 +02:00
|
|
|
let peers: seq[string] = decodeRequestBody[seq[string]](contentBody).valueOr:
|
2024-09-09 10:45:14 +02:00
|
|
|
let e = $error
|
|
|
|
return RestApiResponse.badRequest(fmt("Failed to decode request: {e}"))
|
2023-10-05 14:00:09 +02:00
|
|
|
|
|
|
|
for i, peer in peers:
|
|
|
|
let peerInfo = parsePeerInfo(peer).valueOr:
|
2024-09-09 10:45:14 +02:00
|
|
|
let e = $error
|
|
|
|
return RestApiResponse.badRequest(fmt("Couldn't parse remote peer info: {e}"))
|
2023-10-05 14:00:09 +02:00
|
|
|
|
2024-10-29 18:37:07 +02:00
|
|
|
if not (await node.peerManager.connectPeer(peerInfo, source = "rest")):
|
2024-03-16 00:08:47 +01:00
|
|
|
return RestApiResponse.badRequest(
|
|
|
|
fmt("Failed to connect to peer at index: {i} - {peer}")
|
|
|
|
)
|
2023-10-05 14:00:09 +02:00
|
|
|
|
|
|
|
return RestApiResponse.ok()
|
|
|
|
|
2024-01-09 11:42:29 +01:00
|
|
|
proc installAdminV1GetFilterSubsHandler(router: var RestRouter, node: WakuNode) =
|
2024-03-16 00:08:47 +01:00
|
|
|
router.api(MethodGet, ROUTE_ADMIN_V1_FILTER_SUBS) do() -> RestApiResponse:
|
2024-01-09 11:42:29 +01:00
|
|
|
if node.wakuFilter.isNil():
|
2024-03-16 00:08:47 +01:00
|
|
|
return
|
|
|
|
RestApiResponse.badRequest("Error: Filter Protocol is not mounted to the node")
|
2024-01-09 11:42:29 +01:00
|
|
|
|
|
|
|
var
|
|
|
|
subscriptions: seq[FilterSubscription] = @[]
|
|
|
|
filterCriteria: seq[FilterTopic]
|
|
|
|
|
2024-01-16 17:27:40 +01:00
|
|
|
for peerId in node.wakuFilter.subscriptions.peersSubscribed.keys:
|
2024-03-16 00:08:47 +01:00
|
|
|
filterCriteria = node.wakuFilter.subscriptions.getPeerSubscriptions(peerId).mapIt(
|
|
|
|
FilterTopic(pubsubTopic: it[0], contentTopic: it[1])
|
|
|
|
)
|
2024-01-09 11:42:29 +01:00
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
subscriptions.add(
|
|
|
|
FilterSubscription(peerId: $peerId, filterCriteria: filterCriteria)
|
|
|
|
)
|
2024-01-09 11:42:29 +01:00
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
let resp = RestApiResponse.jsonResponse(subscriptions, status = Http200)
|
2024-01-09 11:42:29 +01:00
|
|
|
if resp.isErr():
|
2024-03-16 00:08:47 +01:00
|
|
|
error "An error ocurred while building the json respose: ", error = resp.error
|
|
|
|
return RestApiResponse.internalServerError(
|
|
|
|
fmt("An error ocurred while building the json respose: {resp.error}")
|
|
|
|
)
|
2024-01-09 11:42:29 +01:00
|
|
|
|
|
|
|
return resp.get()
|
|
|
|
|
2023-10-05 14:00:09 +02:00
|
|
|
proc installAdminApiHandlers*(router: var RestRouter, node: WakuNode) =
|
|
|
|
installAdminV1GetPeersHandler(router, node)
|
|
|
|
installAdminV1PostPeersHandler(router, node)
|
2024-01-09 11:42:29 +01:00
|
|
|
installAdminV1GetFilterSubsHandler(router, node)
|