mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-08-05 16:57:44 +00:00
Revert "bgpd: convert neighbor plist to transactional cli"
This reverts commit d9986d26c0
.
This commit is contained in:
parent
a771a8769e
commit
642ef66443
@ -15182,64 +15182,6 @@ int bgp_neighbors_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_config_rmap_ex
|
||||
return NB_OK;
|
||||
}
|
||||
|
||||
static int bgp_neighbor_afi_safi_plist_modify(struct nb_cb_modify_args *args,
|
||||
int direct)
|
||||
{
|
||||
struct bgp *bgp;
|
||||
const char *peer_str;
|
||||
struct peer *peer;
|
||||
const struct lyd_node *nbr_dnode;
|
||||
const struct lyd_node *nbr_af_dnode;
|
||||
const char *af_name;
|
||||
afi_t afi;
|
||||
safi_t safi;
|
||||
const char *name_str;
|
||||
|
||||
nbr_af_dnode = yang_dnode_get_parent(args->dnode, "afi-safi");
|
||||
af_name = yang_dnode_get_string(nbr_af_dnode, "./afi-safi-name");
|
||||
yang_afi_safi_identity2value(af_name, &afi, &safi);
|
||||
|
||||
nbr_dnode = yang_dnode_get_parent(nbr_af_dnode, "neighbor");
|
||||
bgp = nb_running_get_entry(nbr_dnode, NULL, true);
|
||||
peer_str = yang_dnode_get_string(nbr_dnode, "./remote-address");
|
||||
peer = bgp_neighbor_peer_lookup(bgp, peer_str, args->errmsg,
|
||||
args->errmsg_len);
|
||||
|
||||
name_str = yang_dnode_get_string(args->dnode, NULL);
|
||||
if (peer_prefix_list_set(peer, afi, safi, direct, name_str) < 0)
|
||||
return NB_ERR_INCONSISTENCY;
|
||||
|
||||
return NB_OK;
|
||||
}
|
||||
|
||||
static int bgp_neighbor_afi_safi_plist_destroy(struct nb_cb_destroy_args *args,
|
||||
int direct)
|
||||
{
|
||||
struct bgp *bgp;
|
||||
const char *peer_str;
|
||||
struct peer *peer;
|
||||
const struct lyd_node *nbr_dnode;
|
||||
const struct lyd_node *nbr_af_dnode;
|
||||
const char *af_name;
|
||||
afi_t afi;
|
||||
safi_t safi;
|
||||
|
||||
nbr_af_dnode = yang_dnode_get_parent(args->dnode, "afi-safi");
|
||||
af_name = yang_dnode_get_string(nbr_af_dnode, "./afi-safi-name");
|
||||
yang_afi_safi_identity2value(af_name, &afi, &safi);
|
||||
|
||||
nbr_dnode = yang_dnode_get_parent(nbr_af_dnode, "neighbor");
|
||||
bgp = nb_running_get_entry(nbr_dnode, NULL, true);
|
||||
peer_str = yang_dnode_get_string(nbr_dnode, "./remote-address");
|
||||
peer = bgp_neighbor_peer_lookup(bgp, peer_str, args->errmsg,
|
||||
args->errmsg_len);
|
||||
|
||||
if (peer_prefix_list_unset(peer, afi, safi, direct) < 0)
|
||||
return NB_ERR_INCONSISTENCY;
|
||||
|
||||
return NB_OK;
|
||||
}
|
||||
|
||||
/*
|
||||
* XPath:
|
||||
* /frr-routing:routing/control-plane-protocols/control-plane-protocol/frr-bgp:bgp/neighbors/neighbor/afi-safis/afi-safi/ipv4-unicast/filter-config/plist-import
|
||||
@ -15251,9 +15193,9 @@ int bgp_neighbors_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_config_plist_i
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_neighbor_afi_safi_plist_modify(args, FILTER_IN);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
@ -15266,9 +15208,9 @@ int bgp_neighbors_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_config_plist_i
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_neighbor_afi_safi_plist_destroy(args, FILTER_IN);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
@ -15285,9 +15227,9 @@ int bgp_neighbors_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_config_plist_e
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_neighbor_afi_safi_plist_modify(args, FILTER_OUT);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
@ -15300,9 +15242,9 @@ int bgp_neighbors_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_config_plist_e
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_neighbor_afi_safi_plist_destroy(args, FILTER_OUT);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
@ -23558,65 +23500,6 @@ int bgp_neighbors_unnumbered_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_con
|
||||
return NB_OK;
|
||||
}
|
||||
|
||||
static int
|
||||
bgp_unnumbered_neighbor_afi_safi_plist_modify(struct nb_cb_modify_args *args,
|
||||
int direct)
|
||||
{
|
||||
struct bgp *bgp;
|
||||
const char *peer_str;
|
||||
struct peer *peer;
|
||||
const struct lyd_node *nbr_dnode;
|
||||
const struct lyd_node *nbr_af_dnode;
|
||||
const char *af_name;
|
||||
afi_t afi;
|
||||
safi_t safi;
|
||||
const char *name_str;
|
||||
|
||||
nbr_af_dnode = yang_dnode_get_parent(args->dnode, "afi-safi");
|
||||
af_name = yang_dnode_get_string(nbr_af_dnode, "./afi-safi-name");
|
||||
yang_afi_safi_identity2value(af_name, &afi, &safi);
|
||||
|
||||
nbr_dnode = yang_dnode_get_parent(nbr_af_dnode, "unnumbered-neighbor");
|
||||
bgp = nb_running_get_entry(nbr_dnode, NULL, true);
|
||||
peer_str = yang_dnode_get_string(nbr_dnode, "./interface");
|
||||
peer = bgp_unnumbered_neighbor_peer_lookup(bgp, peer_str, args->errmsg,
|
||||
args->errmsg_len);
|
||||
|
||||
name_str = yang_dnode_get_string(args->dnode, NULL);
|
||||
if (peer_prefix_list_set(peer, afi, safi, direct, name_str) < 0)
|
||||
return NB_ERR_INCONSISTENCY;
|
||||
|
||||
return NB_OK;
|
||||
}
|
||||
|
||||
static int
|
||||
bgp_unnumbered_neighbor_afi_safi_plist_destroy(struct nb_cb_destroy_args *args,
|
||||
int direct)
|
||||
{
|
||||
struct bgp *bgp;
|
||||
const char *peer_str;
|
||||
struct peer *peer;
|
||||
const struct lyd_node *nbr_dnode;
|
||||
const struct lyd_node *nbr_af_dnode;
|
||||
const char *af_name;
|
||||
afi_t afi;
|
||||
safi_t safi;
|
||||
|
||||
nbr_af_dnode = yang_dnode_get_parent(args->dnode, "afi-safi");
|
||||
af_name = yang_dnode_get_string(nbr_af_dnode, "./afi-safi-name");
|
||||
yang_afi_safi_identity2value(af_name, &afi, &safi);
|
||||
|
||||
nbr_dnode = yang_dnode_get_parent(nbr_af_dnode, "unnumbered-neighbor");
|
||||
bgp = nb_running_get_entry(nbr_dnode, NULL, true);
|
||||
peer_str = yang_dnode_get_string(nbr_dnode, "./interface");
|
||||
peer = bgp_unnumbered_neighbor_peer_lookup(bgp, peer_str, args->errmsg,
|
||||
args->errmsg_len);
|
||||
|
||||
if (peer_prefix_list_unset(peer, afi, safi, direct) < 0)
|
||||
return NB_ERR_INCONSISTENCY;
|
||||
|
||||
return NB_OK;
|
||||
}
|
||||
/*
|
||||
* XPath:
|
||||
* /frr-routing:routing/control-plane-protocols/control-plane-protocol/frr-bgp:bgp/neighbors/unnumbered-neighbor/afi-safis/afi-safi/ipv4-unicast/filter-config/plist-import
|
||||
@ -23628,10 +23511,9 @@ int bgp_neighbors_unnumbered_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_con
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_unnumbered_neighbor_afi_safi_plist_modify(args,
|
||||
FILTER_IN);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
@ -23644,10 +23526,9 @@ int bgp_neighbors_unnumbered_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_con
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_unnumbered_neighbor_afi_safi_plist_destroy(
|
||||
args, FILTER_IN);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
@ -23664,10 +23545,9 @@ int bgp_neighbors_unnumbered_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_con
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_unnumbered_neighbor_afi_safi_plist_modify(
|
||||
args, FILTER_OUT);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
@ -23680,10 +23560,9 @@ int bgp_neighbors_unnumbered_neighbor_afi_safis_afi_safi_ipv4_unicast_filter_con
|
||||
case NB_EV_VALIDATE:
|
||||
case NB_EV_PREPARE:
|
||||
case NB_EV_ABORT:
|
||||
break;
|
||||
case NB_EV_APPLY:
|
||||
return bgp_unnumbered_neighbor_afi_safi_plist_destroy(
|
||||
args, FILTER_OUT);
|
||||
/* TODO: implement me. */
|
||||
break;
|
||||
}
|
||||
|
||||
return NB_OK;
|
||||
|
136
bgpd/bgp_vty.c
136
bgpd/bgp_vty.c
@ -5747,6 +5747,7 @@ DEFUN_YANG (neighbor_nexthop_self,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -5785,6 +5786,7 @@ DEFUN_YANG(neighbor_nexthop_self_force,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -5869,6 +5871,7 @@ DEFUN_YANG (no_neighbor_nexthop_self_force,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -6026,6 +6029,7 @@ DEFUN_YANG (neighbor_remove_private_as_all,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -6065,6 +6069,7 @@ DEFUN_YANG (neighbor_remove_private_as_replace_as,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -6105,6 +6110,7 @@ DEFUN_YANG (neighbor_remove_private_as_all_replace_as,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -6185,6 +6191,7 @@ DEFUN_YANG (no_neighbor_remove_private_as_all,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -6225,6 +6232,7 @@ DEFUN_YANG (no_neighbor_remove_private_as_replace_as,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -6266,6 +6274,7 @@ DEFUN_YANG (no_neighbor_remove_private_as_all_replace_as,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -6555,6 +6564,7 @@ DEFUN_YANG (neighbor_soft_reconfiguration,
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
|
||||
@ -7941,44 +7951,69 @@ ALIAS_HIDDEN(
|
||||
"Filter outgoing updates\n")
|
||||
|
||||
/* Set prefix list to the peer. */
|
||||
DEFPY_YANG(
|
||||
neighbor_prefix_list, neighbor_prefix_list_cmd,
|
||||
"[no$no] neighbor <A.B.C.D|X:X::X:X|WORD>$neighbor_str prefix-list WORD$prefix_str <in|out>$direction",
|
||||
NO_STR NEIGHBOR_STR NEIGHBOR_ADDR_STR2
|
||||
"Filter updates to/from this neighbor\n"
|
||||
"Name of a prefix list\n"
|
||||
"Filter incoming updates\n"
|
||||
"Filter outgoing updates\n")
|
||||
static int peer_prefix_list_set_vty(struct vty *vty, const char *ip_str,
|
||||
afi_t afi, safi_t safi,
|
||||
const char *name_str,
|
||||
const char *direct_str)
|
||||
{
|
||||
char base_xpath[XPATH_MAXLEN];
|
||||
char af_xpath[XPATH_MAXLEN];
|
||||
char plist_xpath[80];
|
||||
afi_t afi = bgp_node_afi(vty);
|
||||
safi_t safi = bgp_node_safi(vty);
|
||||
int ret;
|
||||
int direct = FILTER_IN;
|
||||
struct peer *peer;
|
||||
|
||||
snprintf(af_xpath, sizeof(af_xpath), FRR_BGP_AF_XPATH,
|
||||
yang_afi_safi_value2identity(afi, safi));
|
||||
if (peer_and_group_lookup_nb(vty, neighbor_str, base_xpath,
|
||||
sizeof(base_xpath), af_xpath)
|
||||
< 0)
|
||||
peer = peer_and_group_lookup_vty(vty, ip_str);
|
||||
if (!peer)
|
||||
return CMD_WARNING_CONFIG_FAILED;
|
||||
|
||||
if (strmatch(direction, "in"))
|
||||
snprintf(plist_xpath, sizeof(plist_xpath),
|
||||
"./%s/filter-config/plist-import",
|
||||
bgp_afi_safi_get_container_str(afi, safi));
|
||||
else if (strmatch(direction, "out"))
|
||||
snprintf(plist_xpath, sizeof(plist_xpath),
|
||||
"./%s/filter-config/plist-export",
|
||||
bgp_afi_safi_get_container_str(afi, safi));
|
||||
/* Check filter direction. */
|
||||
if (strncmp(direct_str, "i", 1) == 0)
|
||||
direct = FILTER_IN;
|
||||
else if (strncmp(direct_str, "o", 1) == 0)
|
||||
direct = FILTER_OUT;
|
||||
|
||||
if (!no)
|
||||
nb_cli_enqueue_change(vty, plist_xpath, NB_OP_MODIFY,
|
||||
prefix_str);
|
||||
else
|
||||
nb_cli_enqueue_change(vty, plist_xpath, NB_OP_DESTROY, NULL);
|
||||
ret = peer_prefix_list_set(peer, afi, safi, direct, name_str);
|
||||
|
||||
return nb_cli_apply_changes(vty, base_xpath);
|
||||
return bgp_vty_return(vty, ret);
|
||||
}
|
||||
|
||||
static int peer_prefix_list_unset_vty(struct vty *vty, const char *ip_str,
|
||||
afi_t afi, safi_t safi,
|
||||
const char *direct_str)
|
||||
{
|
||||
int ret;
|
||||
struct peer *peer;
|
||||
int direct = FILTER_IN;
|
||||
|
||||
peer = peer_and_group_lookup_vty(vty, ip_str);
|
||||
if (!peer)
|
||||
return CMD_WARNING_CONFIG_FAILED;
|
||||
|
||||
/* Check filter direction. */
|
||||
if (strncmp(direct_str, "i", 1) == 0)
|
||||
direct = FILTER_IN;
|
||||
else if (strncmp(direct_str, "o", 1) == 0)
|
||||
direct = FILTER_OUT;
|
||||
|
||||
ret = peer_prefix_list_unset(peer, afi, safi, direct);
|
||||
|
||||
return bgp_vty_return(vty, ret);
|
||||
}
|
||||
|
||||
DEFUN (neighbor_prefix_list,
|
||||
neighbor_prefix_list_cmd,
|
||||
"neighbor <A.B.C.D|X:X::X:X|WORD> prefix-list WORD <in|out>",
|
||||
NEIGHBOR_STR
|
||||
NEIGHBOR_ADDR_STR2
|
||||
"Filter updates to/from this neighbor\n"
|
||||
"Name of a prefix list\n"
|
||||
"Filter incoming updates\n"
|
||||
"Filter outgoing updates\n")
|
||||
{
|
||||
int idx_peer = 1;
|
||||
int idx_word = 3;
|
||||
int idx_in_out = 4;
|
||||
return peer_prefix_list_set_vty(
|
||||
vty, argv[idx_peer]->arg, bgp_node_afi(vty), bgp_node_safi(vty),
|
||||
argv[idx_word]->arg, argv[idx_in_out]->arg);
|
||||
}
|
||||
|
||||
ALIAS_HIDDEN(neighbor_prefix_list, neighbor_prefix_list_hidden_cmd,
|
||||
@ -7989,6 +8024,32 @@ ALIAS_HIDDEN(neighbor_prefix_list, neighbor_prefix_list_hidden_cmd,
|
||||
"Filter incoming updates\n"
|
||||
"Filter outgoing updates\n")
|
||||
|
||||
DEFUN (no_neighbor_prefix_list,
|
||||
no_neighbor_prefix_list_cmd,
|
||||
"no neighbor <A.B.C.D|X:X::X:X|WORD> prefix-list WORD <in|out>",
|
||||
NO_STR
|
||||
NEIGHBOR_STR
|
||||
NEIGHBOR_ADDR_STR2
|
||||
"Filter updates to/from this neighbor\n"
|
||||
"Name of a prefix list\n"
|
||||
"Filter incoming updates\n"
|
||||
"Filter outgoing updates\n")
|
||||
{
|
||||
int idx_peer = 2;
|
||||
int idx_in_out = 5;
|
||||
return peer_prefix_list_unset_vty(vty, argv[idx_peer]->arg,
|
||||
bgp_node_afi(vty), bgp_node_safi(vty),
|
||||
argv[idx_in_out]->arg);
|
||||
}
|
||||
|
||||
ALIAS_HIDDEN(no_neighbor_prefix_list, no_neighbor_prefix_list_hidden_cmd,
|
||||
"no neighbor <A.B.C.D|X:X::X:X|WORD> prefix-list WORD <in|out>",
|
||||
NO_STR NEIGHBOR_STR NEIGHBOR_ADDR_STR2
|
||||
"Filter updates to/from this neighbor\n"
|
||||
"Name of a prefix list\n"
|
||||
"Filter incoming updates\n"
|
||||
"Filter outgoing updates\n")
|
||||
|
||||
static int peer_aslist_set_vty(struct vty *vty, const char *ip_str, afi_t afi,
|
||||
safi_t safi, const char *name_str,
|
||||
const char *direct_str)
|
||||
@ -19442,16 +19503,27 @@ void bgp_vty_init(void)
|
||||
|
||||
/* "neighbor prefix-list" commands. */
|
||||
install_element(BGP_NODE, &neighbor_prefix_list_hidden_cmd);
|
||||
install_element(BGP_NODE, &no_neighbor_prefix_list_hidden_cmd);
|
||||
install_element(BGP_IPV4_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV4_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV4M_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV4M_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV4L_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV4L_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV6_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV6_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV6M_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV6M_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV6L_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_IPV6L_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_VPNV4_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_VPNV4_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_VPNV6_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_VPNV6_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_FLOWSPECV4_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_FLOWSPECV4_NODE, &no_neighbor_prefix_list_cmd);
|
||||
install_element(BGP_FLOWSPECV6_NODE, &neighbor_prefix_list_cmd);
|
||||
install_element(BGP_FLOWSPECV6_NODE, &no_neighbor_prefix_list_cmd);
|
||||
|
||||
/* "neighbor filter-list" commands. */
|
||||
install_element(BGP_NODE, &neighbor_filter_list_hidden_cmd);
|
||||
|
Loading…
Reference in New Issue
Block a user