summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--templates/interfaces/l2tpv3/node.def49
-rw-r--r--templates/interfaces/l2tpv3/node.tag/bridge-group/bridge/node.def12
-rw-r--r--templates/interfaces/l2tpv3/node.tag/bridge-group/cost/node.def4
-rw-r--r--templates/interfaces/l2tpv3/node.tag/bridge-group/node.def3
-rw-r--r--templates/interfaces/l2tpv3/node.tag/bridge-group/priority/node.def4
-rw-r--r--templates/interfaces/l2tpv3/node.tag/dport/node.def6
-rw-r--r--templates/interfaces/l2tpv3/node.tag/encap/node.def7
-rw-r--r--templates/interfaces/l2tpv3/node.tag/endpoint/local-ip/node.def6
-rw-r--r--templates/interfaces/l2tpv3/node.tag/endpoint/node.def1
-rw-r--r--templates/interfaces/l2tpv3/node.tag/endpoint/remote-ip/node.def6
-rw-r--r--templates/interfaces/l2tpv3/node.tag/local-ip/node.def8
-rw-r--r--templates/interfaces/l2tpv3/node.tag/peer-session-id/node.def5
-rw-r--r--templates/interfaces/l2tpv3/node.tag/peer-tunnel-id/node.def5
-rw-r--r--templates/interfaces/l2tpv3/node.tag/remote-ip/node.def4
-rw-r--r--templates/interfaces/l2tpv3/node.tag/session-id/node.def5
-rw-r--r--templates/interfaces/l2tpv3/node.tag/sport/node.def6
-rw-r--r--templates/interfaces/l2tpv3/node.tag/tunnel-id/node.def5
-rw-r--r--templates/interfaces/l2tpv3/node.tag/wait/node.def6
18 files changed, 142 insertions, 0 deletions
diff --git a/templates/interfaces/l2tpv3/node.def b/templates/interfaces/l2tpv3/node.def
new file mode 100644
index 00000000..924d27b7
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.def
@@ -0,0 +1,49 @@
+tag:
+priority: 380
+type: txt
+help: l2tpv3 interface
+val_help: <l2tpethN>; l2tpv3 interface name
+syntax:expression: pattern $VAR(@) "^l2tpeth[0-9]+$" \
+ ; "tunnel must be (l2tpeth0-l2tpeth999)"
+
+commit:expression: $VAR(./local-ip/) != "" ; \
+ "Must configure the l2tpv3 local-ip for $VAR(@)"
+commit:expression: $VAR(./remote-ip/) != "" ; \
+ "Must configure the l2tpv3 remote-ip for $VAR(@)"
+commit:expression: $VAR(./endpoint/local-ip/) != "" ; \
+ "Must configure the l2tpv3 endpoint local-ip for $VAR(@)"
+commit:expression: $VAR(./endpoint/remote-ip/) != "" ; \
+ "Must configure the l2tpv3 endpoint remote-ip for $VAR(@)"
+commit:expression: $VAR(./tunnel-id/) != "" ; \
+ "Must configure the l2tpv3 tunnel-id for $VAR(@)"
+commit:expression: $VAR(./peer-tunnel-id/) != "" ; \
+ "Must configure the l2tpv3 peer-tunnel-id for $VAR(@)"
+commit:expression: $VAR(./session-id/) != "" ; \
+ "Must configure the l2tpv3 session-id for $VAR(@)"
+commit:expression: $VAR(./peer-session-id/) != "" ; \
+ "Must configure the l2tpv3 peer-session-id for $VAR(@)"
+
+begin:
+ [ -d /sys/module/l2tp_eth ] || sudo modprobe l2tp_eth
+ [ -d /sys/module/l2tp_netlink ] || sudo modprobe l2tp_netlink
+
+create:
+ for i in `seq 1 $VAR(./wait/@)`
+ do
+ ping -c 1 $VAR(./remote-ip/@) > /dev/null 2>&1 && break
+ sleep 1
+ done
+ ip l2tp add tunnel tunnel_id $VAR(./tunnel-id/@) peer_tunnel_id $VAR(./peer-tunnel-id/@) udp_sport $VAR(./sport/@) udp_dport $VAR(./dport/@) encap $VAR(./encap/@) local $VAR(./local-ip/@) remote $VAR(./remote-ip/@) ||
+ echo "ip l2tp add tunnel tunnel_id $VAR(./tunnel-id/@) peer_tunnel_id $VAR(./peer-tunnel-id/@) udp_sport $VAR(./sport/@) udp_dport $VAR(./dport/@) encap $VAR(./encap/@) local $VAR(./local-ip/@) remote $VAR(./remote-ip/@)"
+ ip l2tp add session tunnel_id $VAR(./tunnel-id/@) session_id $VAR(./session-id/@) peer_session_id $VAR(./peer-session-id/@) || echo "ip l2tp add session tunnel_id $VAR(./tunnel-id/@) session_id $VAR(./session-id/@) peer_session_id $VAR(./peer-session-id/@)"
+ ip addr add $VAR(./endpoint/local-ip/@) peer $VAR(./endpoint/remote-ip/@) dev $VAR(@) || echo "ip addr add $VAR(./endpoint/local-ip/@) peer $VAR(./endpoint/remote-ip/@) dev $VAR(@)"
+ ip link set $VAR(@) up mtu 1500
+
+delete:
+ ip link set $VAR(@) down
+ if [ -n "$VAR(./tunnel-id@/)" ] && [ -n "$VAR(./session-id@/)" ] ; then
+ ip l2tp del session $VAR(./tunnel-id/@) session_id $VAR(./session-id/@)
+ fi
+ if [ -n "$VAR(./tunnel-id@/)" ] ; then
+ ip l2tp del tunnel tunnel_id $VAR(./tunnel-id/@)
+ fi
diff --git a/templates/interfaces/l2tpv3/node.tag/bridge-group/bridge/node.def b/templates/interfaces/l2tpv3/node.tag/bridge-group/bridge/node.def
new file mode 100644
index 00000000..d58e8f07
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/bridge-group/bridge/node.def
@@ -0,0 +1,12 @@
+type: txt
+
+help: Bridge group name
+
+syntax:expression: pattern $VAR(@) "^br[0-9]+$" \
+ ; "$VAR(@): not a valid name for a bridge"
+
+commit:expression: exec \
+ "/opt/vyatta/sbin/vyatta-interfaces.pl --dev=$VAR(@) --check=bridge"
+
+allowed: /opt/vyatta/sbin/vyatta-interfaces.pl --show=bridge
+
diff --git a/templates/interfaces/l2tpv3/node.tag/bridge-group/cost/node.def b/templates/interfaces/l2tpv3/node.tag/bridge-group/cost/node.def
new file mode 100644
index 00000000..22bac5a2
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/bridge-group/cost/node.def
@@ -0,0 +1,4 @@
+type: u32
+help: Bridge port cost
+syntax:expression: $VAR(@) >= 1 && $VAR(@) < 65536 ; "Bridge cost value must be between 1 and 65535"
+val_help: u32:1-65535; Path cost value for Spanning Tree Protocol
diff --git a/templates/interfaces/l2tpv3/node.tag/bridge-group/node.def b/templates/interfaces/l2tpv3/node.tag/bridge-group/node.def
new file mode 100644
index 00000000..74ecab4d
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/bridge-group/node.def
@@ -0,0 +1,3 @@
+help: Add this interface to a bridge group
+
+end: /opt/vyatta/sbin/vyatta-bridge.pl ${COMMIT_ACTION} $VAR(../@)
diff --git a/templates/interfaces/l2tpv3/node.tag/bridge-group/priority/node.def b/templates/interfaces/l2tpv3/node.tag/bridge-group/priority/node.def
new file mode 100644
index 00000000..be0ff479
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/bridge-group/priority/node.def
@@ -0,0 +1,4 @@
+type: u32
+help: Bridge port priority
+syntax:expression: $VAR(@) >= 0 &&$VAR(@) < 64; "Port priority must be between 0-63"
+val_help: u32:0-63; Bridge port priority
diff --git a/templates/interfaces/l2tpv3/node.tag/dport/node.def b/templates/interfaces/l2tpv3/node.tag/dport/node.def
new file mode 100644
index 00000000..1dac1418
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/dport/node.def
@@ -0,0 +1,6 @@
+help: Source port
+type: u32
+default: 5000
+syntax:expression: ($VAR(@) >= 1 && $VAR(@) <= 65535) ; "must between 1-65535"
+
+val_help: u32:1-65535; Numbered port
diff --git a/templates/interfaces/l2tpv3/node.tag/encap/node.def b/templates/interfaces/l2tpv3/node.tag/encap/node.def
new file mode 100644
index 00000000..c3726314
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/encap/node.def
@@ -0,0 +1,7 @@
+help: Encryption algorithm
+type: txt
+default: "udp"
+syntax:expression: $VAR(@) in "ip", "udp"; "must be ip, or udp"
+
+val_help: udp; udp encryption (default)
+val_help: ip; ip encryption
diff --git a/templates/interfaces/l2tpv3/node.tag/endpoint/local-ip/node.def b/templates/interfaces/l2tpv3/node.tag/endpoint/local-ip/node.def
new file mode 100644
index 00000000..f443d9ec
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/endpoint/local-ip/node.def
@@ -0,0 +1,6 @@
+type: ipv4net, ipv6net
+help: Endpoint IP address for this l2tpv3 [REQUIRED]
+val_help: ipv4net; Endpoint IPv4 address for this l2tpv3 [REQUIRED]
+val_help: ipv6net; Endpoint IPv6 address for this l2tpv3 [REQUIRED]
+
+syntax:expression: exec "/opt/vyatta/sbin/valid_address $VAR(@)"
diff --git a/templates/interfaces/l2tpv3/node.tag/endpoint/node.def b/templates/interfaces/l2tpv3/node.tag/endpoint/node.def
new file mode 100644
index 00000000..d199b6f6
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/endpoint/node.def
@@ -0,0 +1 @@
+help: l2tpv3 of Endpoint IP address
diff --git a/templates/interfaces/l2tpv3/node.tag/endpoint/remote-ip/node.def b/templates/interfaces/l2tpv3/node.tag/endpoint/remote-ip/node.def
new file mode 100644
index 00000000..6e1bcf80
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/endpoint/remote-ip/node.def
@@ -0,0 +1,6 @@
+type: ipv4net, ipv6net
+help: Peer Endpoint IP address for this l2tpv3 [REQUIRED]
+val_help: ipv4net; Peer Endpoint IPv4 address for this l2tpv3 [REQUIRED]
+val_help: ipv6net; Peer Endpoint IPv6 address for this l2tpv3 [REQUIRED]
+
+syntax:expression: exec "/opt/vyatta/sbin/valid_address $VAR(@)"
diff --git a/templates/interfaces/l2tpv3/node.tag/local-ip/node.def b/templates/interfaces/l2tpv3/node.tag/local-ip/node.def
new file mode 100644
index 00000000..3dfc3816
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/local-ip/node.def
@@ -0,0 +1,8 @@
+type: ipv4, ipv6
+help: Local IP address for this l2tpv3 [REQUIRED]
+val_help: ipv4; Local IPv4 address for this l2tpv3 [REQUIRED]
+val_help: ipv6; Local IPv6 address for this l2tpv3 [REQUIRED]
+
+syntax:expression: exec \
+ "/opt/vyatta/sbin/local_ip $VAR(@) || \
+ echo Warning! IP address $VAR(@) doesn\\'t exist on this system"
diff --git a/templates/interfaces/l2tpv3/node.tag/peer-session-id/node.def b/templates/interfaces/l2tpv3/node.tag/peer-session-id/node.def
new file mode 100644
index 00000000..decdf6ea
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/peer-session-id/node.def
@@ -0,0 +1,5 @@
+help: l2tpv3 peer-session-id [REQUIRED]
+type: u32
+
+syntax:expression: ($VAR(@) >= 1 && $VAR(@) <= 429496729) ; "must between 1-429496729"
+val_help: u32:1-429496729; l2tpv3 peer-session-id [REQUIRED]
diff --git a/templates/interfaces/l2tpv3/node.tag/peer-tunnel-id/node.def b/templates/interfaces/l2tpv3/node.tag/peer-tunnel-id/node.def
new file mode 100644
index 00000000..fa734902
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/peer-tunnel-id/node.def
@@ -0,0 +1,5 @@
+help: l2tpv3 peer-tunnel-id [REQUIRED]
+type: u32
+
+syntax:expression: ($VAR(@) >= 1 && $VAR(@) <= 429496729) ; "must between 1-429496729"
+val_help: u32:1-429496729; l2tpv3 peer-tunnel-id [REQUIRED]
diff --git a/templates/interfaces/l2tpv3/node.tag/remote-ip/node.def b/templates/interfaces/l2tpv3/node.tag/remote-ip/node.def
new file mode 100644
index 00000000..806f6a94
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/remote-ip/node.def
@@ -0,0 +1,4 @@
+type: ipv4, ipv6
+help: Remote IP address for this l2tpv3 [REQUIRED]
+val_help: ipv4; Remote IPv4 address for this l2tpv3 [REQUIRED]
+val_help: ipv6; Remote IPv6 address for this l2tpv3 [REQUIRED]
diff --git a/templates/interfaces/l2tpv3/node.tag/session-id/node.def b/templates/interfaces/l2tpv3/node.tag/session-id/node.def
new file mode 100644
index 00000000..ad4a22f9
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/session-id/node.def
@@ -0,0 +1,5 @@
+help: l2tpv3 session-id [REQUIRED]
+type: u32
+
+syntax:expression: ($VAR(@) >= 1 && $VAR(@) <= 429496729) ; "must between 1-429496729"
+val_help: u32:1-429496729; l2tpv3 session-id [REQUIRED]
diff --git a/templates/interfaces/l2tpv3/node.tag/sport/node.def b/templates/interfaces/l2tpv3/node.tag/sport/node.def
new file mode 100644
index 00000000..a9ccfe49
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/sport/node.def
@@ -0,0 +1,6 @@
+help: Destination port
+type: u32
+default: 5000
+syntax:expression: ($VAR(@) >= 1 && $VAR(@) <= 65535) ; "must between 1-65535"
+
+val_help: u32:1-65535; Numbered port
diff --git a/templates/interfaces/l2tpv3/node.tag/tunnel-id/node.def b/templates/interfaces/l2tpv3/node.tag/tunnel-id/node.def
new file mode 100644
index 00000000..b4cdc752
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/tunnel-id/node.def
@@ -0,0 +1,5 @@
+help: l2tpv3 tunnel-id [REQUIRED]
+type: u32
+
+syntax:expression: ($VAR(@) >= 1 && $VAR(@) <= 429496729) ; "must between 1-429496729"
+val_help: u32:1-429496729; l2tpv3 tunnel-id
diff --git a/templates/interfaces/l2tpv3/node.tag/wait/node.def b/templates/interfaces/l2tpv3/node.tag/wait/node.def
new file mode 100644
index 00000000..53044eea
--- /dev/null
+++ b/templates/interfaces/l2tpv3/node.tag/wait/node.def
@@ -0,0 +1,6 @@
+help: Wait count
+type: u32
+default: 30
+syntax:expression: ($VAR(@) >= 5 && $VAR(@) <= 300) ; "must be in the range 5 to 300 seconds"
+
+val_help: u32:5-300 wait (default 30)