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.

80 lines
3.0 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 '.env' file. #"
  9. echo '# (everything in plain text, even the password) #'
  10. #echo '# #'
  11. echo '####################################################################'
  12. echo ''
  13. CONFIG_EXISTS='false'
  14. KEEP_CONFIG=''
  15. POSTGRES_VERSION=''
  16. POSTGRES_HOST_IP_ADDRESS=''
  17. POSTGRES_HOST_PORT=''
  18. POSTGRES_ADMIN_USER=''
  19. POSTGRES_ADMIN_PASSWORD=''
  20. POSTGRES_SHARED_HOSTING=''
  21. if [ -f ".env" ]; then
  22. CONFIG_EXISTS='true'
  23. read -p "Config file '.env' already exists! Would you like to use this? (y/n)" KEEP_CONFIG
  24. fi
  25. if [ $CONFIG_EXISTS == 'false' ] || [ $KEEP_CONFIG == 'n' ]; then
  26. read -p 'Enter postgres version which should be used: ' POSTGRES_VERSION
  27. read -p 'Enter host (vm) ip address on which postgres should be accessible: ' POSTGRES_HOST_IP_ADDRESS
  28. read -p 'Enter host (vm) port on which postgres should be accessible: ' POSTGRES_HOST_PORT
  29. read -p 'Enter admin user name for postgres: ' POSTGRES_ADMIN_USER
  30. read -p 'Enter admin password for postgres: ' POSTGRES_ADMIN_PASSWORD
  31. rm -f .env
  32. touch .env
  33. echo "POSTGRES_VERSION="$POSTGRES_VERSION >> .env
  34. echo "POSTGRES_HOST_IP_ADDRESS="$POSTGRES_HOST_IP_ADDRESS >> .env
  35. echo "POSTGRES_HOST_PORT="$POSTGRES_HOST_PORT >> .env
  36. echo "POSTGRES_ADMIN_USER="$POSTGRES_ADMIN_USER >> .env
  37. echo "POSTGRES_ADMIN_PASSWORD="$POSTGRES_ADMIN_PASSWORD >> .env
  38. else
  39. while read line; do
  40. if [[ $line == *"POSTGRES_ADMIN_USER="* ]]; then
  41. POSTGRES_ADMIN_USER=$(echo $line | cut -c 21-)
  42. fi
  43. done < ".env"
  44. fi
  45. read -p 'Would you like to modify postgres rights for shared hosting? (y/n)' POSTGRES_SHARED_HOSTING
  46. docker-compose up -d
  47. echo 'Wait a few seconds for the container to spin up ...'
  48. sleep 5
  49. if [ $POSTGRES_SHARED_HOSTING == 'y' ]; then
  50. touch tmp
  51. echo "REVOKE ALL ON DATABASE template1 FROM public;" >> tmp
  52. echo "REVOKE ALL ON SCHEMA public FROM public;" >> tmp
  53. echo "GRANT ALL ON SCHEMA public TO "$POSTGRES_ADMIN_USER";" >> tmp
  54. echo "REVOKE ALL ON pg_user FROM public;" >> tmp
  55. echo "REVOKE ALL ON pg_roles FROM public;" >> tmp
  56. echo "REVOKE ALL ON pg_group FROM public;" >> tmp
  57. echo "REVOKE ALL ON pg_authid FROM public;" >> tmp
  58. echo "REVOKE ALL ON pg_auth_members FROM public;" >> tmp
  59. echo "REVOKE ALL ON pg_database FROM public;" >> tmp
  60. echo "REVOKE ALL ON pg_tablespace FROM public;" >> tmp
  61. echo "REVOKE ALL ON pg_settings FROM public;" >> tmp
  62. cat tmp | docker exec -i postgres psql -U $POSTGRES_ADMIN_USER -d template1
  63. rm -f tmp
  64. fi
  65. echo 'Done!'