Commit | Line | Data |
---|---|---|
0155bbac JD |
1 | #!/bin/bash |
2 | # IMPORTANT! This script assumes you have already installed OpenSRF. | |
3 | ||
71f85432 | 4 | HOSTNAME="nonprod-28" |
0155bbac JD |
5 | DEFAULT_USER="sitkastaff" |
6 | HOMEDIR="/home/${DEFAULT_USER}" | |
ae9cb412 JD |
7 | #EGRELEASE="Evergreen-ILS-2.8.beta" |
8 | #BUILDDIR="${HOMEDIR}/${EGRELEASE}" | |
9 | BUILDDIR="${HOMEDIR}/evergreen" | |
0155bbac | 10 | INSTALLDIR="/srv/openils" |
fae89064 | 11 | BRANCH="production/sitka_2_8_tpac" |
df5285f4 JD |
12 | STAMP_ID="rel_2_8_1" |
13 | ALT_STAMP_IDS="2_8_1 rel_2_8_beta 2_8_beta rel_2_8_0 2_8_0" | |
4115cc36 | 14 | VERSION="2.8.1.sitka.0" |
0155bbac | 15 | SITKACONF="${HOMEDIR}/sysadmin" |
fae89064 | 16 | SITKACONF_BRANCH="master" |
341cf34e | 17 | SITKATOOLS="/root/sitka-tools" |
0155bbac | 18 | |
e724d7db | 19 | suwrap() { |
e2ad4781 | 20 | su -s /bin/bash -c "source ~/.bashrc ; $1" $2 |
e724d7db JD |
21 | } |
22 | ||
24057702 JD |
23 | while getopts ":p" opt ; do |
24 | case $opt in | |
25 | p ) PROD="prod";; | |
f3b555fc | 26 | e ) EDI="edi";; |
24057702 JD |
27 | esac |
28 | done | |
29 | shift $(($OPTIND - 1)) | |
30 | ||
31 | if [[ -n "$PROD" ]] ; then | |
32 | echo 'this is a production install' | |
33 | else | |
34 | echo 'this is NOT a production install' | |
35 | fi | |
36 | ||
0155bbac JD |
37 | # as DEFAULT_USER |
38 | ||
39 | # grab Sitka config files | |
40 | if [ ! -d "${SITKACONF}" ] | |
41 | then | |
42 | # this will fail unless DEFAULT_USER has read access to the repo | |
e724d7db | 43 | suwrap "cd ${HOMEDIR} && git clone git+ssh://git@git.sitka.bclibraries.ca/sitka-infra/sysadmin" ${DEFAULT_USER} |
0155bbac | 44 | fi |
902a19b7 | 45 | suwrap "cd ${SITKACONF} && git fetch origin && git checkout ${SITKACONF_BRANCH} && git pull" ${DEFAULT_USER} |
0155bbac JD |
46 | |
47 | # checkout EG source | |
ae9cb412 JD |
48 | if [ ! -d "${BUILDDIR}" ] |
49 | then | |
50 | suwrap "cd ${HOMEDIR} && git clone git://git.sitka.bclibraries.ca/sitka/evergreen evergreen" ${DEFAULT_USER} | |
51 | fi | |
52 | suwrap "cd ${BUILDDIR} && git fetch origin && git checkout ${BRANCH} && git pull" ${DEFAULT_USER} | |
71f85432 JD |
53 | |
54 | # download and unpack EG release | |
ae9cb412 JD |
55 | #rm -rf ${BUILDDIR} |
56 | #suwrap "cd ${HOMEDIR} && wget http://open-ils.org/downloads/${EGRELEASE}.tar.gz && tar xzf ${EGRELEASE}.tar.gz" ${DEFAULT_USER} | |
0155bbac JD |
57 | |
58 | # as root | |
71f85432 | 59 | cd ${BUILDDIR} && make -f Open-ILS/src/extras/Makefile.install ubuntu-trusty |
4115cc36 | 60 | #cd ${BUILDDIR} && make -f Open-ILS/src/extras/Makefile.install ubuntu-trusty-developer # required for web client |
0155bbac JD |
61 | # by default, CPAN needs some manual input at this point; you can just accept all defaults |
62 | ||
63 | # as DEFAULT_USER | |
ae9cb412 | 64 | suwrap "cd ${BUILDDIR} && autoreconf -i" ${DEFAULT_USER} # not required for release versions |
f4c3759b | 65 | suwrap "PATH=${INSTALLDIR}/bin:\$PATH cd ${BUILDDIR} && PATH=${INSTALLDIR}/bin:\$PATH ./configure -C --prefix=${INSTALLDIR} --sysconfdir=${INSTALLDIR}/conf --with-opensrf-headers=${INSTALLDIR}/include/ --with-opensrf-libs=${INSTALLDIR}/lib/" ${DEFAULT_USER} |
e724d7db | 66 | suwrap "cd ${BUILDDIR} && make" ${DEFAULT_USER} |
691245a2 | 67 | suwrap "cd ${BUILDDIR}/build/i18n && make LOCALE=fr-CA install && make LOCALE=en-CA install" ${DEFAULT_USER} |
0155bbac JD |
68 | |
69 | # as root | |
4115cc36 | 70 | cd ${BUILDDIR} && make STAFF_CLIENT_VERSION=${VERSION} STAFF_CLIENT_STAMP_ID=${STAMP_ID} install |
ae9cb412 | 71 | mv ${INSTALLDIR}/var/web/reports/fm_IDL.xml ${INSTALLDIR}/var/web/reports/fm_IDL.xml.orig && cp ${INSTALLDIR}/conf/fm_IDL.xml ${INSTALLDIR}/var/web/reports/ |
0155bbac JD |
72 | chown -R opensrf:opensrf ${INSTALLDIR} |
73 | ||
74 | # Apache stuff (as root): | |
661d99f4 | 75 | APACHEFILES="/etc/apache2/eg_vhost.conf /etc/apache2/eg_startup /etc/apache2/sites-available/eg.conf /etc/apache2/envvars" |
0155bbac JD |
76 | for APACHEFILE in ${APACHEFILES} |
77 | do | |
bd41f68d | 78 | mv ${APACHEFILE} ${APACHEFILE}.bak |
0155bbac JD |
79 | cp ${SITKACONF}/files/${APACHEFILE}/${HOSTNAME} ${APACHEFILE} |
80 | done | |
ae9cb412 JD |
81 | #a2dissite 000-default |
82 | #a2ensite eg.conf | |
83 | #if [ ! -d "/etc/apache2/ssl" ] | |
84 | #then | |
85 | # mkdir /etc/apache2/ssl | |
86 | # cd /etc/apache2/ssl && openssl req -new -x509 -days 365 -nodes -out server.crt -keyout server.key | |
87 | #fi | |
71f85432 JD |
88 | # ensure opensrf can run Apache |
89 | chown -R opensrf:opensrf /var/lock/apache2 | |
7d30f3bf | 90 | |
26b3ea66 | 91 | # set up log rotation |
702f0bd2 JD |
92 | if [[ ! -n "$PROD" ]] ; then |
93 | if [ ! -f "/etc/logrotate.d/evergreen" ] | |
94 | then | |
95 | cp ${SITKACONF}/files/etc/logrotate.d/evergreen/${HOSTNAME} /etc/logrotate.d/evergreen | |
96 | fi | |
26b3ea66 | 97 | fi |
0155bbac | 98 | |
0155bbac JD |
99 | # 0. osrf conf stuff |
100 | # FIXME: ensure osrf conf files point at a real, distinct db! | |
101 | OSRFCONFFILES="${INSTALLDIR}/conf/opensrf.xml ${INSTALLDIR}/conf/opensrf_core.xml" | |
102 | for OSRFCONFFILE in ${OSRFCONFFILES} | |
103 | do | |
51a4755a | 104 | mv ${OSRFCONFFILE} ${OSRFCONFFILE}.bak |
0155bbac JD |
105 | cp ${SITKACONF}/files/${OSRFCONFFILE}/${HOSTNAME} ${OSRFCONFFILE} |
106 | done | |
661d99f4 | 107 | if [ ! -f "/home/opensrf/.srfsh.xml" ] |
9d46f12d | 108 | then |
661d99f4 | 109 | cp ${SITKACONF}/files/home/opensrf/.srfsh.xml/${HOSTNAME} /home/opensrf/.srfsh.xml |
9d46f12d JD |
110 | fi |
111 | ||
0155bbac | 112 | # 1. install dojo |
abcafeff | 113 | if [ ! -f "/home/opensrf/dojo-release-1.3.3.tar.gz" ] |
51a4755a JD |
114 | then |
115 | cd /home/opensrf && wget http://download.dojotoolkit.org/release-1.3.3/dojo-release-1.3.3.tar.gz | |
116 | fi | |
0155bbac JD |
117 | tar -C ${INSTALLDIR}/var/web/js -xzf /home/opensrf/dojo-release-1.3.3.tar.gz |
118 | cp -r ${INSTALLDIR}/var/web/js/dojo-release-1.3.3/* ${INSTALLDIR}/var/web/js/dojo/. | |
119 | ||
120 | # 2. set up staff client | |
9d46f12d | 121 | cd ${INSTALLDIR}/var/web/xul && rm server && rm current |
0155bbac | 122 | cd ${INSTALLDIR}/var/web/xul && ln -s ${STAMP_ID} current && ln -s current/server server |
03b5e41f JD |
123 | for ALT_STAMP_ID in ${ALT_STAMP_IDS} |
124 | do | |
125 | cd ${INSTALLDIR}/var/web/xul && ln -s current ${ALT_STAMP_ID} | |
126 | done | |
0155bbac | 127 | |
9d46f12d | 128 | # 3. install circ scripts and opac skins - DEPRECATED |
71f85432 | 129 | |
96b76bbb JD |
130 | # 4a. avoid 404s |
131 | touch ${INSTALLDIR}/var/web/css/skin/default/register_custom.css | |
132 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-CA/patron_custom.properties | |
133 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-CA/common_custom.properties | |
134 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-CA/offline_custom.properties | |
135 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-CA/auth_custom.properties | |
136 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-CA/cat_custom.properties | |
137 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-CA/circ_custom.properties | |
138 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-US/patron_custom.properties | |
139 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-US/common_custom.properties | |
140 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-US/offline_custom.properties | |
141 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-US/auth_custom.properties | |
142 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-US/cat_custom.properties | |
143 | touch ${INSTALLDIR}/var/web/xul/server/locale/en-US/circ_custom.properties | |
144 | touch ${INSTALLDIR}/var/web/xul/server/skin/custom.js | |
145 | ||
146 | # 4b. workaround for LP#1461683 | |
147 | cd ${INSTALLDIR}/var/web/xul/server/locale/en-CA && mv multiclass_search_help.html multiclass_search_help.html.orig && ln -s ../en-US/multiclass_search_help.html | |
71f85432 JD |
148 | |
149 | # 5. locale hack - XXX deprecated? | |
150 | #cd ${INSTALLDIR}/var/web/opac/locale && cp -fdr en-US en-US-bak && cp -fdr en-CA en-US | |
0155bbac JD |
151 | |
152 | # 6. deletepatron | |
153 | # ensure apache conf contains deletepatron config (location should be ${INSTALLDIR}/var/web/deletepatron) | |
437b75c1 JD |
154 | if [[ ! -d "${INSTALLDIR}/var/web/deletepatron" ]] ; then |
155 | NEW_DELETEPATRON_INSTALL="true" | |
156 | cd ${INSTALLDIR}/var/web && git clone https://github.com/twirlip/deletepatron.git | |
157 | fi | |
158 | cd ${INSTALLDIR}/var/web/deletepatron && git checkout eg22 | |
159 | if [[ -n "$NEW_DELETEPATRON_INSTALL" ]] ; then | |
160 | find ${INSTALLDIR}/var/web/deletepatron -name "*.pm" | xargs sed -i -e 's|/openils|/srv/openils|g' | |
161 | fi | |
ae9cb412 | 162 | apt-get install -y libcgi-session-perl libhtml-template-perl |
0155bbac | 163 | |
f3b555fc JD |
164 | # 7. support scripts |
165 | cp ${BUILDDIR}/Open-ILS/src/support-scripts/generate_circ_notices.pl ${INSTALLDIR}/bin | |
22b9d1ac | 166 | cp ${BUILDDIR}/Open-ILS/src/support-scripts/oils_header.pl ${INSTALLDIR}/bin |
f3b555fc JD |
167 | |
168 | # 7.5 EDI (optional) | |
169 | if [[ -n "$EDI" ]] ; then | |
170 | cp -r ${BUILDDIR}/Open-ILS/src/edi_translator ${INSTALLDIR}/var/edi | |
171 | cd ${INSTALLDIR}/var/edi && ./install.sh | |
172 | cp ${BUILDDIR}/Open-ILS/src/support-scripts/edi_pusher.pl ${INSTALLDIR}/bin | |
173 | cp ${BUILDDIR}/Open-ILS/src/support-scripts/edi_fetcher.pl ${INSTALLDIR}/bin | |
174 | cp ${SYSADMIN}/files/${INSTALLDIR}/bin/edi_per_account_fetcher.sh ${INSTALLDIR}/bin/edi_per_account_fetcher.sh | |
175 | fi | |
0155bbac | 176 | |
c05e3516 JD |
177 | # 8. setup start page |
178 | if [ ! -d "${INSTALLDIR}/var/web/news" ] | |
179 | then | |
180 | mkdir ${INSTALLDIR}/var/web/news | |
181 | fi | |
24057702 JD |
182 | if [ ! -d "${INSTALLDIR}/var/web/news/media" ] |
183 | then | |
184 | mkdir ${INSTALLDIR}/var/web/news/media | |
185 | fi | |
186 | NEWSFILES="index.html style.css media/logo.png media/book.png media/policy.png media/dash.png media/delete.png" | |
c05e3516 JD |
187 | for NEWSFILE in ${NEWSFILES} |
188 | do | |
189 | if [ -f "${SITKACONF}/files/${INSTALLDIR}/var/web/news/${NEWSFILE}/${HOSTNAME}" ] | |
190 | then | |
191 | cp ${SITKACONF}/files/${INSTALLDIR}/var/web/news/${NEWSFILE}/${HOSTNAME} ${INSTALLDIR}/var/web/news/${NEWSFILE} | |
192 | fi | |
193 | done | |
24057702 JD |
194 | if [[ -n "$PROD" ]] ; then |
195 | if [ ! -e "${INSTALLDIR}/var/web/news/wikipull.pl" ] ; then cp ${SITKACONF}/files/${INSTALLDIR}/var/web/news/wikipull.pl/${HOSTNAME} ${INSTALLDIR}/var/web/news/wikipull.pl ; fi | |
196 | if [ ! -e "/etc/cron.d/news" ] ; then cp ${SITKACONF}/files/etc/cron.d/news/${HOSTNAME} /etc/cron.d/news ; fi | |
197 | fi | |
c05e3516 | 198 | |
341cf34e | 199 | # 8.5 offline patron list |
24057702 JD |
200 | if [ ! -d "${INSTALLDIR}/var/data/offline/blocked" ] ; then |
201 | # TODO: handle prod - an NFS share should exist | |
202 | if [[ ! -n "$PROD" ]] ; then | |
203 | mkdir -p ${INSTALLDIR}/var/data/offline/blocked | |
204 | fi | |
205 | fi | |
437b75c1 | 206 | if [ ! -e "${INSTALLDIR}/var/web/standalone/list.txt" ] ; then ln -sf ${INSTALLDIR}/var/data/offline/blocked/patron-block-list.txt ${INSTALLDIR}/var/web/standalone/list.txt ; fi |
341cf34e JD |
207 | if [ ! -e "${INSTALLDIR}/bin/update-offline-blocked-list.sh" ] ; then cp ${SITKATOOLS}/maintenance/update-offline-blocked-list.sh ${INSTALLDIR}/bin/update-offline-blocked-list.sh ; fi |
208 | ||
f37d71da | 209 | cp ${SITKACONF}/files${INSTALLDIR}/var/data/zips.txt/${HOSTNAME} ${INSTALLDIR}/var/data/zips.txt |
661d99f4 | 210 | |
02bd66d5 JD |
211 | cp -r ${SITKATOOLS}/overdrive-eg-opac/build/* ${INSTALLDIR}/var/web/js/ui/default/opac |
212 | ODAPI_LIBS="bc mb" | |
213 | for ODAPI_LIB in ${ODAPI_LIBS} ; do | |
d8761dca | 214 | cp ${SITKACONF}/files/${INSTALLDIR}/var/web/js/ui/default/opac/${ODAPI_LIB}/od_config.js ${INSTALLDIR}/var/web/js/ui/default/opac/${ODAPI_LIB}/od_config.js |
02bd66d5 JD |
215 | done |
216 | ||
c05e3516 | 217 | # 9. make sure opensrf owns all the stuff we just did |
0155bbac | 218 | chown -R opensrf:opensrf ${INSTALLDIR} |
d4e88b8a | 219 | chown -R opensrf:opensrf /home/opensrf |
7f126d3b JD |
220 | SKINDIRS="${INSTALLDIR}/var/skins ${INSTALLDIR}/var/web/css/skin" |
221 | for SKINDIR in ${SKINDIRS} ; do | |
222 | if [[ ! -d "${SKINDIR}" ]] ; then mkdir ${SKINDIR} ; fi | |
223 | chmod 777 ${SKINDIR} | |
224 | chown -R sitkastaff:sitkastaff ${SKINDIR} | |
225 | done | |
0155bbac | 226 | |
d4e88b8a | 227 | # 10. staff client stuff |
ae9cb412 | 228 | apt-get install -y nsis unzip |
089f11fb JD |
229 | |
230 | # 11. integrity checker prereqs | |
ae9cb412 | 231 | apt-get install -y libconfig-simple-perl libgit-repository-perl libdate-manip-perl |
ee1de43f JD |
232 | |
233 | # 12. paper overdue prereqs | |
5e12a76f | 234 | apt-get install -y python-reportlab python-reportlab-accel unifont |