浏览代码

Separate tracker utils

Bob Mottram 8 年前
父节点
当前提交
a6d36eb13e
没有帐户链接到提交者的电子邮件
共有 3 个文件被更改,包括 171 次插入14 次删除
  1. 59
    14
      src/freedombone-app-librevault
  2. 9
    0
      src/freedombone-mesh-batman
  3. 103
    0
      src/freedombone-utils-tracker

+ 59
- 14
src/freedombone-app-librevault 查看文件

@@ -67,36 +67,77 @@ function remove_librevault {
67 67
     if ! grep -Fxq "install_librevault" $COMPLETION_FILE; then
68 68
         return
69 69
     fi
70
-    iptables -D INPUT -p udp --dport $LIBREVAULT_PORT -j ACCEPT
71
-    iptables -D INPUT -p tcp --dport $LIBREVAULT_PORT -j ACCEPT
72
-    function_check save_firewall_settings
73
-    save_firewall_settings
70
+    if [ $LIBREVAULT_PORT ]; then
71
+        iptables -D INPUT -p udp --dport $LIBREVAULT_PORT -j ACCEPT
72
+        iptables -D INPUT -p tcp --dport $LIBREVAULT_PORT -j ACCEPT
73
+        function_check save_firewall_settings
74
+        save_firewall_settings
75
+    fi
74 76
 
75 77
     systemctl stop librevault
76 78
     systemctl disable librevault
77 79
     rm /etc/systemd/system/librevault.service
78 80
     sed -i '/install_librevault/d' $COMPLETION_FILE
79 81
     sed -i '/configure_firewall_for_librevault/d' $COMPLETION_FILE
80
-    systemctl restart cron
81 82
 }
82 83
 
83 84
 function configure_firewall_for_librevault {
84 85
     if grep -Fxq "configure_firewall_for_librevault" $COMPLETION_FILE; then
85 86
         return
86 87
     fi
87
-    iptables -A INPUT -p udp --dport $LIBREVAULT_PORT -j ACCEPT
88
-    iptables -A INPUT -p tcp --dport $LIBREVAULT_PORT -j ACCEPT
89
-    function_check save_firewall_settings
90
-    save_firewall_settings
91
-
92
-    OPEN_PORTS+=("Librevault $LIBREVAULT_PORT")
88
+    if [ $LIBREVAULT_PORT ]; then
89
+        iptables -A INPUT -p udp --dport $LIBREVAULT_PORT -j ACCEPT
90
+        iptables -A INPUT -p tcp --dport $LIBREVAULT_PORT -j ACCEPT
91
+        function_check save_firewall_settings
92
+        save_firewall_settings
93
+        OPEN_PORTS+=("Librevault $LIBREVAULT_PORT")
94
+    fi
93 95
     echo 'configure_firewall_for_librevault' >> $COMPLETION_FILE
94 96
 }
95 97
 
