|
@@ -137,126 +137,6 @@ function mesh_install_batman {
|
137
|
137
|
chroot "$rootdir" systemctl enable batman
|
138
|
138
|
}
|
139
|
139
|
|
140
|
|
-function install_mesh_tunnel {
|
141
|
|
- # https://sudoroom.org/wiki/Mesh/Relay_setup
|
142
|
|
- chroot "$rootdir" apt-get -yq install xl2tpd l2tpns libnl-3-dev libnl-3-200
|
143
|
|
- chroot "$rootdir" apt-get -yq install iproute bridge-utils libnetfilter-conntrack3 python-dev libevent-dev ebtables python-pip git
|
144
|
|
-
|
145
|
|
- git clone https://github.com/wlanslovenija/tunneldigger $rootdir/opt/tunneldigger
|
146
|
|
- if [ ! -d $rootdir/opt/tunneldigger/client ]; then
|
147
|
|
- echo $'Unable to clone tunneldigger repo'
|
148
|
|
- exit 1987453
|
149
|
|
- fi
|
150
|
|
- sed -i 's|-I. |-I. -I/usr/include/libnl3 |g' $rootdir/opt/tunneldigger/client/Makefile
|
151
|
|
- echo '#!/bin/bash' > $rootdir/opt/tunneldigger/buildtunnel.sh
|
152
|
|
- echo 'cd /opt/tunneldigger/client' >> $rootdir/opt/tunneldigger/buildtunnel.sh
|
153
|
|
- echo 'make' >> $rootdir/opt/tunneldigger/buildtunnel.sh
|
154
|
|
- chmod +x $rootdir/opt/tunneldigger/buildtunnel.sh
|
155
|
|
- chroot "$rootdir" /opt/tunneldigger/buildtunnel.sh
|
156
|
|
- if [ ! -f $rootdir/opt/tunneldigger/client/l2tp_client ]; then
|
157
|
|
- echo $'tunneldigger failed to build client'
|
158
|
|
- exit 823563
|
159
|
|
- fi
|
160
|
|
- rm $rootdir/opt/tunneldigger/buildtunnel.sh
|
161
|
|
- cd $rootdir/opt/tunneldigger/broker
|
162
|
|
- chroot "$rootdir" pip install -r requirements.txt
|
163
|
|
- echo 'l2tp_core' >> $rootdir/etc/modules
|
164
|
|
- echo 'l2tp_eth' >> $rootdir/etc/modules
|
165
|
|
- echo 'l2tp_netlink' >> $rootdir/etc/modules
|
166
|
|
-
|
167
|
|
- echo '#!/bin/sh' > $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
168
|
|
- echo 'INTERFACE="$3"' >> $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
169
|
|
- echo 'ifconfig $INTERFACE up' >> $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
170
|
|
- echo 'batctl if add $INTERFACE' >> $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
171
|
|
- echo 'if [ `cat /sys/class/net/bat0/operstate` != "up" ]; then' >> $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
172
|
|
- echo " ipv4addr=\$(ip -o -f inet addr show dev \"eth0\" | awk '{print \$4}' | awk 'END {print}' | awk -F '/' '{print \$1}')" >> $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
173
|
|
- echo ' ifconfig bat0 $ipv4addr netmask 255.0.0.0 up' >> $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
174
|
|
- echo 'fi' >> $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
175
|
|
- chmod +x $rootdir/opt/tunneldigger/broker/scripts/up_hook.sh
|
176
|
|
-
|
177
|
|
- echo '[broker]' > $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
178
|
|
- echo '; IP address the broker will listen and accept tunnels on' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
179
|
|
- echo 'address=127.0.0.1' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
180
|
|
- echo '; Ports where the broker will listen on' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
181
|
|
- echo 'port=53,8942' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
182
|
|
- echo '; Interface with that IP address' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
183
|
|
- echo 'interface=lo' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
184
|
|
- echo '; Maximum number of tunnels that will be allowed by the broker' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
185
|
|
- echo 'max_tunnels=1024' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
186
|
|
- echo '; Tunnel port base' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
187
|
|
- echo 'port_base=20000' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
188
|
|
- echo '; Tunnel id base' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
189
|
|
- echo 'tunnel_id_base=100' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
190
|
|
- echo '; Namespace (for running multiple brokers); note that you must also' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
191
|
|
- echo '; configure disjunct ports, and tunnel identifiers in order for' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
192
|
|
- echo '; namespacing to work' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
193
|
|
- echo 'namespace=default' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
194
|
|
- echo '; check if all kernel module are loaded. Do not check for built-ins.' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
195
|
|
- echo 'check_modules=true' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
196
|
|
- echo '' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
197
|
|
- echo '[log]' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
198
|
|
- echo '; Log filename' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
199
|
|
- echo 'filename=tunneldigger-broker.log' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
200
|
|
- echo '; Verbosity' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
201
|
|
- echo 'verbosity=DEBUG' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
202
|
|
- echo '; Should IP addresses be logged or not' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
203
|
|
- echo 'log_ip_addresses=false' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
204
|
|
- echo '' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
205
|
|
- echo '[hooks]' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
206
|
|
- echo '; Arguments to the session.{up,pre-down,down} hooks are as follows:' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
207
|
|
- echo ';' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
208
|
|
- echo '; <tunnel_id> <session_id> <interface> <mtu> <endpoint_ip> <endpoint_port> <local_port>' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
209
|
|
- echo ';' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
210
|
|
- echo '; Arguments to the session.mtu-changed hook are as follows:' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
211
|
|
- echo ';' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
212
|
|
- echo '; <tunnel_id> <session_id> <interface> <old_mtu> <new_mtu>' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
213
|
|
- echo ';' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
214
|
|
- echo '' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
215
|
|
- echo '; Called after the tunnel interface goes up' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
216
|
|
- echo 'session.up=/opt/tunneldigger/broker/scripts/up_hook.sh' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
217
|
|
- echo '; Called just before the tunnel interface goes down' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
218
|
|
- echo 'session.pre-down=' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
219
|
|
- echo '; Called after the tunnel interface goes down' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
220
|
|
- echo 'session.down=' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
221
|
|
- echo '; Called after the tunnel MTU gets changed because of PMTU discovery' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
222
|
|
- echo 'session.mtu-changed=' >> $rootdir/opt/tunneldigger/broker/l2tp_broker.cfg
|
223
|
|
-
|
224
|
|
- echo '[Unit]' > $rootdir/etc/systemd/system/tunneldigger.service
|
225
|
|
- echo 'Description=TunnelDigger Broker' >> $rootdir/etc/systemd/system/tunneldigger.service
|
226
|
|
- echo 'After=syslog.target' >> $rootdir/etc/systemd/system/tunneldigger.service
|
227
|
|
- echo 'After=network.target' >> $rootdir/etc/systemd/system/tunneldigger.service
|
228
|
|
- echo '' >> $rootdir/etc/systemd/system/tunneldigger.service
|
229
|
|
- echo '[Service]' >> $rootdir/etc/systemd/system/tunneldigger.service
|
230
|
|
- echo 'Type=simple' >> $rootdir/etc/systemd/system/tunneldigger.service
|
231
|
|
- echo 'User=root' >> $rootdir/etc/systemd/system/tunneldigger.service
|
232
|
|
- echo 'Group=root' >> $rootdir/etc/systemd/system/tunneldigger.service
|
233
|
|
- echo 'WorkingDirectory=/opt/tunneldigger/broker' >> $rootdir/etc/systemd/system/tunneldigger.service
|
234
|
|
- echo 'ExecStart=/opt/tunneldigger/broker/l2tp_broker.py l2tp_broker.cfg' >> $rootdir/etc/systemd/system/tunneldigger.service
|
235
|
|
- echo 'Restart=always' >> $rootdir/etc/systemd/system/tunneldigger.service
|
236
|
|
- echo 'RestartSec=60' >> $rootdir/etc/systemd/system/tunneldigger.service
|
237
|
|
- echo '' >> $rootdir/etc/systemd/system/tunneldigger.service
|
238
|
|
- echo '[Install]' >> $rootdir/etc/systemd/system/tunneldigger.service
|
239
|
|
- echo 'WantedBy=multi-user.target' >> $rootdir/etc/systemd/system/tunneldigger.service
|
240
|
|
-
|
241
|
|
- echo '#!/bin/bash' > $rootdir/usr/bin/meshtunnel
|
242
|
|
- echo 'if [ ! $1 ]; then' >> $rootdir/usr/bin/meshtunnel
|
243
|
|
- echo ' echo "Syntax: meshtunnel [from external IP] [to external IP]"' >> $rootdir/usr/bin/meshtunnel
|
244
|
|
- echo ' exit 1' >> $rootdir/usr/bin/meshtunnel
|
245
|
|
- echo 'fi' >> $rootdir/usr/bin/meshtunnel
|
246
|
|
- echo 'if [ ! $2 ]; then' >> $rootdir/usr/bin/meshtunnel
|
247
|
|
- echo ' echo "Syntax: meshtunnel [from external IP] [to external IP]"' >> $rootdir/usr/bin/meshtunnel
|
248
|
|
- echo ' exit 2' >> $rootdir/usr/bin/meshtunnel
|
249
|
|
- echo 'fi' >> $rootdir/usr/bin/meshtunnel
|
250
|
|
- echo '' >> $rootdir/usr/bin/meshtunnel
|
251
|
|
- echo 'sed -i "s|address=.*|address=$1|g" /opt/tunneldigger/broker/l2tp_broker.cfg' >> $rootdir/usr/bin/meshtunnel
|
252
|
|
- echo 'systemctl restart tunneldigger' >> $rootdir/usr/bin/meshtunnel
|
253
|
|
- echo 'sleep 3' >> $rootdir/usr/bin/meshtunnel
|
254
|
|
- echo 'cd /opt/tunneldigger/client' >> $rootdir/usr/bin/meshtunnel
|
255
|
|
- echo './l2tp_client -f -u foo -l ${2}:53 -i l2tp' >> $rootdir/usr/bin/meshtunnel
|
256
|
|
- echo 'exit 0' >> $rootdir/usr/bin/meshtunnel
|
257
|
|
- chmod +x $rootdir/usr/bin/meshtunnel
|
258
|
|
-}
|
259
|
|
-
|
260
|
140
|
function install_batman {
|
261
|
141
|
if [ $INSTALLING_MESH ]; then
|
262
|
142
|
mesh_install_batman
|