2026-03-03 14:07:29 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
# PostgreSQL initialization script for development environment
|
|
|
|
|
# Creates: workclub (application data), keycloak (Keycloak metadata)
|
|
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
|
|
# Create application database
|
|
|
|
|
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" <<-EOSQL
|
|
|
|
|
CREATE USER app WITH PASSWORD 'devpass';
|
|
|
|
|
CREATE DATABASE workclub OWNER app;
|
|
|
|
|
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON TABLES TO app;
|
|
|
|
|
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON SEQUENCES TO app;
|
|
|
|
|
EOSQL
|
|
|
|
|
|
|
|
|
|
# Create Keycloak database
|
|
|
|
|
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" <<-EOSQL
|
|
|
|
|
CREATE USER keycloak WITH PASSWORD 'keycloakpass';
|
|
|
|
|
CREATE DATABASE keycloak OWNER keycloak;
|
2026-03-05 11:07:12 +01:00
|
|
|
EOSQL
|
|
|
|
|
|
|
|
|
|
# Grant privileges in keycloak database
|
|
|
|
|
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "keycloak" <<-EOSQL
|
|
|
|
|
GRANT ALL ON SCHEMA public TO keycloak;
|
|
|
|
|
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON TABLES TO keycloak;
|
|
|
|
|
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON SEQUENCES TO keycloak;
|
2026-03-03 14:07:29 +01:00
|
|
|
EOSQL
|
|
|
|
|
|
|
|
|
|
echo "PostgreSQL initialization complete: workclub and keycloak databases created"
|