114 lines
3.8 KiB
Bash
114 lines
3.8 KiB
Bash
#!/bin/bash
|
|
#
|
|
# Federated Computer Control Postgresql Service
|
|
|
|
PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
|
|
|
config_postgresql() {
|
|
echo -ne "\n* Configuring /federated/apps/postgresql container.."
|
|
spin &
|
|
SPINPID=$!
|
|
|
|
if [ ! -d "/federated/apps/postgresql" ]; then
|
|
mkdir -p /federated/apps/postgresql/data/var/lib/postgresql apps/postgresql/data/docker-entrypoint-initdb.d
|
|
cp /federated/apps/dns/data/etc/letsencrypt/archive/$DOMAIN/fullchain1.pem apps/postgresql/data/var/lib/postgresql/server.crt
|
|
cp /federated/apps/dns/data/etc/letsencrypt/archive/$DOMAIN/privkey1.pem apps/postgresql/data/var/lib/postgresql/server.key
|
|
chown 999 /federated/apps/postgresql/data/var/lib/postgresql/server.*
|
|
chmod 600 /federated/apps/postgresql/data/var/lib/postgresql/server.*
|
|
fi
|
|
|
|
DOMAIN_ARRAY=(${DOMAIN//./ })
|
|
DOMAIN_FIRST=${DOMAIN_ARRAY[0]}
|
|
DOMAIN_LAST=${DOMAIN_ARRAY[1]}
|
|
|
|
cat > /federated/apps/postgresql/docker-compose.yml <<EOF
|
|
version: "3.7"
|
|
|
|
services:
|
|
postgresql:
|
|
image: postgres:14
|
|
container_name: postgresql
|
|
hostname: postgresql.$DOMAIN
|
|
domainname: $DOMAIN
|
|
restart: always
|
|
networks:
|
|
federated:
|
|
ipv4_address: 172.99.0.40
|
|
volumes:
|
|
- ./data/var/lib/postgresql/server.crt:/var/lib/postgresql/server.crt
|
|
- ./data/var/lib/postgresql/server.key:/var/lib/postgresql/server.key
|
|
- ./data/var/lib/postgresql/data:/var/lib/postgresql/data
|
|
- ./data/docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d
|
|
environment:
|
|
- POSTGRES_DB=nextcloud
|
|
- POSTGRES_USER=nextcloud
|
|
- POSTGRES_PASSWORD=$ADMINPASS
|
|
- POSTGRES_INITDB_ARGS=--encoding='UTF8' --lc-collate='C' --lc-ctype='C'
|
|
command: >
|
|
-c ssl=on
|
|
-c ssl_cert_file=/var/lib/postgresql/server.crt
|
|
-c ssl_key_file=/var/lib/postgresql/server.key
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U nextcloud"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
networks:
|
|
federated:
|
|
external: true
|
|
EOF
|
|
|
|
# cat postgresql/data/docker-entrypoint-initdb.d/init.sql
|
|
cat > /federated/apps/postgresql/data/docker-entrypoint-initdb.d/init.sql <<EOF
|
|
CREATE USER vaultwarden WITH PASSWORD '$ADMINPASS';
|
|
CREATE DATABASE vaultwarden;
|
|
GRANT ALL PRIVILEGES ON DATABASE vaultwarden TO vaultwarden;
|
|
CREATE USER listmonk WITH PASSWORD '$ADMINPASS';
|
|
CREATE DATABASE listmonk;
|
|
GRANT ALL PRIVILEGES ON DATABASE listmonk TO listmonk;
|
|
CREATE USER matrix WITH PASSWORD '$ADMINPASS';
|
|
CREATE DATABASE matrix;
|
|
GRANT ALL PRIVILEGES ON DATABASE matrix TO matrix;
|
|
EOF
|
|
|
|
kill -9 $SPINPID &> /dev/null
|
|
echo -ne "done."
|
|
}
|
|
|
|
start_postgresql() {
|
|
# Start /federated/apps/postgresql with output to /dev/null
|
|
echo -ne "\n* Starting /federated/apps/postgresql service.."
|
|
spin &
|
|
SPINPID=$!
|
|
|
|
if [ $DEBUG ]; then
|
|
# Start /federated/apps/postgresql with output to console for debug
|
|
docker-compose -f /federated/apps/postgresql/docker-compose.yml -p postgresql up
|
|
[ $? -eq 0 ] && echo -ne "done.\n" || fail "There was a problem starting service /federated/apps/postgresql"
|
|
else
|
|
docker-compose -f /federated/apps/postgresql/docker-compose.yml -p postgresql up -d &> /dev/null
|
|
|
|
# Keep trying postgresql port 5432 to make sure it's up
|
|
# before we proceed
|
|
RETRY="30"
|
|
while [ $RETRY -gt 0 ]; do
|
|
nc -z 172.99.0.40 5432 &> /dev/null
|
|
if [ $? -eq 0 ]; then
|
|
break
|
|
else
|
|
if [ "$RETRY" == 1 ]; then
|
|
docker-compose -f /federated/apps/postgresql/docker-compose.yml -p postgresql down &> /dev/null
|
|
kill -9 $SPINPID &> /dev/null
|
|
fail "There was a problem starting service /federated/apps/postgresql\nCheck the output of 'docker logs postgresql' or turn on\ndebug with -d"
|
|
fi
|
|
((RETRY--))
|
|
sleep 7
|
|
fi
|
|
done
|
|
fi
|
|
|
|
kill -9 $SPINPID &> /dev/null
|
|
echo -ne "done."
|
|
}
|