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.
24 lines
735 B
24 lines
735 B
2 years ago
|
#!/bin/bash
|
||
|
|
||
|
set -e
|
||
|
set -u
|
||
|
|
||
|
function create_user_and_database() {
|
||
|
local database=$(echo $1 | tr ',' ' ' | awk '{print $1}')
|
||
|
local owner=$(echo $1 | tr ',' ' ' | awk '{print $2}')
|
||
|
echo " Creating user and database '$database'"
|
||
|
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" <<-EOSQL
|
||
|
CREATE USER $owner IF NOT EXISTS;
|
||
|
ALTER USER $owner PASSWORD $database;
|
||
|
CREATE DATABASE $database;
|
||
|
GRANT ALL PRIVILEGES ON DATABASE $database TO $owner;
|
||
|
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_user_and_database $db
|
||
|
done
|
||
|
echo "Multiple databases created"
|
||
|
fi
|