pureftpd.sh 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #!/bin/bash
  2. # Author: yeho <lj2007331 AT gmail.com>
  3. # BLOG: https://blog.linuxeye.cn
  4. #
  5. # Notes: OneinStack for CentOS/RadHat 6+ Debian 6+ and Ubuntu 12+
  6. #
  7. # Project home page:
  8. # https://oneinstack.com
  9. # https://github.com/lj2007331/oneinstack
  10. Install_PureFTPd() {
  11. pushd ${oneinstack_dir}/src > /dev/null
  12. id -u ${run_user} >/dev/null 2>&1
  13. [ $? -ne 0 ] && useradd -M -s /sbin/nologin ${run_user}
  14. tar xzf pure-ftpd-${pureftpd_ver}.tar.gz
  15. pushd pure-ftpd-${pureftpd_ver}
  16. [ ! -d "${pureftpd_install_dir}" ] && mkdir -p ${pureftpd_install_dir}
  17. ./configure --prefix=${pureftpd_install_dir} CFLAGS=-O2 --with-puredb --with-quotas --with-cookie --with-virtualhosts --with-virtualchroot --with-diraliases --with-sysquotas --with-ratios --with-altlog --with-paranoidmsg --with-shadow --with-welcomemsg --with-throttling --with-uploadscript --with-language=english --with-rfc2640 --with-tls
  18. make -j ${THREAD} && make install
  19. if [ -e "${pureftpd_install_dir}/sbin/pure-ftpwho" ]; then
  20. [ ! -e "${pureftpd_install_dir}/etc" ] && mkdir ${pureftpd_install_dir}/etc
  21. popd
  22. /bin/cp ../init.d/Pureftpd-init /etc/init.d/pureftpd
  23. /bin/cp ../config/pure-ftpd.conf ${pureftpd_install_dir}/etc
  24. sed -i "s@/usr/local/pureftpd@${pureftpd_install_dir}@g" /etc/init.d/pureftpd
  25. chmod +x /etc/init.d/pureftpd
  26. [ "${OS}" == "CentOS" ] && { chkconfig --add pureftpd; chkconfig pureftpd on; }
  27. [[ "${OS}" =~ ^Ubuntu$|^Debian$ ]] && { sed -i 's@^. /etc/rc.d/init.d/functions@. /lib/lsb/init-functions@' /etc/init.d/pureftpd; update-rc.d pureftpd defaults; }
  28. [ "${Debian_ver}" == '7' ] && sed -i 's@/var/lock/subsys/@/var/lock/@g' /etc/init.d/pureftpd
  29. sed -i "s@^PureDB.*@PureDB ${pureftpd_install_dir}/etc/pureftpd.pdb@" ${pureftpd_install_dir}/etc/pure-ftpd.conf
  30. sed -i "s@^LimitRecursion.*@LimitRecursion 65535 8@" ${pureftpd_install_dir}/etc/pure-ftpd.conf
  31. openssl req -x509 -days 7300 -sha256 -nodes -subj "/C=CN/ST=Shanghai/L=Shanghai/O=OneinStack/CN=${IPADDR}" -newkey rsa:2048 -keyout ${pureftpd_install_dir}/etc/pure-ftpd.pem -out ${pureftpd_install_dir}/etc/pure-ftpd.pem
  32. chmod 600 ${pureftpd_install_dir}/etc/pure-ftpd.pem
  33. sed -i "s@^# TLS.*@&\nCertFile ${pureftpd_install_dir}/etc/pure-ftpd.pem@" ${pureftpd_install_dir}/etc/pure-ftpd.conf
  34. sed -i "s@^# TLS.*@&\nTLSCipherSuite HIGH:MEDIUM:+TLSv1:\!SSLv2:\!SSLv3@" ${pureftpd_install_dir}/etc/pure-ftpd.conf
  35. sed -i "s@^# TLS.*@TLS 1@" ${pureftpd_install_dir}/etc/pure-ftpd.conf
  36. ulimit -s unlimited
  37. service pureftpd start
  38. # iptables Ftp
  39. if [ "${iptables_yn}" == 'y' ]; then
  40. if [ "${OS}" == "CentOS" ]; then
  41. if [ -z "$(grep '20000:30000' /etc/sysconfig/iptables)" ]; then
  42. iptables -I INPUT 5 -p tcp -m state --state NEW -m tcp --dport 21 -j ACCEPT
  43. iptables -I INPUT 6 -p tcp -m state --state NEW -m tcp --dport 20000:30000 -j ACCEPT
  44. service iptables save
  45. fi
  46. elif [[ "${OS}" =~ ^Ubuntu$|^Debian$ ]]; then
  47. if [ -z "$(grep '20000:30000' /etc/iptables.up.rules)" ]; then
  48. iptables -I INPUT 5 -p tcp -m state --state NEW -m tcp --dport 21 -j ACCEPT
  49. iptables -I INPUT 6 -p tcp -m state --state NEW -m tcp --dport 20000:30000 -j ACCEPT
  50. iptables-save > /etc/iptables.up.rules
  51. fi
  52. fi
  53. fi
  54. echo "${CSUCCESS}Pure-Ftp installed successfully! ${CEND}"
  55. rm -rf pure-ftpd-${pureftpd_ver}
  56. else
  57. rm -rf ${pureftpd_install_dir}
  58. echo "${CFAILURE}Pure-Ftpd install failed, Please contact the author! ${CEND}"
  59. kill -9 $$
  60. fi
  61. popd
  62. }