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