12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- #!/bin/bash
- if [ -z "$ZT_IDENTITY_PATH" ]; then
- echo '*** FAILED: ZT_IDENTITY_PATH environment variable is not defined'
- exit 1
- fi
- if [ -z "$ZT_DB_HOST" ]; then
- echo '*** FAILED: ZT_DB_HOST environment variable not defined'
- exit 1
- fi
- if [ -z "$ZT_DB_PORT" ]; then
- echo '*** FAILED: ZT_DB_PORT environment variable not defined'
- exit 1
- fi
- if [ -z "$ZT_DB_NAME" ]; then
- echo '*** FAILED: ZT_DB_NAME environment variable not defined'
- exit 1
- fi
- if [ -z "$ZT_DB_USER" ]; then
- echo '*** FAILED: ZT_DB_USER environment variable not defined'
- exit 1
- fi
- if [ -z "$ZT_DB_PASSWORD" ]; then
- echo '*** FAILED: ZT_DB_PASSWORD environment variable not defined'
- exit 1
- fi
- REDIS=""
- if [ "$ZT_USE_REDIS" == "true" ]; then
- if [ -z "$ZT_REDIS_HOST" ]; then
- echo '*** FAILED: ZT_REDIS_HOST environment variable not defined'
- exit 1
- fi
- if [ -z "$ZT_REDIS_PORT" ]; then
- echo '*** FAILED: ZT_REDIS_PORT enivronment variable not defined'
- exit 1
- fi
- if [ -z "$ZT_REDIS_CLUSTER_MODE" ]; then
- echo '*** FAILED: ZT_REDIS_CLUSTER_MODE environment variable not defined'
- exit 1
- fi
- REDIS="\"redis\": {
- \"hostname\": \"${ZT_REDIS_HOST}\",
- \"port\": ${ZT_REDIS_PORT},
- \"clusterMode\": ${ZT_REDIS_CLUSTER_MODE},
- \"password\": \"${ZT_REDIS_PASSWORD}\"
- }
- "
- else
- REDIS="\"redis\": {}"
- fi
- mkdir -p /var/lib/zerotier-one
- pushd /var/lib/zerotier-one
- ln -s $ZT_IDENTITY_PATH/identity.public identity.public
- ln -s $ZT_IDENTITY_PATH/identity.secret identity.secret
- popd
- DEFAULT_PORT=9993
- echo "{
- \"settings\": {
- \"controllerDbPath\": \"postgres:host=${ZT_DB_HOST} port=${ZT_DB_PORT} dbname=${ZT_DB_NAME} user=${ZT_DB_USER} password=${ZT_DB_PASSWORD} sslmode=prefer sslcert=${DB_CLIENT_CERT} sslkey=${DB_CLIENT_KEY} sslrootcert=${DB_SERVER_CA}\",
- \"portMappingEnabled\": true,
- \"softwareUpdate\": \"disable\",
- \"interfacePrefixBlacklist\": [
- \"inot\",
- \"nat64\"
- ],
- ${REDIS}
- }
- }
- " > /var/lib/zerotier-one/local.conf
- export GLIBCXX_FORCE_NEW=1
- export GLIBCPP_FORCE_NEW=1
- export LD_PRELOAD="/usr/lib64/libjemalloc.so"
- exec /usr/local/bin/zerotier -p /var/lib/zerotier-one service
|