summaryrefslogtreecommitdiffstats
path: root/bgpd/bgp_rpki.c
diff options
context:
space:
mode:
authorDonatas Abraitis <donatas@opensourcerouting.org>2022-06-20 19:31:18 +0200
committerDonatas Abraitis <donatas@opensourcerouting.org>2022-06-20 19:56:32 +0200
commit8156765abe5d5d5cdaffa0503799b117c32ac130 (patch)
tree497cd708b9f5ba76e2e15c45e63de2ae5201d68a /bgpd/bgp_rpki.c
parentMerge pull request #11146 from NicolasDichtel/master (diff)
downloadfrr-8156765abe5d5d5cdaffa0503799b117c32ac130.tar.xz
frr-8156765abe5d5d5cdaffa0503799b117c32ac130.zip
bgpd: Add `no rpki` command
To delete the whole RPKI section. Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
Diffstat (limited to 'bgpd/bgp_rpki.c')
-rw-r--r--bgpd/bgp_rpki.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/bgpd/bgp_rpki.c b/bgpd/bgp_rpki.c
index 1c7dc7cb0..90f48a5be 100644
--- a/bgpd/bgp_rpki.c
+++ b/bgpd/bgp_rpki.c
@@ -120,6 +120,7 @@ static int add_ssh_cache(const char *host, const unsigned int port,
#endif
static struct rtr_socket *create_rtr_socket(struct tr_socket *tr_socket);
static struct cache *find_cache(const uint8_t preference);
+static void rpki_delete_all_cache_nodes(void);
static int add_tcp_cache(const char *host, const char *port,
const uint8_t preference, const char *bindaddr);
static void print_record(const struct pfx_record *record, struct vty *vty,
@@ -276,6 +277,17 @@ static struct cache *find_cache(const uint8_t preference)
return NULL;
}
+static void rpki_delete_all_cache_nodes(void)
+{
+ struct listnode *cache_node, *cache_next;
+ struct cache *cache;
+
+ for (ALL_LIST_ELEMENTS(cache_list, cache_node, cache_next, cache)) {
+ rtr_mgr_remove_group(rtr_config, cache->preference);
+ listnode_delete(cache_list, cache);
+ }
+}
+
static void print_record(const struct pfx_record *record, struct vty *vty,
json_object *json)
{
@@ -1055,6 +1067,17 @@ DEFUN_NOSH (rpki,
return CMD_SUCCESS;
}
+DEFPY (no_rpki,
+ no_rpki_cmd,
+ "no rpki",
+ NO_STR
+ "Enable rpki and enter rpki configuration mode\n")
+{
+ rpki_delete_all_cache_nodes();
+ stop();
+ return CMD_SUCCESS;
+}
+
DEFUN (bgp_rpki_start,
bgp_rpki_start_cmd,
"rpki start",
@@ -1662,6 +1685,8 @@ static void install_cli_commands(void)
install_default(RPKI_NODE);
install_element(CONFIG_NODE, &rpki_cmd);
install_element(ENABLE_NODE, &rpki_cmd);
+ install_element(CONFIG_NODE, &no_rpki_cmd);
+
install_element(ENABLE_NODE, &bgp_rpki_start_cmd);
install_element(ENABLE_NODE, &bgp_rpki_stop_cmd);