1
|
#!/bin/bash -e
|
2
|
# links to locally-available resources
|
3
|
. "$(dirname "${BASH_SOURCE[0]}")"/util.sh
|
4
|
|
5
|
if self_not_included; then
|
6
|
|
7
|
root_dir="$(dirname "${BASH_SOURCE[0]}")"/..
|
8
|
bin_dir="$root_dir"/bin
|
9
|
|
10
|
export PATH="$bin_dir:$PATH"
|
11
|
|
12
|
#### connection vars
|
13
|
|
14
|
: "${remote_server=vegbiendev.nceas.ucsb.edu}"
|
15
|
: "${local_server=localhost}"
|
16
|
: "${local_user=bien}"
|
17
|
: "${local_password="$(cat "$root_dir"/config/bien_password)"}"
|
18
|
|
19
|
#### databases
|
20
|
|
21
|
### MySQL
|
22
|
|
23
|
: "${postgres_compat=1}"
|
24
|
|
25
|
mysql ()
|
26
|
{
|
27
|
echo_func
|
28
|
echo_run mysql_bien --database="$schema" --verbose "$@"
|
29
|
}
|
30
|
|
31
|
mysqldump_local ()
|
32
|
{
|
33
|
echo_func
|
34
|
use_local_remote; mysqldump_diffable "$@"
|
35
|
}
|
36
|
|
37
|
### PostgreSQL
|
38
|
|
39
|
psql () # usage: [file=...] [dir=...] self
|
40
|
{
|
41
|
echo_func
|
42
|
if test -n "$file"; then
|
43
|
set -- --file "$file" "$@"
|
44
|
local dir="${dir:-$(dirname "$file")}"
|
45
|
fi
|
46
|
local dir="${dir:-$top_dir}"
|
47
|
|
48
|
local psql_cmd="psql_$(if log_sql; then echo verbose; else echo script; fi)_vegbien"
|
49
|
(cat <<EOF
|
50
|
\cd $dir
|
51
|
\set schema "$schema"
|
52
|
\set table "$table"
|
53
|
\set table_str '''"$table"'''
|
54
|
SET search_path TO "$schema", util;
|
55
|
EOF
|
56
|
cat)|
|
57
|
env no_search_path=1 "$psql_cmd" --output /dev/fd/3 "$@" 3>&1 >&2
|
58
|
}
|
59
|
|
60
|
fi
|