You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

136 lines
4.4 KiB

  1. #!/bin/bash
  2. echo "####################################################################"
  3. echo "# docker_postgres_setup_script #"
  4. echo "# Dennis Buchhorn - bucde@b-eit.de #"
  5. echo "####################################################################"
  6. echo "# WARNING: password is plain text input! #"
  7. echo "# #"
  8. echo "# Config will be saved in 'config' file. #"
  9. echo "# (everything in plain text, even the password) #"
  10. #echo "# #"
  11. echo "####################################################################"
  12. echo ""
  13. DATE=$(date +'%y%m%d%H%M%S')
  14. CONFIG_EXISTS="false"
  15. USE_EXISTING_CONFIG=""
  16. DELETE_CONFIG=""
  17. POSTGRES_PROJECT_NAME="postgres_${DATE}"
  18. POSTGRES_PROJECT_NAME_SUFFIX=""
  19. POSTGRES_CONTAINER_NAME="${POSTGRES_PROJECT_NAME}_db"
  20. POSTGRES_VERSION=""
  21. POSTGRES_HOST_IP_ADDRESS=""
  22. POSTGRES_HOST_PORT=""
  23. POSTGRES_ADMIN_USER=""
  24. POSTGRES_ADMIN_PASSWORD=""
  25. POSTGRES_SHARED_HOSTING=""
  26. read -p "Enter postgres project name suffix (leave empty for none): " POSTGRES_PROJECT_NAME_SUFFIX
  27. if [ -n "$POSTGRES_PROJECT_NAME_SUFFIX" ]; then
  28. POSTGRES_PROJECT_NAME="${POSTGRES_PROJECT_NAME}_${POSTGRES_PROJECT_NAME_SUFFIX}"
  29. POSTGRES_CONTAINER_NAME="${POSTGRES_CONTAINER_NAME}_${POSTGRES_PROJECT_NAME_SUFFIX}"
  30. fi
  31. rm -f .env
  32. touch .env
  33. echo "COMPOSE_PROJECT_NAME="$POSTGRES_PROJECT_NAME >> .env
  34. echo "POSTGRES_CONTAINER_NAME="$POSTGRES_CONTAINER_NAME >> .env
  35. if [ -f "config" ]; then
  36. CONFIG_EXISTS="true"
  37. read -p "Config file 'config' already exists! Would you like to use this? (y/n)" USE_EXISTING_CONFIG
  38. fi
  39. if [ $CONFIG_EXISTS == "false" ] || [ $USE_EXISTING_CONFIG == "n" ]; then
  40. read -p "Enter postgres version which should be used: " POSTGRES_VERSION
  41. read -p "Enter host (vm) ip address on which postgres should be accessible: " POSTGRES_HOST_IP_ADDRESS
  42. read -p "Enter host (vm) port on which postgres should be accessible: " POSTGRES_HOST_PORT
  43. read -p "Enter admin user name for postgres: " POSTGRES_ADMIN_USER
  44. read -p "Enter admin password for postgres: " POSTGRES_ADMIN_PASSWORD
  45. rm -f config
  46. touch config
  47. echo "POSTGRES_VERSION="$POSTGRES_VERSION >> config
  48. echo "POSTGRES_HOST_IP_ADDRESS="$POSTGRES_HOST_IP_ADDRESS >> config
  49. echo "POSTGRES_HOST_PORT="$POSTGRES_HOST_PORT >> config
  50. echo "POSTGRES_ADMIN_USER="$POSTGRES_ADMIN_USER >> config
  51. echo "POSTGRES_ADMIN_PASSWORD="$POSTGRES_ADMIN_PASSWORD >> config
  52. echo "Config file 'config' created!"
  53. else
  54. echo "Use existing config file 'config'!"
  55. while read line; do
  56. if [[ $line == *"POSTGRES_ADMIN_USER="* ]]; then
  57. POSTGRES_ADMIN_USER=$(echo $line | cut -c 21-)
  58. fi
  59. done < "config"
  60. fi
  61. cat "config" >> ".env"
  62. read -p "Should the config file 'config' be deleted after creating the container? (y/n)" DELETE_CONFIG
  63. read -p "Would you like to modify postgres rights for shared hosting? (y/n)" POSTGRES_SHARED_HOSTING
  64. docker-compose up -d
  65. echo -n "Wait until postgres is ready ..."
  66. while ! docker exec $POSTGRES_CONTAINER_NAME pg_isready -q -U $POSTGRES_ADMIN_USER; do
  67. echo -n "."
  68. sleep 1
  69. done
  70. echo -n "."
  71. sleep 1
  72. echo -n "."
  73. sleep 1
  74. echo -n "."
  75. sleep 1
  76. echo -n "."
  77. sleep 1
  78. while ! docker exec $POSTGRES_CONTAINER_NAME pg_isready -q -U $POSTGRES_ADMIN_USER; do
  79. echo -n "."
  80. sleep 1
  81. done
  82. echo -e "\nPostgres is ready!"
  83. if [ $POSTGRES_SHARED_HOSTING == "y" ]; then
  84. echo "Modify postgres rights for shared hosting..."
  85. rm -f tmp
  86. touch tmp
  87. echo "REVOKE ALL ON DATABASE template1 FROM public;" >> tmp
  88. echo "REVOKE ALL ON SCHEMA public FROM public;" >> tmp
  89. echo "GRANT ALL ON SCHEMA public TO "$POSTGRES_ADMIN_USER";" >> tmp
  90. echo "REVOKE ALL ON pg_user FROM public;" >> tmp
  91. echo "REVOKE ALL ON pg_roles FROM public;" >> tmp
  92. echo "REVOKE ALL ON pg_group FROM public;" >> tmp
  93. echo "REVOKE ALL ON pg_authid FROM public;" >> tmp
  94. echo "REVOKE ALL ON pg_auth_members FROM public;" >> tmp
  95. echo "REVOKE ALL ON pg_database FROM public;" >> tmp
  96. echo "REVOKE ALL ON pg_tablespace FROM public;" >> tmp
  97. echo "REVOKE ALL ON pg_settings FROM public;" >> tmp
  98. cat tmp | docker exec -i $POSTGRES_CONTAINER_NAME psql -U $POSTGRES_ADMIN_USER -d template1
  99. rm -f tmp
  100. fi
  101. if [ $DELETE_CONFIG == "y" ]; then
  102. rm -f config
  103. echo "Config file 'config' deleted!"
  104. fi
  105. rm -f .env
  106. echo "Done!"