選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

start.sh 3.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. #!/bin/bash
  2. vpn_provider="$(echo $OPENVPN_PROVIDER | tr '[A-Z]' '[a-z]')"
  3. vpn_provider_configs="/etc/openvpn/$vpn_provider"
  4. if [ ! -d "$vpn_provider_configs" ]; then
  5. echo "Could not find OpenVPN provider: $OPENVPN_PROVIDER"
  6. echo "Please check your settings."
  7. exit 1
  8. fi
  9. echo "Using OpenVPN provider: $OPENVPN_PROVIDER"
  10. if [ ! -z "$OPENVPN_CONFIG" ]
  11. then
  12. n=$(echo "$OPENVPN_CONFIG" | wc -w)
  13. if [ $n -gt 1 ]
  14. then
  15. rnd=$((RANDOM%n+1))
  16. srv=$(echo "$OPENVPN_CONFIG" | awk -vrnd=$rnd '{print $rnd}')
  17. echo "$n servers found in OPENVPN_CONFIG, $srv chosen randomly"
  18. OPENVPN_CONFIG=$srv
  19. fi
  20. if [ -f $vpn_provider_configs/"${OPENVPN_CONFIG}".ovpn ]
  21. then
  22. echo "Starting OpenVPN using config ${OPENVPN_CONFIG}.ovpn"
  23. OPENVPN_CONFIG=$vpn_provider_configs/${OPENVPN_CONFIG}.ovpn
  24. else
  25. echo "Supplied config ${OPENVPN_CONFIG}.ovpn could not be found."
  26. echo "Using default OpenVPN gateway for provider ${vpn_provider}"
  27. OPENVPN_CONFIG=$vpn_provider_configs/default.ovpn
  28. fi
  29. else
  30. echo "No VPN configuration provided. Using default."
  31. OPENVPN_CONFIG=$vpn_provider_configs/default.ovpn
  32. fi
  33. # add OpenVPN user/pass
  34. if [ "${OPENVPN_USERNAME}" = "**None**" ] || [ "${OPENVPN_PASSWORD}" = "**None**" ] ; then
  35. if [ ! -f /config/openvpn-credentials.txt ] ; then
  36. echo "OpenVPN credentials not set. Exiting."
  37. exit 1
  38. fi
  39. echo "Found existing OPENVPN credentials..."
  40. else
  41. echo "Setting OPENVPN credentials..."
  42. mkdir -p /config
  43. echo $OPENVPN_USERNAME > /config/openvpn-credentials.txt
  44. echo $OPENVPN_PASSWORD >> /config/openvpn-credentials.txt
  45. chmod 600 /config/openvpn-credentials.txt
  46. fi
  47. # add transmission credentials from env vars
  48. echo $TRANSMISSION_RPC_USERNAME > /config/transmission-credentials.txt
  49. echo $TRANSMISSION_RPC_PASSWORD >> /config/transmission-credentials.txt
  50. # Persist transmission settings for use by transmission-daemon
  51. dockerize -template /etc/transmission/environment-variables.tmpl:/etc/transmission/environment-variables.sh
  52. TRANSMISSION_CONTROL_OPTS="--script-security 2 --up-delay --up /etc/openvpn/tunnelUp.sh --down /etc/openvpn/tunnelDown.sh"
  53. if [ "true" = "$ENABLE_UFW" ]; then
  54. # Enable firewall
  55. echo "enabling firewall"
  56. sed -i -e s/IPV6=yes/IPV6=no/ /etc/default/ufw
  57. ufw enable
  58. if [ "true" = "$TRANSMISSION_PEER_PORT_RANDOM_ON_START" ]; then
  59. PEER_PORT="$TRANSMISSION_PEER_PORT_RANDOM_LOW:$TRANSMISSION_PEER_PORT_RANDOM_HIGH/tcp"
  60. else
  61. PEER_PORT=$TRANSMISSION_PEER_PORT
  62. fi
  63. echo "allowing $PEER_PORT through the firewall"
  64. ufw allow $PEER_PORT
  65. if [ "true" = "$WEBPROXY_ENABLED" ]; then
  66. echo "allowing $WEBPROXY_PORT through the firewall"
  67. ufw allow $WEBPROXY_PORT
  68. fi
  69. eval $(/sbin/ip r l m 0.0.0.0 | awk '{if($5!="tun0"){print "GW="$3"\nINT="$5; exit}}')
  70. echo "allowing access to $TRANSMISSION_RPC_PORT from $GW"
  71. ufw allow proto tcp from $GW to any port $TRANSMISSION_RPC_PORT
  72. if [ ! -z "${UFW_EXTRA_PORTS}" ]; then
  73. for port in ${UFW_EXTRA_PORTS//,/ }; do
  74. echo "allowing access to ${port} from $GW"
  75. ufw allow proto tcp from $GW to any port ${port}
  76. done
  77. fi
  78. fi
  79. if [ -n "${LOCAL_NETWORK-}" ]; then
  80. eval $(/sbin/ip r l m 0.0.0.0 | awk '{if($5!="tun0"){print "GW="$3"\nINT="$5; exit}}')
  81. if [ -n "${GW-}" -a -n "${INT-}" ]; then
  82. echo "adding route to local network $LOCAL_NETWORK via $GW dev $INT"
  83. /sbin/ip r a "$LOCAL_NETWORK" via "$GW" dev "$INT"
  84. if [ "true" = "$ENABLE_UFW" ]; then
  85. echo "allowing access to $TRANSMISSION_RPC_PORT from $LOCAL_NETWORK"
  86. ufw allow proto tcp from $LOCAL_NETWORK to any port $TRANSMISSION_RPC_PORT
  87. if [ ! -z "${UFW_EXTRA_PORTS}" ]; then
  88. for port in ${UFW_EXTRA_PORTS//,/ }; do
  89. echo "allowing access to ${port} from $LOCAL_NETWORK"
  90. ufw allow proto tcp from $LOCAL_NETWORK to any port ${port}
  91. done
  92. fi
  93. fi
  94. fi
  95. fi
  96. exec openvpn $TRANSMISSION_CONTROL_OPTS $OPENVPN_OPTS --config "$OPENVPN_CONFIG"