96
-function mesh_install_syncthing {
98
+function mesh_install_librevault {
99
+    install_tracker
100
+
101
+    chroot "$rootdir" apt-get -y -t jessie-backports install cmake
102
+    chroot "$rootdir" apt-get -y install bittornado nginx
103
+    chroot "$rootdir" apt-get -y install build-essential libboost-all-dev libssl-dev
104
+    chroot "$rootdir" apt-get -y install qtbase5-dev libqt5svg5-dev libqt5websockets5-dev
105
+    chroot "$rootdir" apt-get -y install autoconf automake libtool curl make g++ unzip
106
+
107
+    if [ ! -d $rootdir$INSTALL_DIR ]; then
108
+        chroot "$rootdir" mkdir -p $INSTALL_DIR
109
+    fi
110
+    chroot "$rootdir" git clone $PROTOBUF_REPO $rootdir$INSTALL_DIR/protobuf
111
+    cd $rootdir$INSTALL_DIR/protobuf
112
+    git checkout $PROTOBUF_COMMIT -b $PROTOBUF_COMMIT
113
+
114
+    cat <<EOF > $rootdir/root/install_protobuf
115
+cd $INSTALL_DIR/protobuf
116
+./autogen.sh
117
+./configure
118
+make
119
+make install
120
+ldconfig
121
+EOF
122
+    chroot "$rootdir" chmod +x /root/install_protobuf
123
+    chroot "$rootdir" /root/install_protobuf
124
+
125
+    git_clone $LIBREVAULT_REPO $rootdir$INSTALL_DIR/librevault
126
+    cd $rootdir$INSTALL_DIR/librevault
127
+    git checkout $LIBREVAULT_COMMIT -b $LIBREVAULT_COMMIT
128
+    mkdir $rootdir$INSTALL_DIR/librevault/build
129
+
130
+    cat <<EOF > $rootdir/root/install_librevault
131
+cd $INSTALL_DIR/librevault/build
132
+cmake ..
133
+cmake --build .
134
+make install
135
+EOF
136
+    chroot "$rootdir" chmod +x /root/install_librevault
137
+    chroot "$rootdir" /root/install_librevault
97 138
 }
98 139
 
99
-function install_syncthing {
140
+function install_librevault {
100 141
     if [ $INSTALLING_MESH ]; then
101 142
         mesh_install_librevault
102 143
         return
@@ -106,7 +147,10 @@ function install_syncthing {
106 147
         return
107 148
     fi
108 149
 
109
-    apt-get -y install build-essential cmake libboost-all-dev libssl-dev
150
+    install_tracker
151
+
152
+    apt-get -y -t jessie-backports install cmake
153
+    apt-get -y install build-essential libboost-all-dev libssl-dev
110 154
     apt-get -y install qtbase5-dev libqt5svg5-dev libqt5websockets5-dev
111 155
     apt-get -y install autoconf automake libtool curl make g++ unzip
112 156
 
@@ -130,6 +174,7 @@ function install_syncthing {
130 174
     cd $INSTALL_DIR/librevault/build
131 175
     cmake ..
132 176
     cmake --build .
177
+    make install
133 178
 
134 179
     echo 'install_librevault' >> $COMPLETION_FILE
135 180
 }

+ 9
- 0
src/freedombone-mesh-batman 查看文件

@@ -62,6 +62,7 @@ fi
62 62
 ZERONET_PORT=15441
63 63
 IPFS_PORT=4001
64 64
 TOX_PORT=33445
65
+TRACKER_PORT=6969
65 66
 
66 67
 # Ethernet bridge definition (bridged to bat0)
67 68
 BRIDGE=br-mesh
@@ -124,6 +125,10 @@ function stop {
124 125
     ifconfig $IFACE down
125 126
     iwconfig $IFACE mode managed
126 127
 
128
+    iptables -D INPUT -p tcp --dport $TRACKER_PORT -j ACCEPT
129
+    iptables -D INPUT -p udp --dport $TRACKER_PORT -j ACCEPT
130
+    iptables -D INPUT -p tcp --dport 80 -j ACCEPT
131
+    iptables -D INPUT -p udp --dport 80 -j ACCEPT
127 132
     iptables -D INPUT -p tcp --dport 548 -j ACCEPT
128 133
     iptables -D INPUT -p udp --dport 548 -j ACCEPT
129 134
     iptables -D INPUT -p tcp --dport 5353 -j ACCEPT
@@ -226,6 +231,10 @@ function start {
226 231
 
227 232
     iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
228 233
     iptables -A OUTPUT -p icmp --icmp-type echo-reply -j ACCEPT
234
+    iptables -A INPUT -p tcp --dport $TRACKER_PORT -j ACCEPT
235
+    iptables -A INPUT -p udp --dport $TRACKER_PORT -j ACCEPT
236
+    iptables -A INPUT -p tcp --dport 80 -j ACCEPT
237
+    iptables -A INPUT -p udp --dport 80 -j ACCEPT
229 238
     iptables -A INPUT -p tcp --dport 548 -j ACCEPT
230 239
     iptables -A INPUT -p udp --dport 548 -j ACCEPT
231 240
     iptables -A INPUT -p tcp --dport 5353 -j ACCEPT

+ 103
- 0
src/freedombone-utils-tracker 查看文件

@@ -0,0 +1,103 @@
1
+#!/bin/bash
2
+#
3
+# .---.                  .              .
4
+# |                      |              |
5
+# |--- .--. .-.  .-.  .-.|  .-. .--.--. |.-.  .-. .--.  .-.
6
+# |    |   (.-' (.-' (   | (   )|  |  | |   )(   )|  | (.-'
7
+# '    '     --'  --'  -' -  -' '  '   -' -'   -' '   -  --'
8
+#
9
+#                    Freedom in the Cloud
10
+#
11
+# Torrent tracker functions
12
+#
13
+# License
14
+# =======
15
+#
16
+# Copyright (C) 2014-2016 Bob Mottram <bob@robotics.uk.to>
17
+#
18
+# This program is free software: you can redistribute it and/or modify
19
+# it under the terms of the GNU Affero General Public License as published by
20
+# the Free Software Foundation, either version 3 of the License, or
21
+# (at your option) any later version.
22
+#
23
+# This program is distributed in the hope that it will be useful,
24
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
25
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26
+# GNU Affero General Public License for more details.
27
+#
28
+# You should have received a copy of the GNU Affero General Public License
29
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
30
+
31
+TRACKER_PORT=6969
32
+
33
+function mesh_install_tracker {
34
+    chroot "$rootdir" apt-get -y install bittornado nginx
35
+
36
+    TRACKER_DAEMON=$rootdir/etc/systemd/system/tracker.service
37
+    echo '[Unit]' > $TRACKER_DAEMON
38
+    echo 'Description=Torrent Tracker' >> $TRACKER_DAEMON
39
+    echo 'After=syslog.target' >> $TRACKER_DAEMON
40
+    echo 'After=network.target' >> $TRACKER_DAEMON
41
+    echo '[Service]' >> $TRACKER_DAEMON
42
+    echo 'Type=simple' >> $TRACKER_DAEMON
43
+    echo 'User=tracker' >> $TRACKER_DAEMON
44
+    echo 'Group=tracker' >> $TRACKER_DAEMON
45
+    echo "WorkingDirectory=/var/lib/tracker" >> $TRACKER_DAEMON
46
+    echo "ExecStart=/usr/bin/bttrack --port $TRACKER_PORT --dfile /var/lib/tracker/dstate --logfile /var/lib/tracker/tracker.log --nat_check 0 --scrape_allowed full --ipv6_enabled 0" >> $TRACKER_DAEMON
47
+    echo '' >> $TRACKER_DAEMON
48
+    echo 'TimeoutSec=300' >> $TRACKER_DAEMON
49
+    echo '' >> $TRACKER_DAEMON
50
+    echo '[Install]' >> $TRACKER_DAEMON
51
+    echo 'WantedBy=multi-user.target' >> $TRACKER_DAEMON
52
+
53
+    chroot "$rootdir" useradd -d /var/lib/tracker/ -s /bin/false tracker
54
+    if [ ! -d $rootdir/var/lib/tracker ]; then
55
+        mkdir $rootdir/var/lib/tracker
56
+    fi
57
+    chroot "$rootdir" chown -R tracker:tracker /var/lib/tracker
58
+
59
+    chroot "$rootdir" systemctl enable tracker.service
60
+}
61
+
62
+function install_tracker {
63
+    if [ $INSTALLING_MESH ]; then
64
+        mesh_install_tracker
65
+        return
66
+    fi
67
+
68
+    if grep -Fxq "install_tracker" $COMPLETION_FILE; then
69
+        return
70
+    fi
71
+
72
+    apt-get -y install bittornado nginx
73
+
74
+    TRACKER_DAEMON=/etc/systemd/system/tracker.service
75
+    echo '[Unit]' > $TRACKER_DAEMON
76
+    echo 'Description=Torrent Tracker' >> $TRACKER_DAEMON
77
+    echo 'After=syslog.target' >> $TRACKER_DAEMON
78
+    echo 'After=network.target' >> $TRACKER_DAEMON
79
+    echo '[Service]' >> $TRACKER_DAEMON
80
+    echo 'Type=simple' >> $TRACKER_DAEMON
81
+    echo 'User=tracker' >> $TRACKER_DAEMON
82
+    echo 'Group=tracker' >> $TRACKER_DAEMON
83
+    echo "WorkingDirectory=/var/lib/tracker" >> $TRACKER_DAEMON
84
+    echo "ExecStart=/usr/bin/bttrack --port $TRACKER_PORT --dfile /var/lib/tracker/dstate --logfile /var/lib/tracker/tracker.log --nat_check 0 --scrape_allowed full --ipv6_enabled 0" >> $TRACKER_DAEMON
85
+    echo '' >> $TRACKER_DAEMON
86
+    echo 'TimeoutSec=300' >> $TRACKER_DAEMON
87
+    echo '' >> $TRACKER_DAEMON
88
+    echo '[Install]' >> $TRACKER_DAEMON
89
+    echo 'WantedBy=multi-user.target' >> $TRACKER_DAEMON
90
+
91
+    useradd -d /var/lib/tracker/ -s /bin/false tracker
92
+    if [ ! -d /var/lib/tracker ]; then
93
+        mkdir /var/lib/tracker
94
+    fi
95
+    chown -R tracker:tracker /var/lib/tracker
96
+
97
+    systemctl enable tracker.service
98
+    systemctl start tracker.service
99
+
100
+    echo 'install_tracker' >> $COMPLETION_FILE
101
+}
102
+
103
+# NOTE: deliberately no exit 0