2000-03-19 22:09:07 +00:00
|
|
|
/*
|
|
|
|
* BIRD -- Border Gateway Protocol Configuration
|
|
|
|
*
|
|
|
|
* (c) 2000 Martin Mares <mj@ucw.cz>
|
|
|
|
*
|
|
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
2016-05-26 14:09:08 +02:00
|
|
|
*
|
|
|
|
*
|
|
|
|
* Code added from Parsons, Inc. (BGPSEC additions)
|
|
|
|
* (c) 2013-2013
|
|
|
|
*
|
|
|
|
* Can be used under either license:
|
|
|
|
* - Freely distributed and used under the terms of the GNU GPLv2.
|
|
|
|
* - Freely distributed and used under a BSD license, See README.bgpsec.
|
2000-03-19 22:09:07 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
CF_HDR
|
|
|
|
|
|
|
|
#include "proto/bgp/bgp.h"
|
|
|
|
|
2000-04-28 15:13:29 +00:00
|
|
|
CF_DEFINES
|
|
|
|
|
2000-03-19 22:09:07 +00:00
|
|
|
#define BGP_CFG ((struct bgp_config *) this_proto)
|
|
|
|
|
|
|
|
CF_DECLS
|
|
|
|
|
2010-07-13 12:48:23 +02:00
|
|
|
CF_KEYWORDS(BGP, LOCAL, NEIGHBOR, AS, HOLD, TIME, CONNECT, RETRY,
|
|
|
|
KEEPALIVE, MULTIHOP, STARTUP, VIA, NEXT, HOP, SELF, DEFAULT,
|
|
|
|
PATH, METRIC, ERROR, START, DELAY, FORGET, WAIT, ENABLE,
|
|
|
|
DISABLE, AFTER, BGP_PATH, BGP_LOCAL_PREF, BGP_MED, BGP_ORIGIN,
|
|
|
|
BGP_NEXT_HOP, BGP_ATOMIC_AGGR, BGP_AGGREGATOR, BGP_COMMUNITY,
|
2011-08-12 21:03:43 +02:00
|
|
|
BGP_EXT_COMMUNITY, SOURCE, ADDRESS, PASSWORD, RR, RS, CLIENT,
|
|
|
|
CLUSTER, ID, AS4, ADVERTISE, IPV4, CAPABILITIES, LIMIT, PASSIVE,
|
|
|
|
PREFER, OLDER, MISSING, LLADDR, DROP, IGNORE, ROUTE, REFRESH,
|
|
|
|
INTERPRET, COMMUNITIES, BGP_ORIGINATOR_ID, BGP_CLUSTER_LIST, IGP,
|
2012-04-15 15:07:58 +02:00
|
|
|
TABLE, GATEWAY, DIRECT, RECURSIVE, MED, TTL, SECURITY, DETERMINISTIC,
|
2015-02-21 11:46:14 +01:00
|
|
|
SECONDARY, ALLOW, BFD, ADD, PATHS, RX, TX, GRACEFUL, RESTART, AWARE,
|
2016-06-02 10:24:34 +02:00
|
|
|
CHECK, LINK, PORT, EXTENDED, MESSAGES, SETKEY,
|
2016-05-26 14:09:08 +02:00
|
|
|
BGPSEC, BGPSEC_SKI, BGPSEC_KEY_REPO_PATH, BGPSEC_PRIV_KEY_PATH,
|
|
|
|
BGPSEC_SAVE_BINARY_KEYS, BGPSEC_PREFER, BGPSEC_NO_PCOUNT0,
|
|
|
|
BGPSEC_REQUIRE, BGPSEC_NO_INVALID_ROUTES)
|
2000-03-19 22:09:07 +00:00
|
|
|
|
|
|
|
CF_GRAMMAR
|
|
|
|
|
2011-11-07 00:31:23 +01:00
|
|
|
CF_ADDTO(proto, bgp_proto '}' { bgp_check_config(BGP_CFG); } )
|
2000-03-19 22:09:07 +00:00
|
|
|
|
|
|
|
bgp_proto_start: proto_start BGP {
|
2015-02-21 21:08:23 +01:00
|
|
|
this_proto = proto_config_new(&proto_bgp, $1);
|
2015-02-22 13:50:58 +01:00
|
|
|
BGP_CFG->remote_port = BGP_PORT;
|
2013-11-24 12:37:24 +01:00
|
|
|
BGP_CFG->multihop = -1; /* undefined */
|
2000-03-20 21:50:17 +00:00
|
|
|
BGP_CFG->hold_time = 240;
|
2000-03-30 17:39:48 +00:00
|
|
|
BGP_CFG->initial_hold_time = 240;
|
2000-04-17 12:46:07 +00:00
|
|
|
BGP_CFG->compare_path_lengths = 1;
|
2010-07-31 01:04:32 +02:00
|
|
|
BGP_CFG->igp_metric = 1;
|
2015-02-22 16:08:28 +01:00
|
|
|
BGP_CFG->connect_delay_time = 5;
|
|
|
|
BGP_CFG->connect_retry_time = 120;
|
2000-04-25 23:08:31 +00:00
|
|
|
BGP_CFG->error_amnesia_time = 300;
|
|
|
|
BGP_CFG->error_delay_time_min = 60;
|
|
|
|
BGP_CFG->error_delay_time_max = 300;
|
2009-11-26 20:47:59 +01:00
|
|
|
BGP_CFG->enable_refresh = 1;
|
2009-12-14 23:31:25 +01:00
|
|
|
BGP_CFG->enable_as4 = 1;
|
2016-05-26 14:09:08 +02:00
|
|
|
BGP_CFG->enable_bgpsec = 1;
|
|
|
|
BGP_CFG->bgpsec_ski = 0;
|
|
|
|
BGP_CFG->bgpsec_priv_key_path = 0;
|
|
|
|
BGP_CFG->bgpsec_key_repo_path = 0;
|
|
|
|
BGP_CFG->bgpsec_prefer = 1;
|
|
|
|
BGP_CFG->bgpsec_no_pcount0 = 1;
|
|
|
|
BGP_CFG->bgpsec_no_invalid_routes = 0;
|
|
|
|
BGP_CFG->bgpsec_require = 0;
|
|
|
|
BGP_CFG->bgpsec_save_binary_keys = 0;
|
2009-03-13 12:49:44 +01:00
|
|
|
BGP_CFG->capabilities = 2;
|
|
|
|
BGP_CFG->advertise_ipv4 = 1;
|
2010-01-28 15:59:18 +01:00
|
|
|
BGP_CFG->interpret_communities = 1;
|
2009-12-21 11:50:42 +01:00
|
|
|
BGP_CFG->default_local_pref = 100;
|
2014-03-20 14:07:12 +01:00
|
|
|
BGP_CFG->gr_mode = BGP_GR_AWARE;
|
|
|
|
BGP_CFG->gr_time = 120;
|
2016-04-13 14:30:28 +02:00
|
|
|
BGP_CFG->setkey = 1;
|
2000-04-25 23:08:31 +00:00
|
|
|
}
|
2000-03-19 22:09:07 +00:00
|
|
|
;
|
|
|
|
|
2015-02-22 13:50:58 +01:00
|
|
|
bgp_nbr_opts:
|
|
|
|
/* empty */
|
|
|
|
| bgp_nbr_opts PORT expr { BGP_CFG->remote_port = $3; if (($3<1) || ($3>65535)) cf_error("Invalid port number"); }
|
|
|
|
| bgp_nbr_opts AS expr { BGP_CFG->remote_as = $3; }
|
|
|
|
;
|
|
|
|
|
2000-03-19 22:09:07 +00:00
|
|
|
bgp_proto:
|
|
|
|
bgp_proto_start proto_name '{'
|
|
|
|
| bgp_proto proto_item ';'
|
2008-10-26 22:36:08 +01:00
|
|
|
| bgp_proto LOCAL AS expr ';' { BGP_CFG->local_as = $4; }
|
2010-07-12 17:39:39 +02:00
|
|
|
| bgp_proto LOCAL ipa AS expr ';' { BGP_CFG->source_addr = $3; BGP_CFG->local_as = $5; }
|
2015-02-22 13:50:58 +01:00
|
|
|
| bgp_proto NEIGHBOR bgp_nbr_opts ';'
|
|
|
|
| bgp_proto NEIGHBOR ipa ipa_scope bgp_nbr_opts ';' {
|
2012-01-08 15:28:27 +01:00
|
|
|
if (ipa_nonzero(BGP_CFG->remote_ip))
|
|
|
|
cf_error("Only one neighbor per BGP instance is allowed");
|
2000-03-19 22:09:07 +00:00
|
|
|
BGP_CFG->remote_ip = $3;
|
2015-02-22 13:50:58 +01:00
|
|
|
if ($4) BGP_CFG->iface = $4;
|
2000-03-19 22:09:07 +00:00
|
|
|
}
|
2015-02-22 13:50:58 +01:00
|
|
|
| bgp_proto INTERFACE TEXT ';' { BGP_CFG->iface = if_get_by_name($3); }
|
2010-02-20 21:14:02 +01:00
|
|
|
| bgp_proto RR CLUSTER ID idval ';' { BGP_CFG->rr_cluster_id = $5; }
|
2008-10-26 22:45:09 +01:00
|
|
|
| bgp_proto RR CLIENT ';' { BGP_CFG->rr_client = 1; }
|
2008-11-01 12:55:43 +01:00
|
|
|
| bgp_proto RS CLIENT ';' { BGP_CFG->rs_client = 1; }
|
2000-05-15 11:48:23 +00:00
|
|
|
| bgp_proto HOLD TIME expr ';' { BGP_CFG->hold_time = $4; }
|
|
|
|
| bgp_proto STARTUP HOLD TIME expr ';' { BGP_CFG->initial_hold_time = $5; }
|
2013-11-24 12:37:24 +01:00
|
|
|
| bgp_proto DIRECT ';' { BGP_CFG->multihop = 0; }
|
2010-07-12 17:39:39 +02:00
|
|
|
| bgp_proto MULTIHOP ';' { BGP_CFG->multihop = 64; }
|
2011-08-16 23:05:35 +02:00
|
|
|
| bgp_proto MULTIHOP expr ';' { BGP_CFG->multihop = $3; if (($3<1) || ($3>255)) cf_error("Multihop must be in range 1-255"); }
|
2013-04-16 17:27:34 +02:00
|
|
|
| bgp_proto NEXT HOP SELF ';' { BGP_CFG->next_hop_self = 1; BGP_CFG->next_hop_keep = 0; }
|
|
|
|
| bgp_proto NEXT HOP KEEP ';' { BGP_CFG->next_hop_keep = 1; BGP_CFG->next_hop_self = 0; }
|
2009-11-18 20:32:36 +01:00
|
|
|
| bgp_proto MISSING LLADDR SELF ';' { BGP_CFG->missing_lladdr = MLL_SELF; }
|
|
|
|
| bgp_proto MISSING LLADDR DROP ';' { BGP_CFG->missing_lladdr = MLL_DROP; }
|
|
|
|
| bgp_proto MISSING LLADDR IGNORE ';' { BGP_CFG->missing_lladdr = MLL_IGNORE; }
|
2010-07-13 12:48:23 +02:00
|
|
|
| bgp_proto GATEWAY DIRECT ';' { BGP_CFG->gw_mode = GW_DIRECT; }
|
|
|
|
| bgp_proto GATEWAY RECURSIVE ';' { BGP_CFG->gw_mode = GW_RECURSIVE; }
|
2000-05-29 22:08:04 +00:00
|
|
|
| bgp_proto PATH METRIC bool ';' { BGP_CFG->compare_path_lengths = $4; }
|
2011-04-22 16:13:27 +02:00
|
|
|
| bgp_proto MED METRIC bool ';' { BGP_CFG->med_metric = $4; }
|
2010-07-31 01:04:32 +02:00
|
|
|
| bgp_proto IGP METRIC bool ';' { BGP_CFG->igp_metric = $4; }
|
2009-11-17 11:41:29 +01:00
|
|
|
| bgp_proto PREFER OLDER bool ';' { BGP_CFG->prefer_older = $4; }
|
2011-12-22 13:20:29 +01:00
|
|
|
| bgp_proto DETERMINISTIC MED bool ';' { BGP_CFG->deterministic_med = $4; }
|
2000-05-15 11:48:23 +00:00
|
|
|
| bgp_proto DEFAULT BGP_MED expr ';' { BGP_CFG->default_med = $4; }
|
|
|
|
| bgp_proto DEFAULT BGP_LOCAL_PREF expr ';' { BGP_CFG->default_local_pref = $4; }
|
|
|
|
| bgp_proto SOURCE ADDRESS ipa ';' { BGP_CFG->source_addr = $4; }
|
2015-02-22 16:08:28 +01:00
|
|
|
| bgp_proto START DELAY TIME expr ';' { BGP_CFG->connect_delay_time = $5; log(L_WARN "%s: Start delay time option is deprecated, use connect delay time", this_proto->name); }
|
|
|
|
| bgp_proto CONNECT DELAY TIME expr ';' { BGP_CFG->connect_delay_time = $5; }
|
|
|
|
| bgp_proto CONNECT RETRY TIME expr ';' { BGP_CFG->connect_retry_time = $5; }
|
|
|
|
| bgp_proto KEEPALIVE TIME expr ';' { BGP_CFG->keepalive_time = $4; }
|
2015-02-21 11:46:14 +01:00
|
|
|
| bgp_proto ERROR FORGET TIME expr ';' { BGP_CFG->error_amnesia_time = $5; }
|
2000-05-15 11:48:23 +00:00
|
|
|
| bgp_proto ERROR WAIT TIME expr ',' expr ';' { BGP_CFG->error_delay_time_min = $5; BGP_CFG->error_delay_time_max = $7; }
|
2000-05-29 22:08:04 +00:00
|
|
|
| bgp_proto DISABLE AFTER ERROR bool ';' { BGP_CFG->disable_after_error = $5; }
|
2009-11-26 20:47:59 +01:00
|
|
|
| bgp_proto ENABLE ROUTE REFRESH bool ';' { BGP_CFG->enable_refresh = $5; }
|
2008-10-26 22:48:02 +01:00
|
|
|
| bgp_proto ENABLE AS4 bool ';' { BGP_CFG->enable_as4 = $4; }
|
2015-07-18 13:38:21 +02:00
|
|
|
| bgp_proto ENABLE EXTENDED MESSAGES bool ';' { BGP_CFG->enable_extended_messages = $5; }
|
2009-03-13 12:49:44 +01:00
|
|
|
| bgp_proto CAPABILITIES bool ';' { BGP_CFG->capabilities = $3; }
|
|
|
|
| bgp_proto ADVERTISE IPV4 bool ';' { BGP_CFG->advertise_ipv4 = $4; }
|
2014-05-29 23:05:03 +02:00
|
|
|
| bgp_proto PASSWORD text ';' { BGP_CFG->password = $3; }
|
2016-04-13 14:30:28 +02:00
|
|
|
| bgp_proto SETKEY bool ';' { BGP_CFG->setkey = $3; }
|
2012-04-15 15:28:29 +02:00
|
|
|
| bgp_proto ROUTE LIMIT expr ';' {
|
|
|
|
this_proto->in_limit = cfg_allocz(sizeof(struct proto_limit));
|
|
|
|
this_proto->in_limit->limit = $4;
|
|
|
|
this_proto->in_limit->action = PLA_RESTART;
|
2015-02-22 16:08:28 +01:00
|
|
|
log(L_WARN "%s: Route limit option is deprecated, use import limit", this_proto->name);
|
2012-04-15 15:28:29 +02:00
|
|
|
}
|
2009-09-24 22:12:11 +02:00
|
|
|
| bgp_proto PASSIVE bool ';' { BGP_CFG->passive = $3; }
|
2010-01-28 15:59:18 +01:00
|
|
|
| bgp_proto INTERPRET COMMUNITIES bool ';' { BGP_CFG->interpret_communities = $4; }
|
2012-04-15 15:07:58 +02:00
|
|
|
| bgp_proto SECONDARY bool ';' { BGP_CFG->secondary = $3; }
|
2012-08-14 16:25:22 +02:00
|
|
|
| bgp_proto ADD PATHS RX ';' { BGP_CFG->add_path = ADD_PATH_RX; }
|
|
|
|
| bgp_proto ADD PATHS TX ';' { BGP_CFG->add_path = ADD_PATH_TX; }
|
|
|
|
| bgp_proto ADD PATHS bool ';' { BGP_CFG->add_path = $4 ? ADD_PATH_FULL : 0; }
|
2013-10-21 14:58:32 +02:00
|
|
|
| bgp_proto ALLOW LOCAL AS ';' { BGP_CFG->allow_local_as = -1; }
|
|
|
|
| bgp_proto ALLOW LOCAL AS expr ';' { BGP_CFG->allow_local_as = $5; }
|
2014-03-20 14:07:12 +01:00
|
|
|
| bgp_proto GRACEFUL RESTART bool ';' { BGP_CFG->gr_mode = $4; }
|
|
|
|
| bgp_proto GRACEFUL RESTART AWARE ';' { BGP_CFG->gr_mode = BGP_GR_AWARE; }
|
|
|
|
| bgp_proto GRACEFUL RESTART TIME expr ';' { BGP_CFG->gr_time = $5; }
|
2010-07-05 17:50:19 +02:00
|
|
|
| bgp_proto IGP TABLE rtable ';' { BGP_CFG->igp_table = $4; }
|
2011-08-16 23:05:35 +02:00
|
|
|
| bgp_proto TTL SECURITY bool ';' { BGP_CFG->ttl_security = $4; }
|
2016-05-26 14:09:08 +02:00
|
|
|
| bgp_proto BGPSEC bool ';' { BGP_CFG->enable_bgpsec = $3; }
|
|
|
|
| bgp_proto BGPSEC_PREFER bool ';' { BGP_CFG->bgpsec_prefer = $3; }
|
|
|
|
| bgp_proto BGPSEC_NO_INVALID_ROUTES bool ';' { BGP_CFG->bgpsec_no_invalid_routes = $3; }
|
|
|
|
| bgp_proto BGPSEC_SKI text ';' { BGP_CFG->bgpsec_ski = $3; }
|
|
|
|
| bgp_proto BGPSEC_KEY_REPO_PATH text ';' { BGP_CFG->bgpsec_key_repo_path = $3; }
|
|
|
|
| bgp_proto BGPSEC_PRIV_KEY_PATH text ';' { BGP_CFG->bgpsec_priv_key_path = $3; }
|
|
|
|
| bgp_proto BGPSEC_SAVE_BINARY_KEYS bool ';' { BGP_CFG->bgpsec_save_binary_keys = $3; }
|
|
|
|
| bgp_proto BGPSEC_NO_PCOUNT0 bool ';' { BGP_CFG->bgpsec_no_pcount0 = $3; }
|
2015-02-21 11:46:14 +01:00
|
|
|
| bgp_proto CHECK LINK bool ';' { BGP_CFG->check_link = $4; }
|
2013-11-19 22:33:48 +01:00
|
|
|
| bgp_proto BFD bool ';' { BGP_CFG->bfd = $3; cf_check_bfd($3); }
|
2000-03-19 22:09:07 +00:00
|
|
|
;
|
|
|
|
|
2000-04-17 12:46:07 +00:00
|
|
|
CF_ADDTO(dynamic_attr, BGP_ORIGIN
|
2000-04-28 15:13:29 +00:00
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_INT, T_ENUM_BGP_ORIGIN, EA_CODE(EAP_BGP, BA_ORIGIN)); })
|
2010-03-29 19:29:03 +02:00
|
|
|
CF_ADDTO(dynamic_attr, BGP_PATH
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_AS_PATH, T_PATH, EA_CODE(EAP_BGP, BA_AS_PATH)); })
|
2000-04-17 12:46:07 +00:00
|
|
|
CF_ADDTO(dynamic_attr, BGP_NEXT_HOP
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_IP_ADDRESS, T_IP, EA_CODE(EAP_BGP, BA_NEXT_HOP)); })
|
2010-03-29 19:29:03 +02:00
|
|
|
CF_ADDTO(dynamic_attr, BGP_MED
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_INT, T_INT, EA_CODE(EAP_BGP, BA_MULTI_EXIT_DISC)); })
|
|
|
|
CF_ADDTO(dynamic_attr, BGP_LOCAL_PREF
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_INT, T_INT, EA_CODE(EAP_BGP, BA_LOCAL_PREF)); })
|
2000-04-17 12:46:07 +00:00
|
|
|
CF_ADDTO(dynamic_attr, BGP_ATOMIC_AGGR
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_OPAQUE, T_ENUM_EMPTY, EA_CODE(EAP_BGP, BA_ATOMIC_AGGR)); })
|
|
|
|
CF_ADDTO(dynamic_attr, BGP_AGGREGATOR
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_INT, T_INT, EA_CODE(EAP_BGP, BA_AGGREGATOR)); })
|
|
|
|
CF_ADDTO(dynamic_attr, BGP_COMMUNITY
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_INT_SET, T_CLIST, EA_CODE(EAP_BGP, BA_COMMUNITY)); })
|
2010-03-29 19:29:03 +02:00
|
|
|
CF_ADDTO(dynamic_attr, BGP_ORIGINATOR_ID
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_ROUTER_ID, T_QUAD, EA_CODE(EAP_BGP, BA_ORIGINATOR_ID)); })
|
|
|
|
CF_ADDTO(dynamic_attr, BGP_CLUSTER_LIST
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_INT_SET, T_CLIST, EA_CODE(EAP_BGP, BA_CLUSTER_LIST)); })
|
2011-08-12 21:03:43 +02:00
|
|
|
CF_ADDTO(dynamic_attr, BGP_EXT_COMMUNITY
|
|
|
|
{ $$ = f_new_dynamic_attr(EAF_TYPE_EC_SET, T_ECLIST, EA_CODE(EAP_BGP, BA_EXT_COMMUNITY)); })
|
|
|
|
|
2010-03-29 19:29:03 +02:00
|
|
|
|
2000-04-12 13:56:04 +00:00
|
|
|
|
2000-04-28 15:13:29 +00:00
|
|
|
CF_ENUM(T_ENUM_BGP_ORIGIN, ORIGIN_, IGP, EGP, INCOMPLETE)
|
|
|
|
|
2000-03-19 22:09:07 +00:00
|
|
|
CF_CODE
|
|
|
|
|
|
|
|
CF_END
|