浏览代码

Merge branch 'stretch' of https://github.com/bashrc/freedombone

Bob Mottram 7 年前
父节点
当前提交
be89e042c9
共有 3 个文件被更改,包括 64 次插入2 次删除
  1. 46
    0
      src/freedombone-image-customise
  2. 4
    0
      src/freedombone-image-mesh
  3. 14
    2
      src/freedombone-mesh-batman

+ 46
- 0
src/freedombone-image-customise 查看文件

@@ -125,6 +125,9 @@ ENABLE_ZERONET=
125 125
 
126 126
 MESH_TEXT_EDITOR='pluma'
127 127
 
128
+OLSR2_REPO="https://github.com/OLSR/OONF"
129
+OLSR2_COMMIT='81033251c4ee1c5699bfee9d2985112c6266ab0a'
130
+
128 131
 BMX6_REPO="https://github.com/bmx-routing/bmx6"
129 132
 BMX6_COMMIT='39dd1f2d99ac5a3fa28e92f8173c15039132e181'
130 133
 
@@ -668,6 +671,48 @@ mesh_shutdown_script() {
668 671
     chroot "$rootdir" systemctl enable meshshutdown
669 672
 }
670 673
 
674
+install_olsr2() {
675
+    chroot "$rootdir" apt-get -yq install cmake libnl-3-dev
676
+
677
+    git clone $OLSR2_REPO $rootdir/etc/olsr2
678
+
679
+    cat <<EOF > $rootdir/usr/bin/install_olsr2
680
+#!/bin/bash
681
+cd /etc/olsr2
682
+git checkout $OLSR2_COMMIT -b $OLSR2_COMMIT
683
+cd /etc/olsr2/build
684
+cmake ..
685
+make
686
+make install
687
+EOF
688
+    chroot "$rootdir" chmod +x /usr/bin/install_olsr2
689
+    chroot "$rootdir" /usr/bin/install_olsr2
690
+
691
+    if [ ! -f $rootdir/usr/local/sbin/olsrd2_static ]; then
692
+        echo $'Unable to build OLSR2'
693
+        exit 79835392
694
+    fi
695
+
696
+    rm $rootdir/usr/bin/install_olsr2
697
+
698
+    echo '[Unit]' > $rootdir/etc/systemd/system/olsr2.service
699
+    echo 'Description=OLSR2 mesh routing protocol' >> $rootdir/etc/systemd/system/olsr2.service
700
+    echo 'Requires=network.target' >> $rootdir/etc/systemd/system/olsr2.service
701
+    echo 'After=network.target' >> $rootdir/etc/systemd/system/olsr2.service
702
+    echo '' >> $rootdir/etc/systemd/system/olsr2.service
703
+    echo '[Service]' >> $rootdir/etc/systemd/system/olsr2.service
704
+    echo 'Type=forking' >> $rootdir/etc/systemd/system/olsr2.service
705
+    echo 'User=root' >> $rootdir/etc/systemd/system/olsr2.service
706
+    echo 'Group=root' >> $rootdir/etc/systemd/system/olsr2.service
707
+    echo 'ExecStart=/usr/local/sbin/olsrd2_static wlan0' >> $rootdir/etc/systemd/system/olsr2.service
708
+    echo 'ExecStop=/usr/bin/kill -15 $MAINPID' >> $rootdir/etc/systemd/system/olsr2.service
709
+    echo 'PIDFile=/var/run/olsr2/pid' >> $rootdir/etc/systemd/system/olsr2.service
710
+    echo 'Restart=on-failure' >> $rootdir/etc/systemd/system/olsr2.service
711
+    echo '' >> $rootdir/etc/systemd/system/olsr2.service
712
+    echo '[Install]' >> $rootdir/etc/systemd/system/olsr2.service
713
+    echo 'WantedBy=multi-user.target' >> $rootdir/etc/systemd/system/olsr2.service
714
+}
715
+
671 716
 install_bmx6() {
672 717
     git clone $BMX6_REPO $rootdir/etc/bmx6
673 718
 
@@ -853,6 +898,7 @@ initialise_mesh() {
853 898
     install_batman
854 899
     install_bmx6
855 900
     install_bmx7
901
+    install_olsr2
856 902
     mesh_shutdown_script
857 903
     install_vpn
858 904
     install_tomb

+ 4
- 0
src/freedombone-image-mesh 查看文件

@@ -1423,6 +1423,10 @@ if [ -f $MESH_INSTALL_SETUP ]; then
1423 1423
     systemctl disable bmx7
1424 1424
     echo $'BMX7 disabled' >> $INSTALL_LOG
1425 1425
 
1426
+    systemctl stop olsr2
1427
+    systemctl disable olsr2
1428
+    echo $'OLSR2 disabled' >> $INSTALL_LOG
1429
+
1426 1430
     #tomb slam all
1427 1431
     tmp_ram_disk 100
1428 1432
     enable_predictable_device_names

+ 14
- 2
src/freedombone-mesh-batman 查看文件

@@ -54,7 +54,8 @@ function status {
54 54
 
55 55
     if grep -q "bmx6" $MESH_CURRENT_PROTOCOL; then
56 56
         bmx6 -c show=originators
57
-    else
57
+    fi
58
+    if grep -q "bmx7" $MESH_CURRENT_PROTOCOL; then
58 59
         bmx7 -c show=originators
59 60
     fi
60 61
 }
@@ -71,8 +72,10 @@ function stop {
71 72
 
72 73
     systemctl stop bmx6
73 74
     systemctl stop bmx7
75
+    systemctl stop olsr2
74 76
     systemctl disable bmx6
75 77
     systemctl disable bmx7
78
+    systemctl disable olsr2
76 79
     systemctl stop dnsmasq
77 80
     systemctl disable dnsmasq
78 81
 
@@ -206,6 +209,7 @@ function start {
206 209
 
207 210
     sed -i "s|ExecStart=.*|ExecStart=/usr/sbin/bmx6 dev=${IFACE}|g" /etc/systemd/system/bmx6.service
208 211
     sed -i "s|ExecStart=.*|ExecStart=/usr/sbin/bmx7 dev=${IFACE}|g" /etc/systemd/system/bmx7.service
212
+    sed -i "s|ExecStart=.*|ExecStart=/usr/local/sbin/olsrd2_static ${IFACE}|g" /etc/systemd/system/olsr2.service
209 213
     systemctl daemon-reload
210 214
 
211 215
     add_wifi_interface $IFACE $WIFI_SSID ad-hoc $CHANNEL
@@ -229,6 +233,7 @@ function start {
229 233
 
230 234
             sed -i "s|ExecStart=.*|ExecStart=/usr/sbin/bmx6 dev=${IFACE} dev=${EIFACE}|g" /etc/systemd/system/bmx6.service
231 235
             sed -i "s|ExecStart=.*|ExecStart=/usr/sbin/bmx7 dev=${IFACE} dev=${EIFACE}|g" /etc/systemd/system/bmx7.service
236
+            sed -i "s|ExecStart=.*|ExecStart=/usr/local/sbin/olsrd2_static ${IFACE} ${EIFACE}|g" /etc/systemd/system/olsr2.service
232 237
             systemctl daemon-reload
233 238
         else
234 239
             echo $"$EIFACE is not connected"
@@ -255,11 +260,18 @@ function start {
255 260
     if grep -q "bmx6" $MESH_DEFAULT_PROTOCOL; then
256 261
         systemctl enable bmx6
257 262
         systemctl restart bmx6
258
-    else
263
+    fi
264
+
265
+    if grep -q "bmx7" $MESH_DEFAULT_PROTOCOL; then
259 266
         systemctl enable bmx7
260 267
         systemctl restart bmx7
261 268
     fi
262 269
 
270
+    if grep -q "olsr" $MESH_DEFAULT_PROTOCOL; then
271
+        systemctl enable olsr2
272
+        systemctl restart olsr2
273
+    fi
274
+
263 275
     systemctl restart avahi-daemon
264 276
 
265 277
     verify