rwadurian/backend/services/init-multiple-dbs.sh

27 lines
960 B
Bash

#!/bin/bash
# =============================================================================
# PostgreSQL - Initialize Multiple Databases
# =============================================================================
# This script creates multiple databases from POSTGRES_MULTIPLE_DATABASES env var
# =============================================================================
set -e
set -u
function create_database() {
local database=$1
echo "Creating database '$database'"
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" <<-EOSQL
SELECT 'CREATE DATABASE $database'
WHERE NOT EXISTS (SELECT FROM pg_database WHERE datname = '$database')\gexec
EOSQL
}
if [ -n "$POSTGRES_MULTIPLE_DATABASES" ]; then
echo "Multiple database creation requested: $POSTGRES_MULTIPLE_DATABASES"
for db in $(echo $POSTGRES_MULTIPLE_DATABASES | tr ',' ' '); do
create_database $db
done
echo "Multiple databases created"
fi