--- /dev/null
+#!/bin/bash
+# -----------------------------------------------------------------------
+# Copyright (C) 2009-2012 Equinox Software Inc.
+# Bill Erickson <berick@esilibrary.com>
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+# -----------------------------------------------------------------------
+
+while getopts ayst option
+do
+ case "${option}"
+ in
+ a) AUTOSTART=1;;
+ y) YES=1;;
+ s) SAMPLEDATA=--load-all-sample;;
+ t) LIVETEST=1;;
+ esac
+done
+
+function my_init {
+ date
+ init_variables
+ configure_timezone
+ configure_cpan
+ build_essentials
+ setting_up_opensrf_env
+ cloning_git_repos
+ opensrf_prereqs
+ evergreen_prereqs
+ evergreen_db_prereqs
+ setting_ldconfig_and_rsyslog_and_hosts_and_ejabberd
+ build_opensrf
+ test_opensrf_build
+ install_opensrf
+ build_evergreen
+ test_evergreen_build
+ test_and_build_eg_browser_client
+ install_evergreen
+ configure_database
+ configure_apache
+ if [ $AUTOSTART ]; then
+ start_evergreen
+ if [ $LIVETEST ]; then
+ test_evergreen_live
+ fi
+ fi
+ docs_builder_prereqs
+ build_the_docs
+}
+
+function init_variables {
+ echo _.-~= initializing installer
+ date
+ # -----------------------------------------------------------------------
+ # Handling passed arguments to the script
+ # -----------------------------------------------------------------------
+ export DOJO_VERSION='1.3.3';
+ export PATH=/openils/bin:$PATH
+ export LD_LIBRARY_PATH=/openils/lib:/usr/local/lib:/usr/local/lib/dbd:$LD_LIBRARY_PATH
+ export BASE_DIR=$PWD
+ echo AUTOSTART=${AUTOSTART}
+ echo YES=${YES}
+ echo SAMPLEDATA=${SAMPLEDATA}
+ echo LIVETEST=${LIVETEST}
+ echo DOJO_VERSION=${DOJO_VERSION}
+ echo PATH=${PATH}
+ echo LD_LIBRARY_PATH=${LD_LIBRARY_PATH}
+ echo BASE_DIR=${BASE_DIR}
+ # -----------------------------------------------------------------------
+ # Change to suit...
+ # -----------------------------------------------------------------------
+ # If you change the jabber password, you will need to
+ # edit opensrf_core.xml and srfsh.xml accordingly
+ export JABBER_PASSWORD='password'
+ export ADMIN_USER='admin';
+ export ADMIN_PASS='demo123';
+ # -----------------------------------------------------------------------
+ # Database variables
+ # -----------------------------------------------------------------------
+ export PGDATABASE=evergreen
+ export PGUSER=evergreen
+ export PGPASSWORD=evergreen
+ export PGHOST=localhost
+ # -----------------------------------------------------------------------
+ # You can override these like so:
+ # EVERGREEN_BRANCH='master' ./eg_wheezy_installer.sh
+ # -----------------------------------------------------------------------
+ OPENSRF_REPO='git://git.evergreen-ils.org/OpenSRF.git'
+ OPENSRF_BRANCH='master'
+ EVERGREEN_REPO='git://git.evergreen-ils.org/Evergreen.git'
+ EVERGREEN_BRANCH='master'
+ echo OPENSRF_REPO=${OPENSRF_REPO}
+ echo OPENSRF_BRANCH=${OPENSRF_BRANCH}
+ echo EVERGREEN_REPO=${EVERGREEN_REPO}
+ echo EVERGREEN_BRANCH=${EVERGREEN_BRANCH}
+ OPENSRF_PREREQ_TARGET=debian-wheezy
+ EVERGREEN_PREREQ_TARGET=debian-wheezy
+ EVERGREEN_DB_PREREQ_TARGET=postgres-server-debian-wheezy
+ echo OPENSRF_PREREQ_TARGET=${OPENSRF_PREREQ_TARGET}
+ echo EVERGREEN_PREREQ_TARGET=${EVERGREEN_PREREQ_TARGET}
+ echo EVERGREEN_DB_PREREQ_TARGET=${EVERGREEN_DB_PREREQ_TARGET}
+
+ export NODEJS_VERSION='v8.11.4'
+ export NODEJS_BINDIR="node-$NODEJS_VERSION-linux-x64"
+ export NODEJS_TARBIN="$NODEJS_BINDIR.tar.xz"
+ export NODEJS_BINARY="https://nodejs.org/dist/$NODEJS_VERSION/$NODEJS_TARBIN"
+ echo "NODEJS_BINARY=$NODEJS_BINARY"
+ echo "NODEJS_VERSION=$NODEJS_VERSION"
+
+ echo End of intializing installer =~-._
+}
+
+function configure_timezone {
+ echo _.-~= configure timezone
+ date
+ # should be America/New_York
+ perl -e 'print "2\n\n104\n";' | dpkg-reconfigure -fteletype tzdata
+ echo End of configure timezone =~-._
+}
+
+function configure_cpan {
+ echo _.-~= configure CPAN
+ date
+ # -----------------------------------------------------------------------
+ # force CPAN to load by installing something that should already be installed
+ if [ $YES ]; then
+ yes | cpan Fcntl
+ else
+ cpan Fcntl
+ fi
+ echo Return Value = $?
+ # CPAN follow pre-reqs?
+ if [ ! "$(echo 'o conf prerequisites_policy' | cpan | grep follow)" ]; then
+ if [ $YES ]; then
+
+ echo "setting cpan prerequisites_policy to follow"
+ echo -e "o conf prerequisites_policy follow\\n o conf commit" | cpan
+
+ else
+
+ echo '
+
+-----------------------------------------------------------------------
+The install will go faster if CPAN is configured to automatically install
+prerequisites. You can revert the action later with:
+
+echo -e "o conf prerequisites_policy ask\n o conf commit" | cpan
+'
+ while true; do
+ echo -n 'Automatically install prereqs? [Y/n] ';
+ read X;
+ [ "$X" == 'n' -o "$X" == "N" ] && break;
+ if [ "$X" == 'y' -o "$X" == 'Y' ]; then
+ echo -e "o conf prerequisites_policy follow\\n o conf commit" | cpan
+ break;
+ fi;
+ done;
+ fi;
+ fi;
+ echo End of configure CPAN =~-._
+}
+
+function build_essentials {
+ echo _.-~= Installing some build essentials
+ date
+ # Install some essential tools
+ apt-get update \
+ && apt-get -yq dist-upgrade \
+ && apt-get -yq install build-essential automake git psmisc ntp rsyslog lsb-release unzip;
+ echo Return Value = $?
+
+ if [ $LIVETEST ]; then
+ cpan TAP::Parser::SourceHandler::pgTAP
+ echo Return Value = $?
+ fi;
+ echo End of Installing some build essentials =~-._
+}
+
+function docs_builder_prereqs {
+ echo _.-~= Installing prereqs for building the documentation formats
+ date
+ # Install tools used for building the docs
+ apt-get -yq install asciidoc source-highlight fop;
+ echo Return Value = $?
+
+ echo End of Installing prereqs for building the documentation formats =~-._
+}
+
+function build_the_docs {
+ echo _.-~= Building the AsciiDoc output formats
+ date
+ # build HTML
+ su - opensrf sh -c 'cd /home/opensrf/Evergreen/docs/ ; asciidoc root.adoc ; echo Return Value = $?'
+ # build PDF
+ su - opensrf sh -c 'cd /home/opensrf/Evergreen/docs/ ; a2x --fop --fop-opts="-q" root.adoc ; echo Return Value = $?'
+ # build EPUB
+ su - opensrf sh -c 'cd /home/opensrf/Evergreen/docs/ ; a2x --no-xmllint --format epub root.adoc ; echo Return Value = $?'
+
+ echo End of Building the AsciiDoc output formats =~-._
+}
+
+function setting_up_opensrf_env {
+ echo _.-~= creating opensrf user and environment
+ date
+ # Create opensrf user and set up environment
+ if [ ! "$(grep ^opensrf: /etc/passwd)" ]; then
+ useradd -m -s /bin/bash opensrf
+ echo Return Value = $?
+ echo 'export PATH=/openils/bin:$PATH' >> /home/opensrf/.bashrc
+ echo 'export LD_LIBRARY_PATH=/openils/lib:/usr/local/lib:/usr/local/lib/dbd:$LD_LIBRARY_PATH' >> /home/opensrf/.bashrc
+ fi;
+ echo end of creating opensrf user and environment =~-._
+}
+
+function cloning_git_repos {
+ echo _.-~= cloning git repositories
+ date
+ OSRF_COMMAND="
+ cd /home/opensrf;
+ git clone --depth 0 --branch $OPENSRF_BRANCH $OPENSRF_REPO OpenSRF;
+ git clone --depth 0 --branch $EVERGREEN_BRANCH $EVERGREEN_REPO Evergreen;
+ "
+ rm -rf /home/opensrf/Evergreen /home/opensrf/OpenSRF
+ su - opensrf sh -c "$OSRF_COMMAND";
+ echo Return Value = $?
+
+ # Show tips
+ cd /home/opensrf/OpenSRF/
+ echo 'Tip of OpenSRF:' `git log --format=oneline | head -1`
+ cd /home/opensrf/Evergreen/
+ echo 'Tip of Evergreen:' `git log --format=oneline | head -1`
+
+ echo End of cloning git repositories =~-._
+}
+
+function opensrf_prereqs {
+ echo _.-~= Installing OpenSRF pre-requisites
+ date
+ # Install pre-reqs
+ mkdir -p /usr/src/evergreen;
+ cd /usr/src/evergreen;
+ if [ $YES ]; then
+ yes | make -f /home/opensrf/OpenSRF/src/extras/Makefile.install ${OPENSRF_PREREQ_TARGET}
+ else
+ make -f /home/opensrf/OpenSRF/src/extras/Makefile.install ${OPENSRF_PREREQ_TARGET}
+ fi;
+ echo Return Value = $?
+ echo End of Installing OpenSRF pre-requisites =~-._
+}
+
+function evergreen_prereqs {
+ echo _.-~= Installing Evergreen pre-requisites
+ date
+ if [ $YES ]; then
+ yes | make -f /home/opensrf/Evergreen/Open-ILS/src/extras/Makefile.install ${EVERGREEN_PREREQ_TARGET}
+ else
+ make -f /home/opensrf/Evergreen/Open-ILS/src/extras/Makefile.install ${EVERGREEN_PREREQ_TARGET}
+ fi;
+ echo Return Value = $?
+ echo End of Installing Evergreen pre-requisites =~-._
+}
+
+function evergreen_db_prereqs {
+ echo _.-~= Installing Evergreen database pre-requisites
+ date
+ if [ $YES ]; then
+ yes | make -f /home/opensrf/Evergreen/Open-ILS/src/extras/Makefile.install ${EVERGREEN_DB_PREREQ_TARGET}
+ else
+ make -f /home/opensrf/Evergreen/Open-ILS/src/extras/Makefile.install ${EVERGREEN_DB_PREREQ_TARGET}
+ fi;
+ echo Return Value = $?
+ echo End of Installing Evergreen database pre-requisites =~-._
+}
+
+function setting_ldconfig_and_rsyslog_and_hosts_and_ejabberd {
+ echo _.-~= setting ld.so.conf and rsyslog and /etc/hosts and ejabberd
+ date
+ cp $BASE_DIR/evergreen.ld.conf /etc/ld.so.conf.d/
+ ldconfig;
+ echo Return Value = $?
+ # Configure rsyslog and restart
+ cp /home/opensrf/Evergreen/Open-ILS/examples/evergreen-rsyslog.conf /etc/rsyslog.d/evergreen.conf
+ /etc/init.d/rsyslog restart
+ echo Return Value = $?
+ if [ ! "$(grep 'public.localhost' /etc/hosts)" ]; then
+
+ if [ $YES ]; then
+ echo 'Adding public.localhost and private.localhost to /etc/hosts'
+ echo '127.0.1.2 public.localhost public' >> /etc/hosts
+ echo '127.0.1.3 private.localhost private' >> /etc/hosts
+ else
+
+ cat <<EOF
+
+ * Add these lines to /etc/hosts.
+
+ 127.0.1.2 public.localhost public
+ 127.0.1.3 private.localhost private
+
+EOF
+ fi;
+
+ else
+ echo "INFO: /etc/hosts already has public.localhost line";
+ fi
+ echo Return Value = $?
+ # Patch Ejabberd and register users
+ if [ ! "$(grep 'public.localhost' /etc/ejabberd/ejabberd.cfg)" ]; then
+ cd /etc/ejabberd/
+ /etc/init.d/ejabberd stop;
+ killall beam epmd; # just in case
+ cp ejabberd.cfg /root/ejabberd.cfg.orig
+ patch -p0 < $BASE_DIR/ejabberd.EG.patch
+ chown ejabberd:ejabberd ejabberd.cfg
+ echo starting ejabberd after patching
+ date
+ /etc/init.d/ejabberd start
+ echo Return Value = $?
+ sleep 10;
+ ejabberdctl register router private.localhost $JABBER_PASSWORD
+ echo Return Value = $?
+ ejabberdctl register opensrf private.localhost $JABBER_PASSWORD
+ echo Return Value = $?
+ ejabberdctl register router public.localhost $JABBER_PASSWORD
+ echo Return Value = $?
+ ejabberdctl register opensrf public.localhost $JABBER_PASSWORD
+ echo Return Value = $?
+ fi;
+ echo End of setting ld.so.conf and rsyslog and /etc/hosts and ejabberd =~-._
+}
+
+function build_opensrf {
+ # Build and install OpenSRF
+ echo _.-~= Building OpenSRF
+ date
+ OSRF_COMMAND='
+ cd /home/opensrf/OpenSRF;
+ autoreconf -i;
+ ./configure --prefix=/openils --sysconfdir=/openils/conf;
+ make;'
+ su - opensrf sh -c "$OSRF_COMMAND"
+ echo Return Value = $?
+ echo End of Building OpenSRF =~-._
+}
+
+function test_opensrf_build {
+ echo _.-~= Running OpenSRF build tests
+ date
+ cd /home/opensrf/OpenSRF;
+ make check
+ echo Return Value = $?
+ echo End of OpenSRF build tests =~-._
+}
+
+function install_opensrf {
+ echo _.-~= Installing OpenSRF
+ date
+ make install
+ echo Return Value = $?
+ echo End of Installing OpenSRF =~-._
+}
+
+function build_evergreen {
+ echo _.-~= Building Evergreen
+ date
+ OSRF_COMMAND='
+ export PATH=/openils/bin:$PATH
+ cd /home/opensrf/Evergreen;
+ autoreconf -i;
+ ./configure --prefix=/openils --sysconfdir=/openils/conf;
+ make;
+ '
+ su - opensrf sh -c "$OSRF_COMMAND"
+ echo Return Value = $?
+ echo End of Building Evergreen =~-._
+}
+
+function test_evergreen_build {
+ echo _.-~= Running Evergreen build tests
+ date
+ cd /home/opensrf/Evergreen
+ make check
+ echo Return Value = $?
+ echo End of Evergreen build tests =~-._
+}
+
+
+# The evergreen browser client prereq installation and
+# build process is not baked into Evergreen proper (yet).
+# Run it as a standalone operation for now.
+function test_and_build_eg_browser_client {
+ echo _.-~= Running Evergreen browser client build/test
+ cd /home/opensrf && pwd
+ wget -N $NODEJS_BINARY
+ tar xf $NODEJS_TARBIN
+ echo Return Value = $?
+ export PATH=$PATH:/home/opensrf/$NODEJS_BINDIR/bin
+ echo Return Value = $?
+ echo Running npm update
+ npm update
+ echo Return Value = $?
+ echo Running npm i npm@latest -g
+ npm i npm@latest -g
+ echo Return Value = $?
+ echo Running npm audit
+ npm audit
+ echo Return Value = $?
+ cd /home/opensrf/Evergreen/Open-ILS/web/js/ui/default/staff && pwd
+ echo Running npm install
+ npm install # fetch build depencies
+ echo Return Value = $?
+ echo Running npm run build
+ npm run build # copy into place; use build-prod for concatenation
+ echo Return Value = $?
+ echo Running npm test
+ npm run test # run JS unit tests
+ echo Return Value = $?
+ cd /home/opensrf/Evergreen/Open-ILS/src/eg2/ && pwd
+ echo Running npm install
+ npm install # fetch build depencies
+ echo Return Value = $?
+ echo Running ng build --prod
+ ng build --prod # for ang6
+ echo Return Value = $?
+ echo Running npm test
+ npm run test # run JS unit tests
+ echo Return Value = $?
+ echo End of Evergreen browser client build/test =~-._
+}
+
+function install_evergreen {
+ echo _.-~= Installing Evergreen
+ date
+ cd /home/opensrf/Evergreen
+ make install
+ echo Return Value = $?
+
+ cp /openils/conf/opensrf.xml.example /openils/conf/opensrf.xml
+ cp /openils/conf/opensrf_core.xml.example /openils/conf/opensrf_core.xml
+
+ # fetch and install Dojo
+ cd /tmp;
+ wget -N "http://download.dojotoolkit.org/release-$DOJO_VERSION/dojo-release-$DOJO_VERSION.tar.gz" \
+ || wget -N "http://evergreen-ils.org/~phasefx/download.dojotoolkit.org/dojo-release-$DOJO_VERSION.tar.gz"
+ tar -zxf dojo-release-$DOJO_VERSION.tar.gz;
+ cp -r dojo-release-$DOJO_VERSION/* /openils/var/web/js/dojo/;
+
+ # give it all to opensrf
+ chown -R opensrf:opensrf /openils
+
+ # copy srfsh config into place
+ cp /openils/conf/srfsh.xml.example /home/opensrf/.srfsh.xml;
+ chown opensrf:opensrf /home/opensrf/.srfsh.xml;
+ echo End of Installing Evergreen =~-._
+}
+
+function configure_database {
+ echo _.-~= configure database
+ date
+ if [ $YES ]; then
+ echo "Using password $PGPASSWORD for the $PGUSER database user."
+ echo -e "$PGPASSWORD\n$PGPASSWORD\n" | su - postgres sh -c "createuser -P -s $PGUSER;"
+ else
+ echo -e "\n\nPlease enter a password for the $PGUSER database user.\n If you do not want to edit configs, use \"$PGPASSWORD\"\n"
+ su - postgres sh -c "createuser -P -s $PGUSER;"
+ fi;
+
+ # Apply the DB schema
+ cd /home/opensrf/Evergreen
+ perl Open-ILS/src/support-scripts/eg_db_config \
+ --create-database \
+ --create-schema \
+ --create-offline \
+ --update-config $SAMPLEDATA \
+ --service all \
+ --user $PGUSER \
+ --password $PGPASSWORD \
+ --hostname $PGHOST \
+ --database $PGDATABASE \
+ --admin-user $ADMIN_USER \
+ --admin-pass $ADMIN_PASS;
+ echo Return Value = $?
+
+ if [ $LIVETEST ]; then
+ PG_TAP_VER="0.97.0"
+ wget -N http://api.pgxn.org/dist/pgtap/$PG_TAP_VER/pgtap-$PG_TAP_VER.zip \
+ && unzip pgtap-$PG_TAP_VER.zip \
+ && cd pgtap-$PG_TAP_VER \
+ && make \
+ && make installcheck \
+ && make install
+ echo 'CREATE EXTENSION pgtap;' | su - postgres -c "psql evergreen"
+ fi;
+ echo configure database =~-._
+}
+
+function configure_apache {
+ echo _.-~= configure apache
+ date
+ /etc/init.d/apache2 stop
+ # Copy apache configs into place and create SSL cert
+ cd /home/opensrf/Evergreen/
+ cp Open-ILS/examples/apache/eg.conf /etc/apache2/sites-available/
+ cp Open-ILS/examples/apache/eg_vhost.conf /etc/apache2/
+ cp Open-ILS/examples/apache/eg_startup /etc/apache2/
+
+ mkdir -p /etc/apache2/ssl;
+ if [ ! -f /etc/apache2/ssl/server.key ] ; then
+ echo -e "\n\nConfiguring a new temporary SSL certificate....\n";
+ if [ $YES ]; then
+ yes "" | openssl req -new -x509 -days 365 -nodes -out /etc/apache2/ssl/server.crt -keyout /etc/apache2/ssl/server.key
+ else
+ openssl req -new -x509 -days 365 -nodes -out /etc/apache2/ssl/server.crt -keyout /etc/apache2/ssl/server.key
+ fi;
+ else
+ echo -e "\nkeeping existing ssl/server.key file\n";
+ fi
+
+ a2enmod ssl
+ echo Return Value = $?
+ a2enmod rewrite
+ echo Return Value = $?
+ a2enmod expires
+ echo Return Value = $?
+ a2dissite 000-default
+ echo Return Value = $?
+ a2ensite eg.conf
+ echo Return Value = $?
+
+ echo Modifying APACHE_RUN_USER/APACHE_RUN_GROUP in /etc/apache2/envvars
+ sed -i 's/www-data/opensrf/g' /etc/apache2/envvars
+
+ echo Making sure /var/lock/apache2 is owned by opensrf
+ chown opensrf:opensrf /var/lock/apache2
+
+ echo Modifying KeepAliveTimeout in /etc/apache2/apache2.conf
+ sed -i 's/KeepAliveTimeout .*/KeepAliveTimeout 1/' /etc/apache2/apache2.conf
+
+ echo End of configure apache =~-._
+}
+
+function start_evergreen {
+ echo _.-~= Starting Evergreen
+ date
+ if [ $LIVETEST ]; then
+ rm /openils/var/log/*.log
+ fi
+
+ OSRF_COMMAND='
+ export LD_LIBRARY_PATH=/openils/lib:/usr/local/lib:/usr/local/lib/dbd:$LD_LIBRARY_PATH \
+ && export PATH=/openils/bin:$PATH \
+ && OSRF_HOSTNAME="dns_hack" /openils/bin/osrf_control --localhost --restart-all && sleep 3 \
+ && /openils/bin/autogen.sh /openils/conf/opensrf_core.xml \
+ && echo Finis;
+ '
+ echo Starting services...
+ su - opensrf sh -c "$OSRF_COMMAND";
+ echo Return Value = $?
+
+ echo Restarting Apache
+ /etc/init.d/apache2 restart
+ echo Return Value = $?
+
+ echo End of Starting Evergreen =~-._
+}
+
+function test_evergreen_live {
+ # TODO: Eventually move these tests into a Make target within Evergreen
+ cd /home/opensrf/Evergreen
+ echo _.-~= Running pgTAP tests
+ date
+ su - postgres -c 'cd /home/opensrf/Evergreen ; pg_prove -vr -d evergreen Open-ILS/src/sql/Pg/t/ ; echo Return Value = $?'
+ echo End of pgTAP tests =~-._
+ echo _.-~= Running pgTAP live tests
+ date
+ su - postgres -c 'cd /home/opensrf/Evergreen ; pg_prove -vr -d evergreen Open-ILS/src/sql/Pg/live_t/ ; echo Return Value = $?'
+ echo End of pgTAP live tests =~-._
+ echo _.-~= Running settings-tester.pl
+ date
+ su - opensrf sh -c 'export PATH=/openils/bin:$PATH ; cd /home/opensrf/Evergreen/Open-ILS/src/support-scripts/ ; ./settings-tester.pl ; echo Return Value = $?'
+ echo End of settings-tester.pl output =~-._
+ echo _.-~= Running perl live tests
+ date
+ su - opensrf sh -c 'export PATH=/openils/bin:$PATH ; cd /home/opensrf/Evergreen/Open-ILS/src/perlmods/ ; make livecheck; echo Return Value = $?'
+ echo End of perl live tests =~-._
+ echo _.-~= Gathering log summary
+ date
+ echo ''
+ echo 'wc -l *.log:'
+ su - opensrf sh -c 'cd /openils/var/log/ ; wc -l *.log'
+ echo ''
+ echo 'du -sh *.log:'
+ su - opensrf sh -c 'cd /openils/var/log/ ; du -sh *.log'
+ echo ''
+ echo 'perl -ne ''if (/^\[.*?\] (.*?) \[/) { print "$1\n"; }'' osrfsys.log | sort | uniq -c | sort -k2:'
+ (cd /openils/var/log/ ; perl -ne 'if (/^\[.*?\] (.*?) \[/) { print "$1\n"; }' osrfsys.log | sort | uniq -c | sort -k2)
+ echo ''
+ echo End of log summary =~-._
+ cd /openils/var/log/
+ for x in *.log; do
+ echo _.-~= Log Output: $x
+ date
+ cat $x
+ echo End of $x =~-._
+ done
+ echo _.-~= Gathering system information
+ echo ''
+ date
+ echo ''
+ uname -a
+ echo 'select version();' | su - postgres -c 'psql -At'
+ echo ''
+ echo '/proc/meminfo:'
+ cat /proc/meminfo
+ echo ''
+ echo '/proc/cpuinfo:'
+ cat /proc/cpuinfo
+ echo ''
+ echo 'dpkg --list:'
+ dpkg --list
+ echo ''
+ echo 'cpan -l:'
+ cpan -l 2> /dev/null | sort
+ echo End of system information =~-._
+ date
+}
+
+my_init
+
+