shadowsocks.sh 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. #!/bin/bash
  2. # Author: yeho <lj2007331 AT gmail.com>
  3. # BLOG: https://blog.linuxeye.com
  4. #
  5. # Notes: OneinStack for CentOS/RadHat 5+ Debian 6+ and Ubuntu 12+
  6. # Install Shadowsocks(Python) Server
  7. #
  8. # Project home page:
  9. # http://oneinstack.com
  10. # https://github.com/lj2007331/oneinstack
  11. export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
  12. clear
  13. printf "
  14. #######################################################################
  15. # OneinStack for CentOS/RadHat 6+ Debian 6+ and Ubuntu 12+ #
  16. # Install Shadowsocks(Python) Server #
  17. # For more information please visit http://oneinstack.com #
  18. #######################################################################
  19. "
  20. cd src
  21. . ../options.conf
  22. . ../include/color.sh
  23. . ../include/check_os.sh
  24. . ../include/download.sh
  25. # Check if user is root
  26. [ $(id -u) != "0" ] && { echo "${CFAILURE}Error: You must be root to run this script${CEND}"; exit 1; }
  27. PUBLIC_IPADDR=`../include/get_public_ipaddr.py`
  28. [ "$CentOS_RHEL_version" == '5' ] && { echo "${CWARNING}Shadowsocks only support CentOS6,7 or Debian or Ubuntu! ${CEND}"; exit 1; }
  29. Install_shadowsocks(){
  30. if [ "$OS" == 'CentOS' ]; then
  31. for Package in wget unzip openssl-devel gcc swig python python-devel python-setuptools autoconf libtool libevent automake make curl curl-devel zlib-devel perl perl-devel cpio expat-devel gettext-devel
  32. do
  33. yum -y install $Package
  34. done
  35. elif [ $OS == 'Debian' -o $OS == 'Ubuntu' ];then
  36. apt-get -y update
  37. for Package in python-dev python-pip curl wget unzip gcc swig automake make perl cpio
  38. do
  39. apt-get -y install $Package
  40. done
  41. fi
  42. src_url=http://mirrors.linuxeye.com/oneinstack/src/ez_setup.py && Download_src
  43. which pip > /dev/null 2>&1
  44. if [ $? -ne 0 ]; then
  45. OS_CentOS='python ez_setup.py install \n
  46. easy_install pip'
  47. OS_command
  48. fi
  49. if [ -f /usr/bin/pip ]; then
  50. pip install M2Crypto
  51. pip install greenlet
  52. pip install gevent
  53. pip install shadowsocks
  54. if [ -f /usr/bin/ssserver -o -f /usr/local/bin/ssserver ]; then
  55. /bin/cp ../init.d/Shadowsocks-init /etc/init.d/shadowsocks
  56. chmod +x /etc/init.d/shadowsocks
  57. OS_CentOS='chkconfig --add shadowsocks \n
  58. chkconfig shadowsocks on'
  59. OS_Debian_Ubuntu="update-rc.d shadowsocks defaults"
  60. OS_command
  61. [ ! -e /usr/bin/ssserver -a -e /usr/local/bin/ssserver ] && sed -i 's@Shadowsocks_bin=.*@Shadowsocks_bin=/usr/local/bin/ssserver@' /etc/init.d/shadowsocks
  62. else
  63. echo
  64. echo "${CQUESTION}Shadowsocks install failed! Please visit http://oneinstack.com${CEND}"
  65. exit 1
  66. fi
  67. fi
  68. }
  69. Uninstall_shadowsocks(){
  70. while :
  71. do
  72. echo
  73. read -p "Do you want to uninstall Shadowsocks? [y/n]: " Shadowsocks_yn
  74. if [ "$Shadowsocks_yn" != 'y' -a "$Shadowsocks_yn" != 'n' ];then
  75. echo "${CWARNING}input error! Please only input 'y' or 'n'${CEND}"
  76. else
  77. break
  78. fi
  79. done
  80. if [ "$Shadowsocks_yn" == 'y' ]; then
  81. [ -n "`ps -ef | grep -v grep | grep -i "ssserver"`" ] && /etc/init.d/shadowsocks stop
  82. OS_CentOS='chkconfig --del shadowsocks'
  83. OS_Debian_Ubuntu="update-rc.d -f shadowsocks remove"
  84. OS_command
  85. rm -rf /etc/shadowsocks.json /var/run/shadowsocks.pid /etc/init.d/shadowsocks
  86. pip uninstall -y shadowsocks
  87. if [ $? -eq 0 ]; then
  88. echo "${CSUCCESS}Shadowsocks uninstall success! ${CEND}"
  89. else
  90. echo "${CFAILURE}Shadowsocks uninstall failed! ${CEND}"
  91. fi
  92. else
  93. echo "${CMSG}Shadowsocks uninstall cancelled! ${CEND}"
  94. fi
  95. }
  96. AddUser_shadowsocks(){
  97. while :
  98. do
  99. echo
  100. read -p "Please input password for shadowsocks: " Shadowsocks_password
  101. [ -n "`echo $Shadowsocks_password | grep '[+|&]'`" ] && { echo "${CWARNING}input error,not contain a plus sign (+) and & ${CEND}"; continue; }
  102. (( ${#Shadowsocks_password} >= 5 )) && break || echo "${CWARNING}Shadowsocks password least 5 characters! ${CEND}"
  103. done
  104. }
  105. Iptables_set(){
  106. if [ -e '/etc/sysconfig/iptables' ];then
  107. Shadowsocks_Already_port=`grep -oE '90[0-9][0-9]' /etc/sysconfig/iptables | head -n 1`
  108. elif [ -e '/etc/iptables.up.rules' ];then
  109. Shadowsocks_Already_port=`grep -oE '90[0-9][0-9]' /etc/iptables.up.rules | head -n 1`
  110. fi
  111. if [ -n "$Shadowsocks_Already_port" ];then
  112. Shadowsocks_Default_port=`expr $Shadowsocks_Already_port + 1`
  113. else
  114. Shadowsocks_Default_port=9001
  115. fi
  116. while :
  117. do
  118. echo
  119. read -p "Please input Shadowsocks port(Default: $Shadowsocks_Default_port): " Shadowsocks_port
  120. [ -z "$Shadowsocks_port" ] && Shadowsocks_port=$Shadowsocks_Default_port
  121. if [ $Shadowsocks_port -ge 9000 >/dev/null 2>&1 -a $Shadowsocks_port -le 9100 >/dev/null 2>&1 ];then
  122. break
  123. else
  124. echo "${CWARNING}input error! Input range: 9001~9099${CEND}"
  125. fi
  126. done
  127. if [ "$OS" == 'CentOS' ];then
  128. if [ -z "`grep -E $Shadowsocks_port /etc/sysconfig/iptables`" ];then
  129. iptables -I INPUT 4 -p tcp -m state --state NEW -m tcp --dport $Shadowsocks_port -j ACCEPT
  130. fi
  131. elif [ $OS == 'Debian' -o $OS == 'Ubuntu' ];then
  132. if [ -z "`grep -E $Shadowsocks_port /etc/iptables.up.rules`" ];then
  133. iptables -I INPUT 4 -p tcp -m state --state NEW -m tcp --dport $Shadowsocks_port -j ACCEPT
  134. fi
  135. else
  136. echo "${CWARNING}This port is already in iptables${CEND}"
  137. fi
  138. OS_CentOS='service iptables save'
  139. OS_Debian_Ubuntu='iptables-save > /etc/iptables.up.rules'
  140. OS_command
  141. }
  142. Config_shadowsocks(){
  143. cat > /etc/shadowsocks.json<<EOF
  144. {
  145. "server":"0.0.0.0",
  146. "local_address":"127.0.0.1",
  147. "local_port":1080,
  148. "port_password":{
  149. "$Shadowsocks_port":"$Shadowsocks_password"
  150. },
  151. "timeout":300,
  152. "method":"aes-256-cfb",
  153. "fast_open":false
  154. }
  155. EOF
  156. }
  157. AddUser_Config_shadowsocks(){
  158. [ ! -e /etc/shadowsocks.json ] && { echo "${CFAILURE}Shadowsocks is not installed! ${CEND}"; exit 1; }
  159. [ -z "`grep \"$Shadowsocks_port\" /etc/shadowsocks.json`" ] && sed -i "s@\"port_password\":{@\"port_password\":{\n\t\"$Shadowsocks_port\":\"$Shadowsocks_password\",@" /etc/shadowsocks.json || { echo "${CWARNING}This port is already in /etc/shadowsocks.json${CEND}"; exit 1; }
  160. }
  161. Print_User_shadowsocks(){
  162. printf "
  163. Your Server IP: ${CMSG}$PUBLIC_IPADDR${CEND}
  164. Your Server Port: ${CMSG}$Shadowsocks_port${CEND}
  165. Your Password: ${CMSG}$Shadowsocks_password${CEND}
  166. Your Local IP: ${CMSG}127.0.0.1${CEND}
  167. Your Local Port: ${CMSG}1080${CEND}
  168. Your Encryption Method: ${CMSG}aes-256-cfb${CEND}
  169. "
  170. }
  171. case "$1" in
  172. install)
  173. AddUser_shadowsocks
  174. Iptables_set
  175. Install_shadowsocks
  176. Config_shadowsocks
  177. service shadowsocks start
  178. Print_User_shadowsocks
  179. ;;
  180. adduser)
  181. AddUser_shadowsocks
  182. Iptables_set
  183. AddUser_Config_shadowsocks
  184. service shadowsocks restart
  185. Print_User_shadowsocks
  186. ;;
  187. uninstall)
  188. Uninstall_shadowsocks
  189. ;;
  190. *)
  191. echo
  192. echo $"Usage: ${CMSG}$0${CEND} { ${CMSG}install${CEND} | ${CMSG}adduser${CEND} | ${CMSG}uninstall${CEND} }"
  193. echo
  194. exit 1
  195. esac