Browse Source

feat: create setup script

master
bucde 3 years ago
parent
commit
43058cfd51
2 changed files with 56 additions and 4 deletions
  1. +4
    -4
      docker-compose.yml
  2. +52
    -0
      setup

+ 4
- 4
docker-compose.yml View File

@ -2,15 +2,15 @@ version: "3.4"
services: services:
postgres: postgres:
container_name: postgres container_name: postgres
image: postgres:13.4
image: postgres:${POSTGRES_VERSION:-latest}
restart: unless-stopped restart: unless-stopped
ports: ports:
- <host-ip-address>:5432:5432
- ${POSTGRES_HOST_IP_ADDRESS:-127.0.0.1}:${POSTGRES_HOST_PORT:-5432}:5432
volumes: volumes:
- pgdata:/var/lib/postgresql/data - pgdata:/var/lib/postgresql/data
environment: environment:
POSTGRES_USER: <user>
POSTGRES_PASSWORD: <password>
POSTGRES_USER: ${POSTGRES_ADMIN_USER:-sysadmin}
POSTGRES_PASSWORD: ${POSTGRES_ADMIN_PASSWORD:-password}
volumes: volumes:
pgdata: pgdata:

+ 52
- 0
setup View File

@ -0,0 +1,52 @@
#!/bin/bash
echo '####################################################################'
echo '# docker_postgres_setup_script #'
echo '# Dennis Buchhorn - bucde@b-eit.de #'
echo '####################################################################'
echo ''
POSTGRES_VERSION=''
POSTGRES_HOST_IP_ADDRESS=''
POSTGRES_HOST_PORT=''
POSTGRES_ADMIN_USER=''
POSTGRES_ADMIN_PASSWORD=''
POSTGRES_SHARED_HOSTING='y'
read -p 'Enter postgres version which should be used: ' POSTGRES_VERSION
read -p 'Enter host (vm) ip address on which postgres should be accessible: ' POSTGRES_HOST_IP_ADDRESS
read -p 'Enter host (vm) port on which postgres should be accessible: ' POSTGRES_HOST_PORT
read -p 'Enter admin user name for postgres: ' POSTGRES_ADMIN_USER
read -p 'Enter admin password for postgres: ' POSTGRES_ADMIN_PASSWORD
read -p 'Would you like to modify postgres rights for shared hosting? (Y/n)' POSTGRES_SHARED_HOSTING
touch .env
echo "POSTGRES_VERSION="$POSTGRES_VERSION >> .env
echo "POSTGRES_HOST_IP_ADDRESS="$POSTGRES_HOST_IP_ADDRESS >> .env
echo "POSTGRES_HOST_PORT="$POSTGRES_HOST_PORT >> .env
echo "POSTGRES_ADMIN_USER="$POSTGRES_ADMIN_USER >> .env
echo "POSTGRES_ADMIN_PASSWORD="$POSTGRES_ADMIN_PASSWORD >> .env
docker-compose up -d
sleep 5
if [ $POSTGRES_SHARED_HOSTING == 'y' ]; then
touch tmp
echo "REVOKE ALL ON DATABASE template1 FROM public;" >> tmp
echo "REVOKE ALL ON SCHEMA public FROM public;" >> tmp
echo "GRANT ALL ON SCHEMA public TO "$POSTGRES_ADMIN_USER";" >> tmp
echo "REVOKE ALL ON pg_user FROM public;" >> tmp
echo "REVOKE ALL ON pg_roles FROM public;" >> tmp
echo "REVOKE ALL ON pg_group FROM public;" >> tmp
echo "REVOKE ALL ON pg_authid FROM public;" >> tmp
echo "REVOKE ALL ON pg_auth_members FROM public;" >> tmp
echo "REVOKE ALL ON pg_database FROM public;" >> tmp
echo "REVOKE ALL ON pg_tablespace FROM public;" >> tmp
echo "REVOKE ALL ON pg_settings FROM public;" >> tmp
cat tmp | docker exec -i postgres psql -U $POSTGRES_ADMIN_USER -d template1
rm -f tmp

Loading…
Cancel
Save