forked from goroma/ShadowsocksForMiRouter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
install_shadowsocks.sh
91 lines (79 loc) · 2.72 KB
/
install_shadowsocks.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#!/bin/sh
clear
echo "#############################################################"
echo "# Install Shadowsocks for Miwifi(r1d)"
echo "#############################################################"
# Make sure Shadowsocks has not been installed
if [[ -f /etc/firewall.user.back ]]; then
echo "Error: You have installed Shadowsocks. Please remove it after update the MiRouter!" 1>&2
exit 1
fi
# Make sure only root can run our script
if [[ `id -u` -ne 0 ]]; then
echo "Error: This script must be run as root!" 1>&2
exit 1
fi
cd /userdisk/data/
rm -f shadowsocks-miwifi.tar.gz
wget http://cdn.32ph.com/shadowsocks-miwifi.tar.gz
tar zxf shadowsocks-miwifi.tar.gz
# install shadowsocks ss-redir to /usr/bin
mount / -o rw,remount
cp -f ./shadowsocks-miwifi/ss-redir /usr/bin/ss-redir
chmod +x /usr/bin/ss-redir
sync
mount / -o ro,remount
# Config shadowsocks init script
cp ./shadowsocks-miwifi/shadowsocks /etc/init.d/shadowsocks
chmod +x /etc/init.d/shadowsocks
read -p "Do you want to create configuration file? (Y/n)" createConfig
if [[ "$createConfig" = "Y" ]]; then
# Read configuration
mkdir -p /etc/shadowsocks
echo "#############################################################"
echo "#"
echo "# Please input your shadowsocks configuration"
echo "#"
echo "#############################################################"
echo ""
echo "input server_address(IP address is suggested):"
read serverip
echo "input server_port:"
read serverport
echo "input local_port(1082 is suggested):"
read localport
echo "input password:"
read shadowsockspwd
echo "input method"
read method
# Creat shadowsocks
cat > /etc/shadowsocks/config.json<<-EOF
{
"server":"${serverip}",
"server_port":${serverport},
"local_port":${localport},
"password":"${shadowsockspwd}",
"timeout":60,
"method":"${method}"
}
EOF
fi
# Config dnsmasq
mkdir -p /etc/dnsmasq.d
curl https://raw.githubusercontent.com/bazingaterry/ShadowsocksForMiRouter/master/fgserver.conf --insecure > /etc/dnsmasq.d/fgserver.conf
curl https://raw.githubusercontent.com/bazingaterry/ShadowsocksForMiRouter/master/fgset.conf --insecure > /etc/dnsmasq.d/fgset.conf
#config firewall
cp -f /etc/firewall.user /etc/firewall.user.back
echo "ipset -N setmefree iphash -! " >> /etc/firewall.user
echo "iptables -t nat -A PREROUTING -p tcp -m set --match-set setmefree dst -j REDIRECT --to-port ${localport}" >> /etc/firewall.user
#restart all service
/etc/init.d/dnsmasq restart
/etc/init.d/firewall restart
/etc/init.d/shadowsocks start
/etc/init.d/shadowsocks enable
#install successfully
rm -rf /userdisk/data/shadowsocks-miwifi
echo ""
echo "Congratulations, shadowsocks-miwifi installed complete !"
echo ""
exit 0