Sergiusz Bazanski | 1fad2e5 | 2019-08-01 20:16:27 +0200 | [diff] [blame] | 1 | package main |
| 2 | |
| 3 | import ( |
| 4 | "context" |
| 5 | "fmt" |
| 6 | "time" |
| 7 | |
Sergiusz Bazanski | 1fad2e5 | 2019-08-01 20:16:27 +0200 | [diff] [blame] | 8 | pb "code.hackerspace.pl/hscloud/bgpwtf/cccampix/proto" |
| 9 | "code.hackerspace.pl/hscloud/bgpwtf/cccampix/verifier/model" |
Serge Bazanski | ec71cb5 | 2019-08-22 18:13:13 +0200 | [diff] [blame] | 10 | "code.hackerspace.pl/hscloud/go/pki" |
| 11 | "google.golang.org/grpc" |
Sergiusz Bazanski | 1fad2e5 | 2019-08-01 20:16:27 +0200 | [diff] [blame] | 12 | ) |
| 13 | |
| 14 | type peeringDB struct { |
| 15 | pdb pb.PeeringDBProxyClient |
| 16 | } |
| 17 | |
| 18 | func newPeeringDB(addr string) (processor, error) { |
| 19 | conn, err := grpc.Dial(addr, pki.WithClientHSPKI()) |
| 20 | if err != nil { |
| 21 | return nil, fmt.Errorf("could not connect to peeringdb service: %v", err) |
| 22 | } |
| 23 | |
| 24 | return &peeringDB{ |
| 25 | pdb: pb.NewPeeringDBProxyClient(conn), |
| 26 | }, nil |
| 27 | } |
| 28 | |
| 29 | func (p *peeringDB) Name() string { |
| 30 | return "PeeringDB" |
| 31 | } |
| 32 | |
Serge Bazanski | ec71cb5 | 2019-08-22 18:13:13 +0200 | [diff] [blame] | 33 | func (p *peeringDB) NextRun(now time.Time, lastFailed bool) time.Time { |
| 34 | if lastFailed { |
| 35 | return now.Add(1 * time.Minute) |
| 36 | } |
Sergiusz Bazanski | 1fad2e5 | 2019-08-01 20:16:27 +0200 | [diff] [blame] | 37 | return now.Add(5 * time.Minute) |
| 38 | } |
| 39 | |
| 40 | func (p *peeringDB) RunAll(ctx context.Context, m model.Model) error { |
| 41 | id := int64(2641) |
| 42 | req := &pb.GetIXMembersRequest{ |
| 43 | Id: id, |
| 44 | } |
| 45 | |
| 46 | res, err := p.pdb.GetIXMembers(ctx, req) |
| 47 | if err != nil { |
| 48 | return fmt.Errorf("GetIXMembers(%d): %v", id, err) |
| 49 | } |
| 50 | |
| 51 | err = m.RecordPeeringDBPeers(ctx, res.Members) |
| 52 | if err != nil { |
| 53 | return fmt.Errorf("RecordPeeringDBPeers: %v", err) |
| 54 | } |
| 55 | err = m.RecordPeeringDBPeerRouters(ctx, res.Members) |
| 56 | if err != nil { |
| 57 | return fmt.Errorf("RecordPeeringDBPeerRouters: %v", err) |
| 58 | } |
| 59 | return nil |
| 60 | } |