main.sh 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #!/bin/bash
  2. if [ -z "$ZT_IDENTITY_PATH" ]; then
  3. echo '*** FAILED: ZT_IDENTITY_PATH environment variable is not defined'
  4. exit 1
  5. fi
  6. if [ -z "$ZT_DB_HOST" ]; then
  7. echo '*** FAILED: ZT_DB_HOST environment variable not defined'
  8. exit 1
  9. fi
  10. if [ -z "$ZT_DB_PORT" ]; then
  11. echo '*** FAILED: ZT_DB_PORT environment variable not defined'
  12. exit 1
  13. fi
  14. if [ -z "$ZT_DB_NAME" ]; then
  15. echo '*** FAILED: ZT_DB_NAME environment variable not defined'
  16. exit 1
  17. fi
  18. if [ -z "$ZT_DB_USER" ]; then
  19. echo '*** FAILED: ZT_DB_USER environment variable not defined'
  20. exit 1
  21. fi
  22. if [ -z "$ZT_DB_PASSWORD" ]; then
  23. echo '*** FAILED: ZT_DB_PASSWORD environment variable not defined'
  24. exit 1
  25. fi
  26. REDIS=""
  27. if [ "$ZT_USE_REDIS" == "true" ]; then
  28. if [ -z "$ZT_REDIS_HOST" ]; then
  29. echo '*** FAILED: ZT_REDIS_HOST environment variable not defined'
  30. exit 1
  31. fi
  32. if [ -z "$ZT_REDIS_PORT" ]; then
  33. echo '*** FAILED: ZT_REDIS_PORT enivronment variable not defined'
  34. exit 1
  35. fi
  36. if [ -z "$ZT_REDIS_CLUSTER_MODE" ]; then
  37. echo '*** FAILED: ZT_REDIS_CLUSTER_MODE environment variable not defined'
  38. exit 1
  39. fi
  40. REDIS="\"redis\": {
  41. \"hostname\": \"${ZT_REDIS_HOST}\",
  42. \"port\": ${ZT_REDIS_PORT},
  43. \"clusterMode\": ${ZT_REDIS_CLUSTER_MODE},
  44. \"password\": \"${ZT_REDIS_PASSWORD}\"
  45. }
  46. "
  47. else
  48. REDIS="\"redis\": null"
  49. fi
  50. mkdir -p /var/lib/zerotier-one
  51. pushd /var/lib/zerotier-one
  52. ln -s $ZT_IDENTITY_PATH/identity.public identity.public
  53. ln -s $ZT_IDENTITY_PATH/identity.secret identity.secret
  54. popd
  55. DEFAULT_PORT=9993
  56. APP_NAME="controller-$(cat /var/lib/zerotier-one/identity.public | cut -d ':' -f 1)"
  57. echo "{
  58. \"settings\": {
  59. \"controllerDbPath\": \"postgres:host=${ZT_DB_HOST} port=${ZT_DB_PORT} dbname=${ZT_DB_NAME} user=${ZT_DB_USER} password=${ZT_DB_PASSWORD} application_name=${APP_NAME} sslmode=prefer sslcert=${DB_CLIENT_CERT} sslkey=${DB_CLIENT_KEY} sslrootcert=${DB_SERVER_CA}\",
  60. \"portMappingEnabled\": true,
  61. \"softwareUpdate\": \"disable\",
  62. \"interfacePrefixBlacklist\": [
  63. \"inot\",
  64. \"nat64\"
  65. ],
  66. \"ssoRedirectURL\": \"${ZT_SSO_REDIRECT_URL}\",
  67. ${REDIS}
  68. }
  69. }
  70. " > /var/lib/zerotier-one/local.conf
  71. if [ -n "$DB_SERVER_CA" ]; then
  72. echo "secret list"
  73. chmod 600 /secrets/db/*.pem
  74. ls -l /secrets/db/
  75. until /usr/bin/pg_isready -h ${ZT_DB_HOST} -p ${ZT_DB_PORT} -d "sslmode=prefer sslcert=${DB_CLIENT_CERT} sslkey=${DB_CLIENT_KEY} sslrootcert=${DB_SERVER_CA}"; do
  76. echo "Waiting for PostgreSQL...";
  77. sleep 2;
  78. done
  79. else
  80. until /usr/bin/pg_isready -h ${ZT_DB_HOST} -p ${ZT_DB_PORT}; do
  81. echo "Waiting for PostgreSQL...";
  82. sleep 2;
  83. done
  84. fi
  85. export GLIBCXX_FORCE_NEW=1
  86. export GLIBCPP_FORCE_NEW=1
  87. export LD_PRELOAD="/usr/lib/x86_64-linux-gnu/libjemalloc.so.2"
  88. exec /usr/local/bin/zerotier-one -p${ZT_CONTROLLER_PORT:-$DEFAULT_PORT} /var/lib/zerotier-one