From 82cc2054036fe950f0b655824e5a3242f2f18182 Mon Sep 17 00:00:00 2001 From: Nathan Skrzypczak Date: Fri, 23 Feb 2024 18:55:00 +0100 Subject: [PATCH] allow to pass add/del route -a vpnv46 identifier This patch adds an 'identifier %d' option to the route add / del CLI. This is helpful for testing add-paths capabilities in vpv46 contexts. Signed-off-by: Nathan Skrzypczak --- cmd/gobgp/global.go | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/cmd/gobgp/global.go b/cmd/gobgp/global.go index fe24cbe73..00ff62795 100644 --- a/cmd/gobgp/global.go +++ b/cmd/gobgp/global.go @@ -1888,8 +1888,6 @@ func parsePath(rf bgp.RouteFamily, args []string) (*api.Path, error) { return nil, err } - extcomms = args[5:] - if rf == bgp.RF_IPv4_VPN { if ip.To4() == nil { return nil, fmt.Errorf("invalid ipv4 prefix") @@ -1901,6 +1899,19 @@ func parsePath(rf bgp.RouteFamily, args []string) (*api.Path, error) { } nlri = bgp.NewLabeledVPNIPv6AddrPrefix(uint8(ones), ip.String(), *mpls, rd) } + + args = args[5:] + + if len(args) > 1 && args[0] == "identifier" { + id, err := strconv.ParseUint(args[1], 10, 32) + if err != nil { + return nil, fmt.Errorf("invalid format") + } + nlri.SetPathIdentifier(uint32(id)) + args = args[2:] + } + + extcomms = args case bgp.RF_IPv4_MPLS, bgp.RF_IPv6_MPLS: if len(args) < 2 { return nil, fmt.Errorf("invalid format")