summaryrefslogtreecommitdiffhomepage
path: root/server
diff options
context:
space:
mode:
authorFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>2016-02-21 06:01:34 -0800
committerFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>2016-02-21 06:46:05 -0800
commit61bf5455d8edbbf700bd6303599cc686a2676663 (patch)
tree4c0f962c1afc3849b323dc700aa804dda22a8cf0 /server
parentbbed1307daa2cda8434ac5f91ae68f41fb59461e (diff)
rpki: delete all the ROAs from the server when receiving EOD from it
Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Diffstat (limited to 'server')
-rw-r--r--server/rpki.go34
1 files changed, 26 insertions, 8 deletions
diff --git a/server/rpki.go b/server/rpki.go
index 4f073d5e..afead13a 100644
--- a/server/rpki.go
+++ b/server/rpki.go
@@ -229,6 +229,8 @@ func (m *roaManager) handleROAEvent(ev *roaClientEvent) {
log.Info("roa server is disconnected, ", ev.src)
client.state.Downtime = time.Now().Unix()
// clear state
+ client.endOfData = false
+ client.pendingROAs = make([]*ROA, 0)
client.state.RpkiMessages = config.RpkiMessages{}
client.conn = nil
client.t = tomb.Tomb{}
@@ -236,9 +238,6 @@ func (m *roaManager) handleROAEvent(ev *roaClientEvent) {
client.timer = time.AfterFunc(time.Duration(client.lifetime)*time.Second, client.lifetimeout)
case CONNECTED:
log.Info("roa server is connected, ", ev.src)
- if client.timer != nil {
- client.timer.Stop()
- }
client.conn = ev.conn
client.state.Uptime = time.Now().Unix()
client.t = tomb.Tomb{}
@@ -246,7 +245,7 @@ func (m *roaManager) handleROAEvent(ev *roaClientEvent) {
case RTR:
m.handleRTRMsg(client, &client.state, ev.data)
case LIFETIMEOUT:
- if client.conn == nil {
+ if client.endOfData == false {
log.Info("delete all due to timeout", client.host)
m.deleteAllROA(client.host)
} else {
@@ -335,7 +334,11 @@ func (c *roaManager) handleRTRMsg(client *roaClient, state *config.RpkiServerSta
}
roa := NewROA(family, msg.Prefix, msg.PrefixLen, msg.MaxLen, msg.AS, client.host)
if (msg.Flags & 1) == 1 {
- c.addROA(roa)
+ if client.endOfData {
+ c.addROA(roa)
+ } else {
+ client.pendingROAs = append(client.pendingROAs, roa)
+ }
} else {
c.deleteROA(roa)
}
@@ -343,6 +346,16 @@ func (c *roaManager) handleRTRMsg(client *roaClient, state *config.RpkiServerSta
received.EndOfData++
client.sessionID = msg.RTRCommon.SessionID
client.serialNumber = msg.RTRCommon.SerialNumber
+ client.endOfData = true
+ if client.timer != nil {
+ client.timer.Stop()
+ client.timer = nil
+ }
+ c.deleteAllROA(client.host)
+ for _, roa := range client.pendingROAs {
+ c.addROA(roa)
+ }
+ client.pendingROAs = make([]*ROA, 0)
case *bgp.RTRCacheReset:
client.softReset()
received.CacheReset++
@@ -562,13 +575,16 @@ type roaClient struct {
serialNumber uint32
timer *time.Timer
lifetime int64
+ endOfData bool
+ pendingROAs []*ROA
}
func NewRoaClient(address, port string, ch chan *roaClientEvent, lifetime int64) *roaClient {
return &roaClient{
- host: net.JoinHostPort(address, port),
- eventCh: ch,
- lifetime: lifetime,
+ host: net.JoinHostPort(address, port),
+ eventCh: ch,
+ lifetime: lifetime,
+ pendingROAs: make([]*ROA, 0),
}
}
@@ -594,6 +610,8 @@ func (c *roaClient) softReset() error {
return err
}
c.state.RpkiMessages.RpkiSent.ResetQuery++
+ c.endOfData = false
+ c.pendingROAs = make([]*ROA, 0)
}
return nil
}