-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathdwh
executable file
·80 lines (73 loc) · 2.34 KB
/
dwh
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/bin/bash
if [ -z "$COOG_CODE_DIR" ] || [ ! -d "$COOG_CODE_DIR" ] || [ -z "$COOG_DATA_DIR" ]
then
{
echo "Please make sure that these two env vars are set:"
echo " COOG_CODE_DIR: your coog-admin install folder"
echo " COOG_DATA_DIR: the folder where to keep your custom config"
} >&2 && exit 1
fi
server() {
docker run \
$DOCKER_DAEMON_OPTS \
--network "$NETWORK_NAME" \
--name "$NETWORK_NAME-dwh" \
-e "POSTGRES_USER=$DWH_USER" \
-e "POSTGRES_PASSWORD=$DWH_PASSWORD" \
-e "PGDATA=/var/lib/postgresql/data/pgdata" \
-v /usr/share/zoneinfo:/usr/share/zoneinfo:ro \
-v /etc/timezone:/etc/timezone:ro \
-v "$DWH_VOLUME:/var/lib/postgresql/data" \
"$DWH_IMAGE" "$@"
}
client() {
docker run \
$DOCKER_INTERACTIVE_OPTS \
--network "$NETWORK_NAME" \
"$DWH_IMAGE" \
psql -h "$NETWORK_NAME-dwh" -U "$DWH_USER" "$@"
}
dump() {
if [ -z "$DWH_HOST" ]
then
docker run \
$DOCKER_PIPED_OPTS \
--network "$NETWORK_NAME" \
-e PGHOST="$NETWORK_NAME-dwh" \
-e PGUSER="$DWH_USER" \
-e PGPASSWORD="$DWH_PASSWORD" \
"$DWH_IMAGE" \
pg_dump "$DWH_DB_NAME" "$@"
else
docker run \
$DOCKER_PIPED_OPTS \
-e PGHOST="$DWH_HOST" \
-e PGUSER="$DWH_USER" \
-e PGPASSWORD="$DWH_PASSWORD" \
"$DWH_IMAGE" \
pg_dump "$DWH_DB_NAME" "$@"
fi
}
usage() {
echo
echo Available commands
echo
echo " server -> runs a datawarehouse postgres docker image as a server"
echo " client -> runs a datawarehouse postgres docker image as a client"
echo " dump -> creates a dump of datawarehouse database"
echo " <action> -> calls docker action on server container"
echo
}
main() {
source "$COOG_CODE_DIR/config"
[ ! -z "$PGUSER" ] && DWH_USER="$PGUSER"
[ ! -z "$PGPASSWORD" ] && DWH_PASSWORD="$PGPASSWORD"
[ ! -z "$DB_NAME" ] && DWH_DB_NAME="$DB_NAME"
[ -z "$1" ] && usage && return 0
local cmd; cmd=$1; shift
[ "$cmd" = "server" ] && { server "$@"; return $?; }
[ "$cmd" = "client" ] && { client "$@"; return $?; }
[ "$cmd" = "dump" ] && { dump "$@"; return $?; }
docker "$cmd" "$@" "$NETWORK_NAME-dwh"
}
main "$@"