Commit | Line | Data |
---|---|---|
0155bbac JD |
1 | #!/bin/bash |
2 | OSRF="opensrf-2.1.0" | |
3 | INSTALLDIR="/srv/openils" | |
e83deee7 | 4 | HOSTNAME="nonprod" |
0155bbac JD |
5 | DEFAULT_USER="sitkastaff" |
6 | HOMEDIR="/home/${DEFAULT_USER}" | |
7 | SITKACONF="${HOMEDIR}/sysadmin" | |
8 | ||
5dfacac3 JD |
9 | # test for ejabberd passwords |
10 | if [ -z "$PRIVATE_ROUTER_PASSWD" -o -z "$PRIVATE_OPENSRF_PASSWD" -o -z "$PUBLIC_ROUTER_PASSWD" -o -z "$PUBLIC_OPENSRF_PASSWD" ] | |
11 | then | |
12 | echo "Missing ejabberd password(s), no OpenSRF install!" | |
13 | exit | |
14 | fi | |
15 | ||
0155bbac JD |
16 | # as root |
17 | usermod -a -G sudo ${DEFAULT_USER} | |
18 | apt-get install git-core build-essential translate-toolkit python-polib bsdmainutils | |
19 | ||
20 | # as DEFAULT_USER | |
21 | if [ ! -d "${SITKACONF}" ] | |
22 | then | |
23 | # this will fail unless DEFAULT_USER has read access to the repo | |
24 | su -l -c "cd ${HOMEDIR} && git clone git+ssh://git@git.sitka.bclibraries.ca/sitka-infra/sysadmin" ${DEFAULT_USER} | |
25 | fi | |
26 | su -l -c "cd ${HOMEDIR}/sysadmin && git pull" ${DEFAULT_USER} | |
27 | su -l -c "cd ${HOMEDIR} && wget http://open-ils.org/downloads/${OSRF}.tar.gz && tar xzf ${OSRF}.tar.gz" ${DEFAULT_USER} | |
28 | ||
29 | # as root | |
30 | echo "Installing OpenSRF prerequisites for Ubuntu..." | |
31 | cd ${HOMEDIR}/${OSRF} && make -f src/extras/Makefile.install ubuntu-precise | |
32 | ||
33 | # as DEFAULT_USER | |
34 | echo "Configuring and building OpenSRF..." | |
35 | su -l -c "cd ${HOMEDIR}/${OSRF} && autoreconf -i" ${DEFAULT_USER} | |
36 | su -l -c "cd ${HOMEDIR}/${OSRF} && ./configure --prefix=${INSTALLDIR} --sysconfdir=${INSTALLDIR}/conf" ${DEFAULT_USER} | |
37 | su -l -c "cd ${HOMEDIR}/${OSRF} && make" ${DEFAULT_USER} | |
38 | ||
39 | # as root | |
40 | echo "Installing OpenSRF..." | |
41 | cd ${HOMEDIR}/${OSRF} && make install | |
42 | useradd -m -s /bin/bash opensrf | |
43 | echo "export PATH=\$PATH:${INSTALLDIR}/bin" >> /home/opensrf/.bashrc | |
44 | chown -R opensrf:opensrf ${INSTALLDIR} | |
45 | ||
46 | # as root, add the following two lines to /etc/hosts: | |
47 | #127.0.1.2 public.localhost public | |
48 | #127.0.1.3 private.localhost private | |
49 | echo "Updating /etc/hosts..." | |
50 | echo -e "127.0.1.2\tpublic.localhost\tpublic\n127.0.1.3\tprivate.localhost\tprivate\n" | \ | |
51 | cat - /etc/hosts > /etc/hosts.new && mv /etc/hosts.new /etc/hosts | |
52 | ||
53 | # as root | |
54 | echo "ldconfig stuff..." | |
55 | echo "${INSTALLDIR}/lib" > /etc/ld.so.conf.d/opensrf.conf | |
56 | ldconfig | |
57 | ||
58 | # as root | |
59 | echo "Setting up ejabberd..." | |
e83deee7 | 60 | cp ${SITKACONF}/files/etc/ejabberd/ejabberd.cfg/${HOSTNAME} /etc/ejabberd/ejabberd.cfg |
0155bbac JD |
61 | chgrp ejabberd /etc/ejabberd/ejabberd.cfg |
62 | chmod 640 /etc/ejabberd/ejabberd.cfg | |
e83deee7 JD |
63 | /etc/init.d/ejabberd restart && sleep 10 && \ |
64 | ejabberdctl register router private.localhost ${PRIVATE_ROUTER_PASSWD} && \ | |
65 | ejabberdctl register opensrf private.localhost ${PRIVATE_OPENSRF_PASSWD} && \ | |
66 | ejabberdctl register router public.localhost ${PUBLIC_ROUTER_PASSWD} && \ | |
67 | ejabberdctl register opensrf public.localhost ${PUBLIC_OPENSRF_PASSWD} | |
0155bbac JD |
68 | |
69 | echo "OpenSRF is installed!" |