Ver código fonte

Remove previous mesh tunnel

Bob Mottram 7 anos atrás
pai
commit
30fcc2c469
1 arquivos alterados com 0 adições e 120 exclusões
  1. 0
    120
      src/freedombone-app-batman

+ 0
- 120
src/freedombone-app-batman Ver arquivo

@@ -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