(ps peerState, logger *slog.Logger)
| 72 | } |
| 73 | |
| 74 | func NewBfdServer(ps peerState, logger *slog.Logger) *bfdServer { |
| 75 | s := &bfdServer{ |
| 76 | peerState: ps, |
| 77 | logger: logger, |
| 78 | |
| 79 | peers: make(map[netip.Addr]*bfdPeer), |
| 80 | |
| 81 | eventStartStop: time.NewTicker(time.Second), |
| 82 | eventConfig: make(chan *oc.BfdConfig, 1), |
| 83 | eventPeerUpdate: make(chan *bfdEventPeerUpdate, 1), |
| 84 | eventShutdown: make(chan struct{}), |
| 85 | } |
| 86 | |
| 87 | s.shutdownWait.Add(1) |
| 88 | go s.loop() |
| 89 | return s |
| 90 | } |
| 91 | |
| 92 | func (s *bfdServer) Start(ctx context.Context, config oc.BfdConfig) error { |
| 93 | if s.stopped.Load() { |
searching dependent graphs…