feat: implement /s5/p2p/nodes
This commit is contained in:
parent
e034e1096f
commit
3009e1dce3
|
@ -13,6 +13,15 @@ import (
|
||||||
|
|
||||||
var _ interfaces.HTTPService = (*HTTPImpl)(nil)
|
var _ interfaces.HTTPService = (*HTTPImpl)(nil)
|
||||||
|
|
||||||
|
type P2PNodesResponse struct {
|
||||||
|
Nodes []P2PNodeResponse `json:"nodes"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type P2PNodeResponse struct {
|
||||||
|
Id string `json:"id"`
|
||||||
|
Uris []string `json:"uris"`
|
||||||
|
}
|
||||||
|
|
||||||
type HTTPImpl struct {
|
type HTTPImpl struct {
|
||||||
node interfaces.Node
|
node interfaces.Node
|
||||||
}
|
}
|
||||||
|
@ -27,6 +36,7 @@ func (h *HTTPImpl) GetHttpRouter(inject map[string]jape.Handler) *httprouter.Rou
|
||||||
routes := map[string]jape.Handler{
|
routes := map[string]jape.Handler{
|
||||||
"GET /s5/version": h.versionHandler,
|
"GET /s5/version": h.versionHandler,
|
||||||
"GET /s5/p2p": h.p2pHandler,
|
"GET /s5/p2p": h.p2pHandler,
|
||||||
|
"Get /s5/p2p/nodes": h.p2pNodesHandler,
|
||||||
}
|
}
|
||||||
|
|
||||||
for k, v := range inject {
|
for k, v := range inject {
|
||||||
|
@ -86,3 +96,26 @@ func (h *HTTPImpl) p2pHandler(ctx jape.Context) {
|
||||||
h.node.ConnectionTracker().Done()
|
h.node.ConnectionTracker().Done()
|
||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (h *HTTPImpl) p2pNodesHandler(ctx jape.Context) {
|
||||||
|
localId, err := h.node.Services().P2P().NodeId().ToString()
|
||||||
|
|
||||||
|
if ctx.Check("error getting local node id", err) != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
uris := h.node.Services().P2P().SelfConnectionUris()
|
||||||
|
|
||||||
|
nodeList := make([]P2PNodeResponse, len(uris))
|
||||||
|
|
||||||
|
for i, uri := range uris {
|
||||||
|
nodeList[i] = P2PNodeResponse{
|
||||||
|
Id: localId,
|
||||||
|
Uris: []string{uri.String()},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Encode(P2PNodesResponse{
|
||||||
|
Nodes: nodeList,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue