diff options
Diffstat (limited to 'pkg/server')
-rw-r--r-- | pkg/server/grpc_server.go | 12 | ||||
-rw-r--r-- | pkg/server/server.go | 25 |
2 files changed, 37 insertions, 0 deletions
diff --git a/pkg/server/grpc_server.go b/pkg/server/grpc_server.go index 2d25734a..1ae58055 100644 --- a/pkg/server/grpc_server.go +++ b/pkg/server/grpc_server.go @@ -102,6 +102,18 @@ func (s *server) serve() error { return nil } +func (s *server) ListPeerGroup(r *api.ListPeerGroupRequest, stream api.GobgpApi_ListPeerGroupServer) error { + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + fn := func(pg *api.PeerGroup) { + if err := stream.Send(&api.ListPeerGroupResponse{PeerGroup: pg}); err != nil { + cancel() + return + } + } + return s.bgpServer.ListPeerGroup(ctx, r, fn) +} + func parseHost(host string) (string, string) { const unixScheme = "unix://" if strings.HasPrefix(host, unixScheme) { diff --git a/pkg/server/server.go b/pkg/server/server.go index c5b2b0ff..25fd31cc 100644 --- a/pkg/server/server.go +++ b/pkg/server/server.go @@ -2715,6 +2715,31 @@ func (s *BgpServer) GetBgp(ctx context.Context, r *api.GetBgpRequest) (*api.GetB return rsp, nil } +func (s *BgpServer) ListPeerGroup(ctx context.Context, r *api.ListPeerGroupRequest, fn func(*api.PeerGroup)) error { + var l []*api.PeerGroup + s.mgmtOperation(func() error { + peerGroupName := r.PeerGroupName + l = make([]*api.PeerGroup, 0, len(s.peerGroupMap)) + for k, group := range s.peerGroupMap { + if peerGroupName != "" && peerGroupName != k { + continue + } + pg := config.NewPeerGroupFromConfigStruct(group.Conf) + l = append(l, pg) + } + return nil + }, false) + for _, pg := range l { + select { + case <-ctx.Done(): + return nil + default: + fn(pg) + } + } + return nil +} + func (s *BgpServer) ListPeer(ctx context.Context, r *api.ListPeerRequest, fn func(*api.Peer)) error { var l []*api.Peer s.mgmtOperation(func() error { |