summaryrefslogtreecommitdiffhomepage
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/peer.go21
-rw-r--r--server/server.go2
2 files changed, 22 insertions, 1 deletions
diff --git a/server/peer.go b/server/peer.go
index 3b03046b..73aab7e6 100644
--- a/server/peer.go
+++ b/server/peer.go
@@ -189,6 +189,27 @@ func (peer *Peer) handleREST(restReq *api.RestRequest) {
case api.REQ_NEIGHBOR_SOFT_RESET_OUT:
pathList := peer.adjRib.GetOutPathList(peer.rf)
peer.sendMessages(table.CreateUpdateMsgFromPaths(pathList))
+ case api.REQ_ADJ_RIB_IN:
+ fallthrough
+ case api.REQ_ADJ_RIB_OUT:
+ rfs := []bgp.RouteFamily{bgp.RF_IPv4_UC, bgp.RF_IPv6_UC}
+ adjrib := make(map[string][]table.Path)
+
+ if restReq.RequestType == api.REQ_ADJ_RIB_IN {
+ for _, rf := range rfs {
+ paths := peer.adjRib.GetInPathList(rf)
+ adjrib[rf.String()] = paths
+ log.Debugf("RouteFamily=%v adj-rib-in found : %d", rf.String(), len(paths))
+ }
+ } else {
+ for _, rf := range rfs {
+ paths := peer.adjRib.GetOutPathList(rf)
+ adjrib[rf.String()] = paths
+ log.Debugf("RouteFamily=%v adj-rib-out found : %d", rf.String(), len(paths))
+ }
+ }
+ j, _ := json.Marshal(adjrib)
+ result.Data = j
}
restReq.ResponseCh <- result
close(restReq.ResponseCh)
diff --git a/server/server.go b/server/server.go
index cbd67732..14a1ac5f 100644
--- a/server/server.go
+++ b/server/server.go
@@ -241,7 +241,7 @@ func (server *BgpServer) handleRest(restReq *api.RestRequest) {
}
restReq.ResponseCh <- result
close(restReq.ResponseCh)
- case api.REQ_LOCAL_RIB, api.REQ_NEIGHBOR_SHUTDOWN, api.REQ_NEIGHBOR_RESET, api.REQ_NEIGHBOR_SOFT_RESET_IN, api.REQ_NEIGHBOR_SOFT_RESET_OUT:
+ case api.REQ_LOCAL_RIB, api.REQ_NEIGHBOR_SHUTDOWN, api.REQ_NEIGHBOR_RESET, api.REQ_NEIGHBOR_SOFT_RESET_IN, api.REQ_NEIGHBOR_SOFT_RESET_OUT, api.REQ_ADJ_RIB_IN, api.REQ_ADJ_RIB_OUT:
remoteAddr := restReq.RemoteAddr
result := &api.RestResponse{}
info, found := server.peerMap[remoteAddr]