1use async_trait::async_trait;
20
21use super::{
22 jsonrpc::{JsonResponse, JsonResult},
23 util::*,
24};
25use crate::net;
26
27#[async_trait]
28pub trait HandlerP2p: Sync + Send {
29 async fn p2p_get_info(&self, id: u16, _params: JsonValue) -> JsonResult {
30 let mut channels = Vec::new();
31 for channel in self.p2p().hosts().channels() {
32 let session = match channel.session_type_id() {
33 net::session::SESSION_INBOUND => "inbound",
34 net::session::SESSION_OUTBOUND => "outbound",
35 net::session::SESSION_MANUAL => "manual",
36 net::session::SESSION_REFINE => "refine",
37 net::session::SESSION_SEED => "seed",
38 _ => panic!("invalid result from channel.session_type_id()"),
39 };
40 channels.push(json_map([
41 ("url", JsonStr(channel.address().clone().into())),
42 ("session", json_str(session)),
43 ("id", JsonNum(channel.info.id.into())),
44 ]));
45 }
46
47 let mut slots = Vec::new();
48 for channel_id in self.p2p().session_outbound().slot_info().await {
49 slots.push(JsonNum(channel_id.into()));
50 }
51
52 let result =
53 json_map([("channels", JsonArray(channels)), ("outbound_slots", JsonArray(slots))]);
54 JsonResponse::new(result, id).into()
55 }
56
57 fn p2p(&self) -> net::P2pPtr;
58}