Newer
Older
log "github.com/sirupsen/logrus"
)
const (
BGPVersion = 4
)
type bgpServer struct {
localASN uint32
type BGPServer interface {
RouterID() uint32
Start(*config.Global) error
GetPeerInfoAll() map[string]PeerInfo
}
func NewBgpServer() BGPServer {
return &bgpServer{}
}
func (b *bgpServer) GetPeerInfoAll() map[string]PeerInfo {
res := make(map[string]PeerInfo)
b.peers.Range(func(key, value interface{}) bool {
name := key.(string)
peer := value.(*peer)
res[name] = peer.snapshot()
return true
})
return res
func (b *bgpServer) RouterID() uint32 {
func (b *bgpServer) Start(c *config.Global) error {
if err := c.SetDefaultGlobalConfigValues(); err != nil {
return fmt.Errorf("Failed to load defaults: %v", err)
}
b.localASN = c.LocalASN
if c.Listen {
acceptCh := make(chan *net.TCPConn, 4096)
for _, addr := range c.LocalAddressList {
l, err := NewTCPListener(addr, c.Port, acceptCh)
if err != nil {
return fmt.Errorf("Failed to start TCPListener for %s: %v", addr.String(), err)
}
b.listeners = append(b.listeners, l)
}
b.acceptCh = acceptCh
go b.incomingConnectionWorker()
}
return nil
}
func (b *bgpServer) incomingConnectionWorker() {
peerInterface, ok := b.peers.Load(peerAddr)
if !ok {
c.Close()
log.WithFields(log.Fields{
"source": c.RemoteAddr(),
}).Warning("TCP connection from unknown source")
continue
}
peer := peerInterface.(*peer)
log.WithFields(log.Fields{
"source": c.RemoteAddr(),
}).Info("Incoming TCP connection")
log.WithField("Peer", peerAddr).Debug("Sending incoming TCP connection to fsm for peer")
fsm.state = newActiveState(fsm)
fsm.startConnectRetryTimer()
peer.fsmsMu.Lock()
peer.fsms = append(peer.fsms, fsm)
peer.fsmsMu.Unlock()
func (b *bgpServer) AddPeer(c config.Peer) error {
peer, err := newPeer(c, b)
if err != nil {
return err
}
peer.routerID = c.RouterID
peerAddr := peer.GetAddr().String()
b.peers.Store(peerAddr, peer)
peer.Start()