summaryrefslogtreecommitdiff
path: root/zebra
diff options
context:
space:
mode:
authorDonatas Abraitis <donatas@opensourcerouting.org>2025-02-11 21:22:12 +0200
committerDonatas Abraitis <donatas@opensourcerouting.org>2025-02-12 23:37:20 +0200
commit44fe3981ee388f7c60ab2635309bce34774116e1 (patch)
treead5285a1e6eb80e522e19828e84ed8ba5f2b5d86 /zebra
parentbaf4c1a78fe4cafdbb2cdbed030a31ea04a18c4a (diff)
zebra: Do not flush an existing vni configuration trying to remove wrong vni
Before: ``` pc.donatas.net(config)# do sh run | include vni vni 1 pc.donatas.net(config)# no vni 2 pc.donatas.net(config)# do sh run | include vni pc.donatas.net(config)# ``` Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
Diffstat (limited to 'zebra')
-rw-r--r--zebra/zebra_cli.c28
1 files changed, 24 insertions, 4 deletions
diff --git a/zebra/zebra_cli.c b/zebra/zebra_cli.c
index bb79928326..8b2eab3f5d 100644
--- a/zebra/zebra_cli.c
+++ b/zebra/zebra_cli.c
@@ -2355,12 +2355,32 @@ DEFPY_YANG (vni_mapping,
"VNI-ID\n"
"prefix-routes-only\n")
{
- if (!no)
+ const struct lyd_node *dnode;
+ const char *vrf;
+
+ if (!no) {
nb_cli_enqueue_change(vty, "./frr-zebra:zebra/l3vni-id", NB_OP_MODIFY,
vni_str);
- else
- nb_cli_enqueue_change(vty, "./frr-zebra:zebra/l3vni-id", NB_OP_DESTROY,
- NULL);
+ } else {
+ if (vty->node == CONFIG_NODE) {
+ if (yang_dnode_existsf(vty->candidate_config->dnode,
+ "/frr-vrf:lib/vrf[name='%s']/frr-zebra:zebra[l3vni-id='%lu']",
+ VRF_DEFAULT_NAME, vni))
+ nb_cli_enqueue_change(vty, "./frr-zebra:zebra/l3vni-id",
+ NB_OP_DESTROY, NULL);
+ } else {
+ dnode = yang_dnode_get(vty->candidate_config->dnode, VTY_CURR_XPATH);
+ if (dnode) {
+ vrf = yang_dnode_get_string(dnode, "name");
+
+ if (yang_dnode_existsf(vty->candidate_config->dnode,
+ "/frr-vrf:lib/vrf[name='%s']/frr-zebra:zebra[l3vni-id='%lu']",
+ vrf, vni))
+ nb_cli_enqueue_change(vty, "./frr-zebra:zebra/l3vni-id",
+ NB_OP_DESTROY, NULL);
+ }
+ }
+ }
if (filter)
nb_cli_enqueue_change(vty, "./frr-zebra:zebra/prefix-only",