diff options
author | susheela <susheela.vaidya@vyatta.com> | 2012-09-12 13:51:10 -0700 |
---|---|---|
committer | susheela <susheela.vaidya@vyatta.com> | 2012-09-12 13:51:10 -0700 |
commit | 8f49561fba64718c9437bd0549c0dcc00969d96c (patch) | |
tree | 2a7934181c83519a3ac3cdeb61465b57b7f093cb /templates/protocols | |
parent | aa40d2635185ca0c6ea7d65408222d9dda0a347e (diff) | |
parent | 5588a6fb0aa332ac94df5f2879cab7fbde571aca (diff) | |
download | vyatta-cfg-quagga-8f49561fba64718c9437bd0549c0dcc00969d96c.tar.gz vyatta-cfg-quagga-8f49561fba64718c9437bd0549c0dcc00969d96c.zip |
Merge branch 'pacifica' of git.vyatta.com:/git/vyatta-cfg-quagga into pacifica
Diffstat (limited to 'templates/protocols')
11 files changed, 127 insertions, 0 deletions
diff --git a/templates/protocols/static/table/node.def b/templates/protocols/static/table/node.def new file mode 100644 index 00000000..86ec8a44 --- /dev/null +++ b/templates/protocols/static/table/node.def @@ -0,0 +1,5 @@ +tag: +type: u32 +help: Policy route table number +syntax:expression: $VAR(@) >= 1 && $VAR(@) <= 200; "Must be between (1-200)" +val_help: u32:1-200; Policy route table number diff --git a/templates/protocols/static/table/node.tag/interface-route/node.def b/templates/protocols/static/table/node.tag/interface-route/node.def new file mode 100644 index 00000000..73dd97a3 --- /dev/null +++ b/templates/protocols/static/table/node.tag/interface-route/node.def @@ -0,0 +1,7 @@ +tag: +type: ipv4net +help: Interface based static route +syntax:expression: exec "${vyatta_sbindir}/check_prefix_boundary $VAR(@)" + +commit:expression: $VAR(./next-hop-interface/) != "" ; \ + "Must add a next-hop-interface for route $VAR(@)" diff --git a/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.def b/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.def new file mode 100644 index 00000000..255e572d --- /dev/null +++ b/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.def @@ -0,0 +1,34 @@ +tag: +type: txt +help: Next-hop interface [REQUIRED] +# show all current interface +# but syntax accepts any interface since it may exist later (ppp etc) +allowed: ${vyatta_sbindir}/vyatta-interfaces.pl --show all + + +end: + if [[ -n "$VAR(../../../table/@)" ]] + then + table="table $VAR(../../../table/@)" + fi + if [[ -z "$VAR(./disable)" ]] + then + if [[ ${COMMIT_ACTION} = 'DELETE' ]] + then + if ! ${vyatta_sbindir}/vyatta-next-hop-check $VAR(../@) ipv4 interface; then + exit 1; + fi + vtysh -c "configure terminal" \ + -c "no ip route $VAR(../@) $VAR(@) $table" + else + if [[ -n "$VAR(./distance/@)" ]] + then + dist="$VAR(./distance/@)" + fi + vtysh -c "configure terminal" \ + -c "ip route $VAR(../@) $VAR(@) $table $dist"; + fi + else + vtysh -c "configure terminal" \ + -c "no ip route $VAR(../@) $VAR(@) $table" + fi diff --git a/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.tag/disable/node.def b/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.tag/disable/node.def new file mode 100644 index 00000000..92f2ba51 --- /dev/null +++ b/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.tag/disable/node.def @@ -0,0 +1 @@ +help: Disable IPv4 interface static route diff --git a/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.tag/distance/node.def b/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.tag/distance/node.def new file mode 100644 index 00000000..61abcc65 --- /dev/null +++ b/templates/protocols/static/table/node.tag/interface-route/node.tag/next-hop-interface/node.tag/distance/node.def @@ -0,0 +1,4 @@ +type: u32 +help: Distance value for this route +syntax:expression: $VAR(@) >= 1 && $VAR(@) <= 255; "Must be between (1-255)" +val_help: u32:1-255; Distance for this route diff --git a/templates/protocols/static/table/node.tag/route/node.def b/templates/protocols/static/table/node.tag/route/node.def new file mode 100644 index 00000000..682ca944 --- /dev/null +++ b/templates/protocols/static/table/node.tag/route/node.def @@ -0,0 +1,7 @@ +tag: +type: ipv4net +help: Static route +syntax:expression: exec "${vyatta_sbindir}/check_prefix_boundary $VAR(@)" + +commit:expression: $VAR(./next-hop/) != "" || $VAR(./blackhole/) != ""; \ + "Must add either a next-hop or blackhole for route $VAR(@)" diff --git a/templates/protocols/static/table/node.tag/route/node.tag/blackhole/distance/node.def b/templates/protocols/static/table/node.tag/route/node.tag/blackhole/distance/node.def new file mode 100644 index 00000000..61abcc65 --- /dev/null +++ b/templates/protocols/static/table/node.tag/route/node.tag/blackhole/distance/node.def @@ -0,0 +1,4 @@ +type: u32 +help: Distance value for this route +syntax:expression: $VAR(@) >= 1 && $VAR(@) <= 255; "Must be between (1-255)" +val_help: u32:1-255; Distance for this route diff --git a/templates/protocols/static/table/node.tag/route/node.tag/blackhole/node.def b/templates/protocols/static/table/node.tag/route/node.tag/blackhole/node.def new file mode 100644 index 00000000..06dbe5ae --- /dev/null +++ b/templates/protocols/static/table/node.tag/route/node.tag/blackhole/node.def @@ -0,0 +1,22 @@ +help: Silently discard pkts when matched + +end: + if [[ -n "$VAR(../../../table/@)" ]] + then + table="table $VAR(../../../table/@)" + fi + if [ ${COMMIT_ACTION} = 'DELETE' ]; then + if ! ${vyatta_sbindir}/vyatta-next-hop-check $VAR(../@) ipv4 address; then + exit 1; + fi + + vtysh -c "configure terminal" \ + -c "no ip route $VAR(../@) null0 $table"; + else + if [ -n "$VAR(./distance/@)" ]; then + dist="$VAR(./distance/@)"; + fi; + + vtysh -c "configure terminal" \ + -c "ip route $VAR(../@) null0 $table $dist"; + fi; diff --git a/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.def b/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.def new file mode 100644 index 00000000..5fb54a8b --- /dev/null +++ b/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.def @@ -0,0 +1,38 @@ +tag: +type: ipv4 +help: Next-hop router [REQUIRED] +end: + if [[ -n "$VAR(../../../table/@)" ]] + then + table="table $VAR(../../../table/@)" + fi + if [[ -z "$VAR(./disable)" ]] + then + if [[ ${COMMIT_ACTION} = 'DELETE' ]] + then + if ! ${vyatta_sbindir}/vyatta-next-hop-check $VAR(../@) ipv4 address; then + exit 1; + fi + if ${vyatta_sbindir}/vyatta-gateway-static_route-check.pl \ + "$VAR(../@)" "$VAR(@)" + then + vtysh -c "configure terminal" \ + -c "no ip route $VAR(../@) $VAR(@) $table" + fi + else + if [[ -n "$VAR(./distance/@)" ]] + then + dist="$VAR(./distance/@)" + fi + vtysh -c "configure terminal" \ + -c "ip route $VAR(../@) $VAR(@) $table $dist"; + fi + else + if ${vyatta_sbindir}/vyatta-gateway-static_route-check.pl \ + "$VAR(../@)" "$VAR(@)" + then + vtysh -c "configure terminal" \ + -c "no ip route $VAR(../@) $VAR(@) $table" + fi + fi + diff --git a/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.tag/disable/node.def b/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.tag/disable/node.def new file mode 100644 index 00000000..de3afda4 --- /dev/null +++ b/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.tag/disable/node.def @@ -0,0 +1 @@ +help: Disable IPv4 next-hop static route diff --git a/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.tag/distance/node.def b/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.tag/distance/node.def new file mode 100644 index 00000000..61abcc65 --- /dev/null +++ b/templates/protocols/static/table/node.tag/route/node.tag/next-hop/node.tag/distance/node.def @@ -0,0 +1,4 @@ +type: u32 +help: Distance value for this route +syntax:expression: $VAR(@) >= 1 && $VAR(@) <= 255; "Must be between (1-255)" +val_help: u32:1-255; Distance for this route |