-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathentrypoint
executable file
·61 lines (43 loc) · 1.62 KB
/
entrypoint
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!/bin/bash -e
RUNDIR=/run/postgresql
if [[ ${1:0:1} = '-' ]]; then
set -- postgres "$@"
fi
if [[ $1 = postgres ]]; then
mkdir -p "$PGDATA"
chmod 700 "$PGDATA"
chown -R postgres "$PGDATA" "$RUNDIR"
chmod g+s "$RUNDIR"
# look specifically for PG_VERSION, as it is expected in the DB dir
if [[ ! -s $PGDATA/PG_VERSION ]]; then
eval "gosu postgres initdb $POSTGRES_INITDB_ARGS"
if [[ -n $POSTGRES_PASSWORD ]]; then
pass="PASSWORD '$POSTGRES_PASSWORD'"
echo "host all all 0.0.0.0/0 md5" >> "$PGDATA/pg_hba.conf"
sed -ri "s|^#?(listen_addresses)\s*=\s*\S+.*|\1 = '*'|" $PGDATA/postgresql.conf
else
pass=
echo 'WARNING: No $POSTGRES_PASSWORD set! Only local access enabled.'
fi
gosu postgres pg_ctl -o "-c listen_addresses='localhost'" -w start
: ${POSTGRES_USER:=postgres}
: ${POSTGRES_DB:=$POSTGRES_USER}
export POSTGRES_USER POSTGRES_DB
psql=( psql -v ON_ERROR_STOP=1 )
if [[ $POSTGRES_DB != postgres ]]; then
"${psql[@]}" --username postgres <<<"CREATE DATABASE \"$POSTGRES_DB\";"
echo
fi
if [[ $POSTGRES_USER = postgres ]]; then
op='ALTER'
else
op='CREATE'
fi
"${psql[@]}" --username postgres <<<"$op USER \"$POSTGRES_USER\" WITH SUPERUSER $pass;"
psql+=( --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" )
gosu postgres pg_ctl -m fast -w stop
echo 'PostgreSQL init process complete; ready for start up.'
fi
exec gosu postgres "$@"
fi
exec "$@"