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