main.sh 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. #!/bin/bash
  2. if [ -z "$ZT_DB_HOST" ]; then
  3. echo '*** FAILED: ZT_DB_HOST environment variable not defined'
  4. exit 1
  5. fi
  6. if [ -z "$ZT_DB_PORT" ]; then
  7. echo '*** FAILED: ZT_DB_PORT environment variable not defined'
  8. exit 1
  9. fi
  10. if [ -z "$ZT_DB_NAME" ]; then
  11. echo '*** FAILED: ZT_DB_NAME environment variable not defined'
  12. exit 1
  13. fi
  14. if [ -z "$ZT_DB_USER" ]; then
  15. echo '*** FAILED: ZT_DB_USER environment variable not defined'
  16. exit 1
  17. fi
  18. if [ -z "$ZT_DB_PASSWORD" ]; then
  19. echo '*** FAILED: ZT_DB_PASSWORD environment variable not defined'
  20. exit 1
  21. fi
  22. if [ -z "$ZT_DB_TYPE" ]; then
  23. ZT_DB_TYPE="postgres"
  24. fi
  25. REDIS=""
  26. if [ "$ZT_USE_REDIS" == "true" ]; then
  27. if [ -z "$ZT_REDIS_HOST" ]; then
  28. echo '*** FAILED: ZT_REDIS_HOST environment variable not defined'
  29. exit 1
  30. fi
  31. if [ -z "$ZT_REDIS_PORT" ]; then
  32. echo '*** FAILED: ZT_REDIS_PORT enivronment variable not defined'
  33. exit 1
  34. fi
  35. if [ -z "$ZT_REDIS_CLUSTER_MODE" ]; then
  36. echo '*** FAILED: ZT_REDIS_CLUSTER_MODE environment variable not defined'
  37. exit 1
  38. fi
  39. REDIS="\"redis\": {
  40. \"hostname\": \"${ZT_REDIS_HOST}\",
  41. \"port\": ${ZT_REDIS_PORT},
  42. \"clusterMode\": ${ZT_REDIS_CLUSTER_MODE},
  43. \"password\": \"${ZT_REDIS_PASSWORD}\"
  44. }
  45. "
  46. else
  47. REDIS="\"redis\": null"
  48. fi
  49. mkdir -p /var/lib/zerotier-one
  50. pushd /var/lib/zerotier-one
  51. if [ -d "$ZT_IDENTITY_PATH" ]; then
  52. echo '*** Using existing ZT identity from path $ZT_IDENTITY_PATH'
  53. ln -s $ZT_IDENTITY_PATH/identity.public identity.public
  54. ln -s $ZT_IDENTITY_PATH/identity.secret identity.secret
  55. if [ -f "$ZT_IDENTITY_PATH/authtoken.secret" ]; then
  56. ln -s $ZT_IDENTITY_PATH/authtoken.secret authtoken.secret
  57. fi
  58. fi
  59. popd
  60. DEFAULT_PORT=9993
  61. DEFAULT_LB_MODE=false
  62. APP_NAME="controller-$(cat /var/lib/zerotier-one/identity.public | cut -d ':' -f 1)"
  63. echo "{
  64. \"settings\": {
  65. \"controllerDbPath\": \"${ZT_DB_TYPE}: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}\",
  66. \"portMappingEnabled\": true,
  67. \"softwareUpdate\": \"disable\",
  68. \"interfacePrefixBlacklist\": [
  69. \"inot\",
  70. \"nat64\"
  71. ],
  72. \"lowBandwidthMode\": ${ZT_LB_MODE:-$DEFAULT_LB_MODE},
  73. \"ssoRedirectURL\": \"${ZT_SSO_REDIRECT_URL}\",
  74. \"allowManagementFrom\": [\"127.0.0.1\", \"::1\", \"10.0.0.0/8\"],
  75. \"otel\": {
  76. \"exporterEndpoint\": \"${ZT_EXPORTER_ENDPOINT}\",
  77. \"exporterSampleRate\": ${ZT_EXPORTER_SAMPLE_RATE:-0}
  78. },
  79. ${REDIS}
  80. }
  81. }
  82. " > /var/lib/zerotier-one/local.conf
  83. if [ -n "$DB_SERVER_CA" ]; then
  84. echo "secret list"
  85. chmod 600 /secrets/db/*.pem
  86. ls -l /secrets/db/
  87. 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
  88. echo "Waiting for PostgreSQL...";
  89. sleep 2;
  90. done
  91. else
  92. until /usr/bin/pg_isready -h ${ZT_DB_HOST} -p ${ZT_DB_PORT}; do
  93. echo "Waiting for PostgreSQL...";
  94. sleep 2;
  95. done
  96. fi
  97. if [ "$ZT_DB_TYPE" == "cv2" ]; then
  98. echo "Migrating database (if needed)..."
  99. if [ -n "$DB_SERVER_CA" ]; then
  100. /usr/local/bin/migrate -source file:///migrations -database "postgres://$ZT_DB_USER:$ZT_DB_PASSWORD@$ZT_DB_HOST:$ZT_DB_PORT/$ZT_DB_NAME?x-migrations-table=controller_migrations&sslmode=verify-full&sslrootcert=$DB_SERVER_CA&sslcert=$DB_CLIENT_CERT&sslkey=$DB_CLIENT_KEY" up
  101. else
  102. /usr/local/bin/migrate -source file:///migrations -database "postgres://$ZT_DB_USER:$ZT_DB_PASSWORD@$ZT_DB_HOST:$ZT_DB_PORT/$ZT_DB_NAME?x-migrations-table=controller_migrations&sslmode=disable" up
  103. fi
  104. fi
  105. if [ -n "$ZT_TEMPORAL_HOST" ] && [ -n "$ZT_TEMPORAL_PORT" ]; then
  106. echo "waiting for temporal..."
  107. while ! nc -z ${ZT_TEMPORAL_HOST} ${ZT_TEMPORAL_PORT}; do
  108. echo "waiting...";
  109. sleep 1;
  110. done
  111. echo "Temporal is up"
  112. fi
  113. export GLIBCXX_FORCE_NEW=1
  114. export GLIBCPP_FORCE_NEW=1
  115. export LD_PRELOAD="/usr/lib/x86_64-linux-gnu/libjemalloc.so.2"
  116. exec /usr/local/bin/zerotier-one -p${ZT_CONTROLLER_PORT:-$DEFAULT_PORT} /var/lib/zerotier-one