fe254562619f73ffa097dba7103ff39396aca39b
[sitka/sitka-tools.git] / deployment / install-osrf.sh
1 #!/bin/bash
2 DEFAULT_USER="opensrf"
3 HOMEDIR="/home/${DEFAULT_USER}"
4 BUILDDIR="${HOMEDIR}/opensrf"
5 INSTALLDIR="/srv/openils"
6 BRANCH="rel_3_0"
7 HOSTNAME="nonprod"
8 SITKACONF="${HOMEDIR}/sysadmin"
9 SITKACONF_BRANCH="master"
10
11 THISHOST=`hostname -s`
12
13 while getopts ":pwj" opt ; do
14   case $opt in
15     p ) PROD="prod";;
16     w ) WEBSOCKETS="websockets";;
17     j ) SKIP_EJABBERD_REG="skip_ejabberd_reg";;
18   esac
19 done
20 shift $(($OPTIND - 1))
21
22 # test for ejabberd passwords
23 if [ -z "$PRIVATE_ROUTER_PASSWD" -o -z "$PRIVATE_OPENSRF_PASSWD" -o -z "$PUBLIC_ROUTER_PASSWD" -o -z "$PUBLIC_OPENSRF_PASSWD" ]
24 then
25   if [[ ! -n "$SKIP_EJABBERD_REG" ]] ; then
26     echo "Missing ejabberd password(s), no OpenSRF install!"
27     exit
28   fi
29 fi
30
31 # always use a proxy for websockets traffic
32 if [[ -n "$WEBSOCKETS" ]] ; then
33     WSPORT="--with-websockets-port=443"
34 else
35     WSPORT=""
36 fi
37
38 if [[ -n "$PROD" ]] ; then
39   echo 'this is a production install'
40   [ "$HOSTNAME" == "nonprod" ] && HOSTNAME="prod"
41 else
42   echo 'this is NOT a production install'
43 fi
44 # as root
45 usermod -a -G sudo ${DEFAULT_USER}
46 apt-get install git-core build-essential translate-toolkit python-polib bsdmainutils
47  
48 # as DEFAULT_USER
49 if [ ! -d "${SITKACONF}" ]
50 then
51   # this will fail unless DEFAULT_USER has read access to the repo
52   su -c "cd ${HOMEDIR} && git clone git+ssh://git@git.sitka.bclibraries.ca/sitka-infra/sysadmin" ${DEFAULT_USER}
53 fi
54 su -c "cd ${HOMEDIR}/sysadmin && git fetch origin && git checkout ${SITKACONF_BRANCH} && git pull" ${DEFAULT_USER}
55 if [ ! -d "${BUILDDIR}/.git" ] ; then
56   su -c "cd ${HOMEDIR} && git clone git://git.evergreen-ils.org/OpenSRF.git opensrf" ${DEFAULT_USER}
57 fi
58 su -c "cd ${BUILDDIR} && git fetch origin && git checkout ${BRANCH} && git pull" ${DEFAULT_USER}
59  
60 # as root
61 echo "need a placeholder apache2.conf, installing from config repo..."
62 if [ -f '/etc/apache2/apache2.conf' ]
63 then
64   mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.bak
65 fi
66 cp ${SITKACONF}/files/etc/apache2/apache2.conf/${HOSTNAME} /etc/apache2/apache2.conf
67 sed -i "s|__HOSTNAME__|${THISHOST}|g" /etc/apache2/apache2.conf
68
69 # as root
70 echo "Installing OpenSRF prerequisites for Ubuntu..."
71 cd ${BUILDDIR} && make -f src/extras/Makefile.install ubuntu-trusty
72  
73 # as DEFAULT_USER
74 echo "Configuring and building OpenSRF..."
75 su -c "cd ${BUILDDIR} && autoreconf -i" ${DEFAULT_USER}
76 su -c "cd ${BUILDDIR} && ./configure --prefix=${INSTALLDIR} --sysconfdir=${INSTALLDIR}/conf ${WSPORT}" ${DEFAULT_USER}
77 su -c "cd ${BUILDDIR} && make" ${DEFAULT_USER}
78  
79 # as root
80 echo "Installing OpenSRF..."
81 cd ${BUILDDIR} && make install
82 useradd -m -s /bin/bash opensrf
83 PATHFILES="/etc/profile /root/.bashrc /home/${DEFAULT_USER}/.bashrc /home/opensrf/.bashrc"
84 for PATHFILE in ${PATHFILES} ; do
85   if [[ ! -e "${PATHFILE}" || ! `egrep "PATH=.*${INSTALLDIR}/bin" "${PATHFILE}"` ]] ; then 
86     echo "export PATH=${INSTALLDIR}/bin:\$PATH" >> ${PATHFILE}
87   fi
88 done
89 chown ${DEFAULT_USER}:${DEFAULT_USER} /home/${DEFAULT_USER}/.bashrc
90 if [[ ! -n "$PROD" ]] ; then
91   chown -R opensrf:opensrf ${INSTALLDIR}
92 fi
93  
94 # as root, add the following two lines to /etc/hosts:
95 #127.0.1.2      public.localhost        public
96 #127.0.1.3      private.localhost       private
97 if [[ ! -n "$PROD" ]] ; then
98   if [[ ! `grep public.localhost /etc/hosts` ]] ; then
99     echo "Updating /etc/hosts..."
100     echo -e "127.0.1.2\tpublic.localhost\tpublic\n127.0.1.3\tprivate.localhost\tprivate\n" | \
101       cat - /etc/hosts > /etc/hosts.new && mv /etc/hosts.new /etc/hosts
102   fi
103 else
104   echo 'WARNING: If this is a new production server, you will need to manually update /etc/hosts!'
105 fi
106  
107 # as root
108 echo "ldconfig stuff..."
109 echo "${INSTALLDIR}/lib" > /etc/ld.so.conf.d/opensrf.conf
110 ldconfig
111  
112 # as root
113 echo "Setting up ejabberd..."
114 cp ${SITKACONF}/files/etc/ejabberd/ejabberd.cfg/${HOSTNAME} /etc/ejabberd/ejabberd.cfg
115 sed -i "s|__HOSTNAME__|${THISHOST}|g" /etc/ejabberd/ejabberd.cfg
116 chgrp ejabberd /etc/ejabberd/ejabberd.cfg
117 chmod 640 /etc/ejabberd/ejabberd.cfg
118 /etc/init.d/ejabberd stop && /etc/init.d/ejabberd start
119 if [[ ! -n "$SKIP_EJABBERD_REG" ]] ; then
120   sleep 5
121   ejabberdctl register router private.localhost ${PRIVATE_ROUTER_PASSWD} && \
122   ejabberdctl register opensrf private.localhost ${PRIVATE_OPENSRF_PASSWD} && \
123   ejabberdctl register router public.localhost ${PUBLIC_ROUTER_PASSWD} && \
124   ejabberdctl register opensrf public.localhost ${PUBLIC_OPENSRF_PASSWD}
125 fi
126
127 echo "OpenSRF is installed!"
128
129 # websockets install (REQUIRED for web client)
130 # XXX a valid SSL cert is required!
131 if [[ -n "$WEBSOCKETS" ]] ; then
132   rm -r /tmp/apache-websocket
133   cd /tmp && git clone https://github.com/disconnect/apache-websocket
134   cd apache-websocket && apxs2 -i -a -c mod_websocket.c
135   sh /usr/share/doc/apache2/examples/setup-instance websockets
136   a2dismod websocket
137   cp ${SITKACONF}/files/etc/apache2-websockets/apache2.conf/${HOSTNAME} /etc/apache2-websockets/apache2.conf
138   sed -i "s|__HOSTNAME__|${THISHOST}|g" /etc/apache2-websockets/apache2.conf
139   cp ${SITKACONF}/files/etc/apache2-websockets/envvars/${HOSTNAME} /etc/apache2-websockets/envvars
140
141   #/etc/init.d/apache2-websockets start
142
143   #echo "websockets is installed!"
144 fi