Project

General

Profile

1 8699 aaronmk
#!/bin/bash -e
2
# links to locally-available resources
3 8893 aaronmk
. "$(dirname "${BASH_SOURCE[0]}")"/util.sh
4 9854 aaronmk
.rel db.sh
5 9860 aaronmk
.rel make.sh
6 9854 aaronmk
.rel sync.sh
7 8699 aaronmk
8 8705 aaronmk
if self_not_included; then
9
10 9331 aaronmk
root_dir="$(canon_rel_path "$(dirname "${BASH_SOURCE[0]}")"/../..)" || return
11 9787 aaronmk
12 9793 aaronmk
root_rel_path() { echo_func; base_dir="$root_dir" canon_rel_path "$1"; }
13 9787 aaronmk
14 8699 aaronmk
bin_dir="$root_dir"/bin
15 9331 aaronmk
bin_dir_abs="$(realpath "$bin_dir")" || return
16 8705 aaronmk
17 8925 aaronmk
export PATH="$bin_dir_abs:$PATH"
18 8708 aaronmk
19 8939 aaronmk
#### make
20
21 9074 aaronmk
root_make() { echo_func; make --directory="$root_dir" "$@"; }
22 8939 aaronmk
23 8890 aaronmk
#### connection vars
24
25 9630 aaronmk
: "${remote_ssh_server=vegbiendev.nceas.ucsb.edu}"
26
: "${remote_server=}"
27 8890 aaronmk
: "${local_server=localhost}"
28
: "${local_user=bien}"
29
: "${local_password="$(cat "$root_dir"/config/bien_password)"}"
30 9650 aaronmk
: "${local_pg_database=vegbien}"
31 9575 aaronmk
: "${root_user=root}"
32
: "${root_password=$local_password}"
33 8890 aaronmk
34
#### databases
35
36
### MySQL
37
38 8891 aaronmk
: "${postgres_compat=1}"
39
40 9577 aaronmk
mysql_local() { echo_func; use_local_remote; mysql "$@"; }
41
42 9153 aaronmk
mysql_export_local() { echo_func; use_local_remote; mysql_export "$@"; }
43
44 9074 aaronmk
mysqldump_local() { echo_func; use_local_remote; mysqldump_diffable "$@"; }
45 8892 aaronmk
46 9576 aaronmk
mysql_root() { echo_func; use_local_remote; use_root; mysql "$@"; }
47
48 8890 aaronmk
### PostgreSQL
49
50 9650 aaronmk
func_override psql__db_sh
51 9074 aaronmk
psql() # usage: [file=...] [dir=...] self
52 8777 aaronmk
{
53 9235 aaronmk
	echo_func; kw_params file dir
54 9645 aaronmk
	if test "$file"; then local dir="${dir:-$(dirname "$file")}"; fi
55 8834 aaronmk
	local dir="${dir:-$top_dir}"
56 9427 aaronmk
	mk_schema_esc
57
	mk_table_esc
58 8777 aaronmk
59 9650 aaronmk
	use_local
60 8777 aaronmk
	(cat <<EOF
61
\cd $dir
62 9427 aaronmk
\set schema $schema_esc
63
\set table $table_esc
64
\set table_str '''$table_esc'''
65 9827 aaronmk
SET search_path TO $schema_esc;
66 8777 aaronmk
EOF
67 9645 aaronmk
	cat${file:+ "$file"}
68 9650 aaronmk
	)|psql__db_sh "$@"
69 8777 aaronmk
}
70
71 9074 aaronmk
public_schema_exists() { psql_script_vegbien </dev/null 2>/dev/null; }
72 9046 aaronmk
73 9801 aaronmk
74
#### sync
75
76
: "${sync_local_dir=$root_dir}"
77 10033 aaronmk
: "${sync_remote_subdir=bien/}"
78
: "${sync_remote_url=jupiter:/data/dev/aaronmk/$sync_remote_subdir}"
79 9801 aaronmk
80 9896 aaronmk
sync_upload() { echo_func; use_sync; upload --no-owner --no-group "$@"; }
81 9801 aaronmk
82 8705 aaronmk
fi