diff options
-rw-r--r-- | usr.sbin/bgpctl/bgpctl.8 | 6 | ||||
-rw-r--r-- | usr.sbin/bgpctl/bgpctl.c | 48 |
2 files changed, 46 insertions, 8 deletions
diff --git a/usr.sbin/bgpctl/bgpctl.8 b/usr.sbin/bgpctl/bgpctl.8 index d684fbd1fce..0fe4760634b 100644 --- a/usr.sbin/bgpctl/bgpctl.8 +++ b/usr.sbin/bgpctl/bgpctl.8 @@ -1,4 +1,4 @@ -.\" $OpenBSD: bgpctl.8,v 1.7 2004/01/06 16:48:06 jmc Exp $ +.\" $OpenBSD: bgpctl.8,v 1.8 2004/01/06 23:23:49 henning Exp $ .\" .\" Copyright (c) 2003 Henning Brauer <henning@openbsd.org> .\" @@ -54,6 +54,10 @@ routing table. .It Li fib decouple Remove the learned routes into the Forward Information Base aka the kernel routing table. +.It Li neighbor Ar address up +Take the bgp session to the specified neighbor up. +.It Li neighbor Ar address down +Take the bgp session to the specified neighbor down. .El .Sh FILES .Bl -tag -width "/etc/bgpd.conf" -compact diff --git a/usr.sbin/bgpctl/bgpctl.c b/usr.sbin/bgpctl/bgpctl.c index 0a6f3efc5f8..c1153ccf724 100644 --- a/usr.sbin/bgpctl/bgpctl.c +++ b/usr.sbin/bgpctl/bgpctl.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bgpctl.c,v 1.19 2004/01/06 19:24:37 henning Exp $ */ +/* $OpenBSD: bgpctl.c,v 1.20 2004/01/06 23:23:49 henning Exp $ */ /* * Copyright (c) 2003 Henning Brauer <henning@openbsd.org> @@ -36,7 +36,10 @@ enum actions { RELOAD, FIB, FIB_COUPLE, - FIB_DECOUPLE + FIB_DECOUPLE, + NEIGHBOR, + NEIGHBOR_UP, + NEIGHBOR_DOWN }; enum neighbor_views { @@ -52,7 +55,8 @@ struct keywords { static const struct keywords keywords_main[] = { { "reload", RELOAD}, { "show", SHOW}, - { "fib", FIB} + { "fib", FIB}, + { "neighbor", NEIGHBOR} }; static const struct keywords keywords_show[] = { @@ -60,7 +64,7 @@ static const struct keywords keywords_show[] = { { "summary", SHOW_SUMMARY} }; -static const struct keywords keywords_neighbor[] = { +static const struct keywords keywords_show_neighbor[] = { { "timers", SHOW_NEIGHBOR_TIMERS}, { "messages", SHOW_NEIGHBOR} }; @@ -70,6 +74,11 @@ static const struct keywords keywords_fib[] = { { "decouple", FIB_DECOUPLE} }; +static const struct keywords keywords_neighbor[] = { + { "up", NEIGHBOR_UP}, + { "down", NEIGHBOR_DOWN} +}; + int main(int, char *[]); int match_keyword(const char *, const struct keywords [], size_t); void show_summary_head(void); @@ -140,9 +149,9 @@ again: imsg_compose(&ibuf, IMSG_CTL_SHOW_NEIGHBOR, 0, NULL, 0); if (argc >= 5) - action = match_keyword(argv[4], keywords_neighbor, - sizeof(keywords_neighbor)/ - sizeof(keywords_neighbor[0])); + action = match_keyword(argv[4], keywords_show_neighbor, + sizeof(keywords_show_neighbor)/ + sizeof(keywords_show_neighbor[0])); break; case RELOAD: if (argc >= 3) @@ -173,6 +182,28 @@ again: printf("decouple request sent.\n"); done = 1; break; + case NEIGHBOR: + if (argc < 4) + errx(1, "usage: neighbor address command"); + if (!parse_addr(argv[2], &addr)) + errx(1, "%s: not an IP address", argv[2]); + action = match_keyword(argv[3], keywords_neighbor, + sizeof(keywords_neighbor)/ + sizeof(keywords_neighbor[0])); + goto again; + break; + case NEIGHBOR_UP: + imsg_compose(&ibuf, IMSG_CTL_NEIGHBOR_UP, 0, + &addr, sizeof(addr)); + printf("request sent.\n"); + done = 1; + break; + case NEIGHBOR_DOWN: + imsg_compose(&ibuf, IMSG_CTL_NEIGHBOR_DOWN, 0, + &addr, sizeof(addr)); + printf("request sent.\n"); + done = 1; + break; } while (!done) { @@ -201,6 +232,9 @@ again: case FIB: case FIB_COUPLE: case FIB_DECOUPLE: + case NEIGHBOR: + case NEIGHBOR_UP: + case NEIGHBOR_DOWN: break; } imsg_free(&imsg); |