Skip to content

Add support for a callback after each RIB operation.#21

Merged
robshakir merged 13 commits intomainfrom
rib3
Jun 12, 2021
Merged

Add support for a callback after each RIB operation.#21
robshakir merged 13 commits intomainfrom
rib3

Conversation

@robshakir
Copy link
Copy Markdown
Member

  * (M) aft/oc.go
  * (M) aft/update.sh
    - Add delete methods.
  * (M) go.mod
  * (M) go.sum
    - Tidy up modules.
  * (M) rib/rib.go
    - Add support for a simple callback function that is run after
      every update to the RIB.
    - Fix a defect with implicit replace whereby we did not delete the
      RIB entry before doing MergeStructInto meaning that for some
      leaf-lists we ended up appending to the contents of the RIB.
  * (M) rib/rib_test.go
    - Add test cases for the above functionality - including a test
      case demonstrating how gNMI Notifications can be generated.

robshakir added 10 commits June 8, 2021 14:49
  * (M) aft/oc.go
  * (M) aft/update.sh
    - Update generated code.
  * (M) go.mod
  * (M) go.sum
    - Go mod tidying.
  * (M) rib/rib.go
  * (M) rib/rib_test.go
    - Add IPv4 entry add and delete.
  * (M) go.mod
  * (M) go.sum
    -  Tidy up modules.
  * (M) rib/rib.go
  * (M) rib/rib_test.go
    -  Add support for network instances in the RIB rather than
       a single RIB.
  * (M) client/client.go
    - TODO comment about handling coalescing.
  * (M) rib/rib.go
  * (M) rib/rib_test.go
    - Add support for adding NHG and NHs to the RIB.
  * (M) rib/rib.go
  * (M) rib/rib_test.go
    - Validate any candidate RIB against the OpenConfig schema before
      adding it to the RIB.
  * (M) aft/oc.go
  * (M) aft/update.sh
    - Add delete methods.
  * (M) go.mod
  * (M) go.sum
    - Tidy up modules.
  * (M) rib/rib.go
    - Add support for a simple callback function that is run after
      every update to the RIB.
    - Fix a defect with implicit replace whereby we did not delete the
      RIB entry before doing MergeStructInto meaning that for some
      leaf-lists we ended up appending to the contents of the RIB.
  * (M) rib/rib_test.go
    - Add test cases for the above functionality - including a test
      case demonstrating how gNMI Notifications can be generated.
@robshakir robshakir requested a review from sthesayi June 11, 2021 09:13
@robshakir robshakir changed the base branch from rib2 to main June 11, 2021 09:13
@robshakir robshakir changed the base branch from main to rib2 June 11, 2021 09:13
* Add an initial implementation of a resolved-RIB.

Background -- we want the gRIBI server to be able build both a RIB that
is efficient for it to do gRIBI operations with, as well as a software
emulated 'resolved RIB' / 'FIB' whereby we can say something like "where
will this packet go based on what gRIBI is programmed?". This package
starts this implementation.

  * (M) aft/oc.go
    - Update generated code.
  * (M) go.mod
  * (M) go.sum
    - New dependencies on kentik/patricia
  * (A) ocrt/oc.go
  * (A) ocrt/update.sh
    - Generated routing specific OpenConfig Go structs.
  * (A) ocrt/yang/deviations.yang
    - Deviations to reduce the size of the generated oc.go.
  * (M) rib/rib.go
    - Fix handling of implicit replace.
  * (A) sysrib/sysrib.go
  * (A) sysrib/sysrib_test.go
    -  Initial system RIB implementation. This package currently parses
        OpenConfig to build a list of all of the connected routes that
        are on the system.

* Address review comments.
Comment thread rib/rib.go
Comment thread sysrib/sysrib.go Outdated
Base automatically changed from rib2 to main June 11, 2021 23:52
@robshakir robshakir merged commit 6e16dee into main Jun 12, 2021
@robshakir robshakir deleted the rib3 branch June 12, 2021 00:12
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants