]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/src/sql/Pg/build-db.sh
LP#1845260: fix error in vandelay.auto_overlay_org_unit_copies db function
[working/Evergreen.git] / Open-ILS / src / sql / Pg / build-db.sh
1 #!/bin/sh
2
3 # ---------------------------------------------------------------------------
4 # Store command line args for later use
5 # args: {db-host} {db-port} {db-name} {db-user} {db-password} {verbose}
6 # ---------------------------------------------------------------------------
7 PGHOST=$1
8 PGPORT=$2
9 PGDATABASE=$3
10 PGUSER=$4
11 PGPASSWORD=$5
12 VERBOSE=$6
13 export PGHOST PGPORT PGDATABASE PGUSER PGPASSWORD
14
15 # ---------------------------------------------------------------------------
16 # Lookup the database version from the PostgreSQL server.
17 # ---------------------------------------------------------------------------
18 DB_VERSION=`psql -qtc 'show server_version;' | xargs | cut -d. -f 1,2 | tr -d '.' | cut -c1,2`
19 if [ -z "$DB_VERSION" ] || [ `echo $DB_VERSION | grep -c '[^0-9]'` != 0 ]; then
20   cat <<EOM
21 ********************************************************************************
22 * Could not determine the version of PostgreSQL you have installed.  Our best  *
23 * guess was:                                                                   *
24 * $DB_VERSION
25 * which didn't make any sense.  For assistance, please email                   *
26 * open-ils-general@list.georgialibraries.org or join #Evergreen on the         *
27 * freenode IRC network.                                                        *
28 ********************************************************************************
29 EOM
30   exit 1
31 fi
32
33 # ---------------------------------------------------------------------------
34 # Validate fts-config file is available for specified DB_VERSION.
35 # ---------------------------------------------------------------------------
36 if [ -e "000.english.pg$DB_VERSION.fts-config.sql" ]; then
37   fts_config_file="000.english.pg$DB_VERSION.fts-config.sql"
38 else
39   # -------------------------------------------------------------------------
40   # Attempt to auto-detect the latest available config file.
41   # -------------------------------------------------------------------------
42   last_ver=""
43   for i in $(seq 80 99 | sort -rn); do
44     if [ -e "000.english.pg$i.fts-config.sql" ]; then
45       last_ver=$i
46       break
47     fi
48   done
49   if [ -z "$last_ver" ]; then
50     cat <<EOM
51 ********************************************************************************
52 * Cannot locate any configuration files for  full text search config.  This    *
53 * may indicate a problem with your copy of the source files.  We attempted to  *
54 * find files like 000.english.pg83.fts-config.sql in this directory:           *
55 * `pwd` 
56 * but were unsuccessful.  Aborting.                                            *
57 ********************************************************************************
58 EOM
59     exit 1
60   fi
61
62   a=$DB_VERSION  # preserves the text alignment below, in a cheap fashion
63   b=$last_ver    # assuming of course two character DB_VERSION and last_ver
64 cat <<EOM
65 ********************************************************************************
66 * There is no configuration for full text search config, for the database      *
67 * version you have installed ($a).  If you're not really sure why, you should  *
68 * proabably press 'Control-C' now, and abort.  To continue using the latest    *
69 * available version ($b), press enter. For assistance, please email            *
70 * open-ils-general@list.georgialibraries.org or join #Evergreen on the         *
71 * freenode IRC network.                                                        *
72 ********************************************************************************
73 EOM
74   read unused
75   fts_config_file="000.english.pg$last_ver.fts-config.sql"
76 fi
77
78 # ---------------------------------------------------------------------------
79 # Import files via psql, warn user on error, suggest abort.  SQL scripts
80 # are processed in the ordered listed in sql_file_manifest.
81 # ---------------------------------------------------------------------------
82 cat sql_file_manifest | while read sql_file; do
83   if [ `expr "$sql_file" : "^#"` = 1 ] || [ "$sql_file" = '' ]; then
84     continue;
85   fi
86
87   if [ $sql_file = 'FTS_CONFIG_FILE' ]; then
88     sql_file=$fts_config_file
89   fi
90
91   # It would be wise to turn this on only if confidence is high that errors in
92   # scripts will result in terminal failures.  Currently, there are a couple
93   # that seem benign.  --asjoyner
94   # export ON_ERROR_STOP=1
95
96   export PGHOST PGPORT PGDATABASE PGUSER PGPASSWORD
97   # Hide most of the harmless messages that obscure real problems
98   if [ -z "$VERBOSE" ]; then
99     psql -v eg_version=NULL -f $sql_file 2>&1 | grep -v NOTICE | grep -v "^INSERT"
100   else
101     psql -v eg_version=NULL -f $sql_file
102   fi
103   if [ $? != 0 ]; then
104     cat <<EOM
105 ********************************************************************************
106 * There was an error with a database configuration file:                       *
107 * $sql_file
108 * It is very likely that your installation will be unsuccessful because of     *
109 * this error.  Press Control-C to abort, or press enter to charge ahead.       *
110 ********************************************************************************
111 EOM
112     read unused
113   fi
114 done
115