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 net::session::SESSION_DIRECT => "direct",
39 _ => panic!("invalid result from channel.session_type_id()"),
40 };
41
42 channels.push(json_map([
44 ("url", JsonStr(channel.display_address().to_string())),
45 ("session", json_str(session)),
46 ("id", JsonNum(channel.info.id.into())),
47 ]));
48 }
49
50 let mut slots = Vec::new();
51 for channel_id in self.p2p().session_outbound().slot_info().await {
52 slots.push(JsonNum(channel_id.into()));
53 }
54
55 let result =
56 json_map([("channels", JsonArray(channels)), ("outbound_slots", JsonArray(slots))]);
57 JsonResponse::new(result, id).into()
58 }
59
60 fn p2p(&self) -> net::P2pPtr;
61}