install-osrf.sh: insert hostname in ejabberd.cfg if applicable
[sitka/sitka-tools.git] / deployment / install-osrf.sh
1 #!/bin/bash
2 DEFAULT_USER="sitkastaff"
3 HOMEDIR="/home/${DEFAULT_USER}"
4 BUILDDIR="${HOMEDIR}/opensrf"
5 INSTALLDIR="/srv/openils"
6 BRANCH="rel_2_4"
7 HOSTNAME="nonprod"
8 SITKACONF="${HOMEDIR}/sysadmin"
9 SITKACONF_BRANCH="eg210"
10
11 # test for ejabberd passwords
12 if [ -z "$PRIVATE_ROUTER_PASSWD" -o -z "$PRIVATE_OPENSRF_PASSWD" -o -z "$PUBLIC_ROUTER_PASSWD" -o -z "$PUBLIC_OPENSRF_PASSWD" ]
13 then
14   echo "Missing ejabberd password(s), no OpenSRF install!"
15   exit
16 fi
17
18 # as root
19 usermod -a -G sudo ${DEFAULT_USER}
20 apt-get install git-core build-essential translate-toolkit python-polib bsdmainutils
21  
22 # as DEFAULT_USER
23 if [ ! -d "${SITKACONF}" ]
24 then
25   # this will fail unless DEFAULT_USER has read access to the repo
26   su -c "cd ${HOMEDIR} && git clone git+ssh://git@git.sitka.bclibraries.ca/sitka-infra/sysadmin" ${DEFAULT_USER}
27 fi
28 su -c "cd ${HOMEDIR}/sysadmin && git fetch origin && git checkout ${SITKACONF_BRANCH} && git pull" ${DEFAULT_USER}
29 if [ ! -d "${BUILDDIR}/.git" ] ; then
30   su -c "cd ${HOMEDIR} && git clone git://git.evergreen-ils.org/OpenSRF.git opensrf" ${DEFAULT_USER}
31 fi
32 su -c "cd ${BUILDDIR} && git fetch origin && git checkout ${BRANCH} && git pull" ${DEFAULT_USER}
33  
34 # as root
35 echo "need a placeholder apache2.conf, installing from config repo..."
36 if [ -f '/etc/apache2/apache2.conf' ]
37 then
38   mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.bak
39 fi
40 cp ${SITKACONF}/files/etc/apache2/apache2.conf/${HOSTNAME} /etc/apache2/apache2.conf
41 sed -i "s|__HOSTNAME__|${THISHOST}|g" /etc/apache2/apache2.conf
42
43 # as root
44 echo "Installing OpenSRF prerequisites for Ubuntu..."
45 cd ${BUILDDIR} && make -f src/extras/Makefile.install ubuntu-trusty
46  
47 # as DEFAULT_USER
48 echo "Configuring and building OpenSRF..."
49 su -c "cd ${BUILDDIR} && autoreconf -i" ${DEFAULT_USER}
50 su -c "cd ${BUILDDIR} && ./configure --prefix=${INSTALLDIR} --sysconfdir=${INSTALLDIR}/conf" ${DEFAULT_USER}
51 su -c "cd ${BUILDDIR} && make" ${DEFAULT_USER}
52  
53 # as root
54 echo "Installing OpenSRF..."
55 cd ${BUILDDIR} && make install
56 useradd -m -s /bin/bash opensrf
57 PATHFILES="/etc/profile /root/.bashrc /home/${DEFAULT_USER}/.bashrc /home/opensrf/.bashrc"
58 for PATHFILE in ${PATHFILES} ; do
59   if [[ ! -e "${PATHFILE}" || ! `egrep "PATH=.*${INSTALLDIR}/bin" "${PATHFILE}"` ]] ; then 
60     echo "export PATH=${INSTALLDIR}/bin:\$PATH" >> ${PATHFILE}
61   fi
62 done
63 chown ${DEFAULT_USER}:${DEFAULT_USER} /home/${DEFAULT_USER}/.bashrc
64 chown -R opensrf:opensrf ${INSTALLDIR}
65  
66 # as root, add the following two lines to /etc/hosts:
67 #127.0.1.2      public.localhost        public
68 #127.0.1.3      private.localhost       private
69 echo "Updating /etc/hosts..."
70 echo -e "127.0.1.2\tpublic.localhost\tpublic\n127.0.1.3\tprivate.localhost\tprivate\n" | \
71   cat - /etc/hosts > /etc/hosts.new && mv /etc/hosts.new /etc/hosts
72  
73 # as root
74 echo "ldconfig stuff..."
75 echo "${INSTALLDIR}/lib" > /etc/ld.so.conf.d/opensrf.conf
76 ldconfig
77  
78 # as root
79 echo "Setting up ejabberd..."
80 cp ${SITKACONF}/files/etc/ejabberd/ejabberd.cfg/${HOSTNAME} /etc/ejabberd/ejabberd.cfg
81 sed -i "s|__HOSTNAME__|${THISHOST}|g" /etc/ejabberd/ejabberd.cfg
82 chgrp ejabberd /etc/ejabberd/ejabberd.cfg
83 chmod 640 /etc/ejabberd/ejabberd.cfg
84 /etc/init.d/ejabberd restart && sleep 10 && \
85   ejabberdctl register router private.localhost ${PRIVATE_ROUTER_PASSWD} && \
86   ejabberdctl register opensrf private.localhost ${PRIVATE_OPENSRF_PASSWD} && \
87   ejabberdctl register router public.localhost ${PUBLIC_ROUTER_PASSWD} && \
88   ejabberdctl register opensrf public.localhost ${PUBLIC_OPENSRF_PASSWD}
89
90 echo "OpenSRF is installed!"
91
92 # websockets install (REQUIRED for web client)
93 # XXX a valid SSL cert is required!
94 #rm -r /tmp/apache-websocket
95 #cd /tmp && git clone https://github.com/disconnect/apache-websocket
96 #cd apache-websocket && apxs2 -i -a -c mod_websocket.c
97 #sh /usr/share/doc/apache2/examples/setup-instance websockets
98 #a2dismod websocket
99 #cp ${SITKACONF}/files/etc/apache2-websockets/apache2.conf/${HOSTNAME} /etc/apache2-websockets/apache2.conf
100 #cp ${SITKACONF}/files/etc/apache2-websockets/envvars/${HOSTNAME} /etc/apache2-websockets/envvars
101
102 #/etc/init.d/apache2-websockets start
103
104 #echo "websockets is installed!"
105