add section "(OPTIONAL) IP-Redirection";
authorSteve Sheppard <ssheps@gmail.com>
Tue, 25 Jan 2011 17:00:35 +0000 (12:00 -0500)
committerSteve Sheppard <ssheps@gmail.com>
Tue, 25 Jan 2011 17:00:35 +0000 (12:00 -0500)
1.6/admin/serversideinstallation.xml

index 03c9357..7b33b90 100644 (file)
                                        In the following example, the default shell for the 
                                        <systemitem class="username">opensrf</systemitem> user is automatically set
                                        to <command>/bin/bash</command> to inherit a reasonable environment:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        useradd -m -s /bin/bash opensrf
        passwd opensrf</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <title>Download and Unpack Latest OpenSRF Version</title>
                                        the directory <filename class="directory">/home/opensrf</filename> then download
                                        and extract OpenSRF. The new subdirectory
                                        <filename class="directory">/home/opensrf/OpenSRF-1.4.0</filename> will be created:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        cd /home/opensrf
        wget http://evergreen-ils.org/downloads/OpenSRF-1.4.0.tar.gz
        tar zxf OpenSRF-1.4.0.tar.gz</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <title>Install Prerequisites to Build OpenSRF</title>
                                        distribution keywords table <xref linkend="serversideinstallation-keywords-opensrf"/> . 
                                        For example, to install the prerequisites for Ubuntu version 10.04 (Lucid Lynx) you would
                                        enter this command: <command>make -f src/extras/Makefile.install ubuntu-lucid</command> .</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        cd /home/opensrf/OpenSRF-1.4.0
        make -f src/extras/Makefile.install [DISTRIBUTION]</userinput>
-</screen>
+                                       </screen>
                                        <table xml:id="serversideinstallation-keywords-opensrf">
                                                <?dbfo keep-together="always" ?>
                                                <title>Keyword Targets for OpenSRF <application>"make"</application> Command</title>
                                                        include support for Python and Java, add the configuration
                                                        options <option>--enable-python</option> and
                                                        <option>--enable-java</option>, respectively:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the opensrf user:
        cd /home/opensrf/OpenSRF-1.4.0
        ./configure --prefix=/openils --sysconfdir=/openils/conf
        make</userinput>
-</screen>
+                                                       </screen>
                                                        <para>This step will take several minutes to complete.</para>
                                                </step>
                                                <step>
                                                        user, return to the new OpenSRF build directory and use the
                                                        <command>make</command> utility to compile, link and install
                                                        OpenSRF:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        cd /home/opensrf/OpenSRF-1.4.0
        make install</userinput>
-</screen>
+                                                       </screen>
                                                        <para>This step will take several minutes to complete.</para>
                                                </step>
                                                <step>
                                                        new library path, then run the command
                                                        <command>ldconfig</command> to automatically read the file and
                                                        modify the system dynamic library path:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        echo "/openils/lib" > /etc/ld.so.conf.d/osrf.conf
        ldconfig</userinput>
-</screen>
+                                                       </screen>
                                                </step>
                                                <step xml:id="serversideinstallation-definedomains">
                                                        <title>Define Public and Private OpenSRF Domains</title>
                                                        <indexterm>
                                                                <primary>Jabber</primary>
                                                        </indexterm>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        127.0.1.2  public.localhost   public
        127.0.1.3  private.localhost  private</userinput>
-</screen>
+                                                       </screen>
                                                </step>
                                                <step>
                                                        <title>Change File Ownerships</title>
                                                        user, change the ownership of all files installed in the
                                                        directory <filename class="directory">/openils</filename> to the
                                                        user <systemitem class="username">opensrf</systemitem>:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        chown -R opensrf:opensrf /openils</userinput>
-</screen>
+                                                       </screen>
                                                </step>
                                        </substeps>
                                </step>
                                        <para>Before continuing with configuration of <systemitem class="service">ejabberd</systemitem>
                                        you must stop that service. As the <systemitem class="username">root</systemitem> user,
                                        execute the following command to stop the service:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        /etc/init.d/ejabberd stop</userinput>
-</screen>
+                                       </screen>
                                        <para>If <systemitem class="service">ejabberd</systemitem> reports that it 
                                        is already stopped, there may have been a problem when it started back
                                        in the installation step. If there are any remaining daemon processes such as
                                        <systemitem class="daemon">beam</systemitem> or
                                        <systemitem class="daemon">epmd</systemitem> 
                                        you may need to perform the following commands to kill them:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        epmd -kill
        killall beam; killall beam.smp
        rm /var/lib/ejabberd/*
        echo 'ERLANG_NODE=ejabberd@localhost' >> /etc/default/ejabberd</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <title>Edit the <systemitem class="service">ejabberd</systemitem> configuration</title>
                                        <para>As the <systemitem class="username">root</systemitem> user, restart the
                                        <systemitem class="service">ejabberd</systemitem> service to test the
                                        configuration changes and to register your users:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        /etc/init.d/ejabberd start</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <title>Register <systemitem class="username">router</systemitem> and
                                        for the users <systemitem class="username">router</systemitem> and
                                        <systemitem class="username">opensrf</systemitem> on each domain (remember to replace
                                        <emphasis>NEWPASSWORD</emphasis> with the appropriate password):</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        # Note: the syntax for registering a user with ejabberdctl is:
        #    ejabberdctl register USER DOMAIN PASSWORD
        ejabberdctl register router  public.localhost  NEWPASSWORD
        ejabberdctl register opensrf private.localhost NEWPASSWORD
        ejabberdctl register opensrf public.localhost  NEWPASSWORD</userinput>
-</screen>
+                                       </screen>
                                        <para>Note that the users <systemitem class="username">router</systemitem> and
                                        <systemitem class="username">opensrf</systemitem> and their respective passwords 
                                        will be used again in <xref linkend="serversideinstallation-passwords"/> when
                                        execute the following commands to create the new configuration files
                                        <filename>/openils/conf/opensrf_core.xml</filename> and
                                        <filename>/openils/conf/opensrf.xml</filename> from the example templates:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        cd /openils/conf
        cp opensrf.xml.example      opensrf.xml
        cp opensrf_core.xml.example opensrf_core.xml</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step xml:id="serversideinstallation-passwords">
                                        <title>Update usernames and passwords in the OpenSRF configuration file</title>
                                        <para>to instead read:</para>
                                        <literal>/tmp/persist.db</literal>
                                        <para>Following is a sample modification of that portion of the file:</para>
-<programlisting language="xml"><![CDATA[
+                                       <programlisting language="xml"><![CDATA[
 <!-- Example of an app-specific setting override -->
 <opensrf.persist>
   <app_settings>
                                        to the home directory of each user who will use <command>srfsh</command>. 
                                        For instance, do the following for the 
                                        <systemitem class="username">opensrf</systemitem> user:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        cp /openils/conf/srfsh.xml.example  /home/opensrf/.srfsh.xml</userinput>
-</screen>
+                                       </screen>
                                        <para>Edit each user's file <filename>~/.srfsh.xml</filename> and make the
                                        following changes:</para>
                                        <itemizedlist>
                                                </listitem>
                                        </itemizedlist>
                                        <para>Following is a sample of the file:</para>
-<programlisting language="xml"><![CDATA[
+                                       <programlisting language="xml"><![CDATA[
 <?xml version="1.0"?>
 <!-- This file follows the standard bootstrap config file layout -->
 <!-- found in opensrf_core.xml -->
                                        environmental variable <envar>PATH</envar> by adding a new file path to the
                                        <systemitem class="username">opensrf</systemitem> user's shell configuration
                                        file <filename>~/.bashrc</filename>:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        echo "export PATH=/openils/bin:\$PATH" >> ~/.bashrc</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <title>Start OpenSRF</title>
                                        <para>As the <systemitem class="username">root</systemitem> user, start the
                                        <systemitem class="service">ejabberd</systemitem> and 
                                        <systemitem class="service">memcached</systemitem> services:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        /etc/init.d/ejabberd start
        /etc/init.d/memcached start</userinput>
-</screen>
+                                       </screen>
                                        <para>As the <systemitem class="username">opensrf</systemitem> user,
                                        start OpenSRF as follows:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        osrf_ctl.sh -l -a start_all</userinput>
-</screen>
+                                       </screen>
                                        <para>The flag <option>-l</option> forces Evergreen to use 
                                        <systemitem class="domainname">localhost</systemitem> (your current system) 
                                        as the hostname. The flag <option>-a start_all</option>  starts the other 
                                        <systemitem class="service">OpenSRF</systemitem> using the <command>srfsh</command> 
                                        utility and trying to call the <command>add</command> method on the OpenSRF 
                                        <systemitem class="service">math</systemitem> service:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        /openils/bin/srfsh</userinput>
-       <computeroutput>
+                                               <computeroutput>
        srfsh# <userinput>request opensrf.math add 2 2</userinput></computeroutput>
-       <computeroutput>
+                                               <computeroutput>
        Received Data: 4
        ------------------------------------
        Request Completed Successfully
        Request Time in seconds: 0.007519
        ------------------------------------</computeroutput>
-</screen>
+                                       </screen>
                                        <para>For other <command>srfsh</command> commands, type in
                                        <userinput>help</userinput> at the prompt.</para>
                                </step>
                                        <command>osrf_ctl.sh</command> again. As the 
                                        <systemitem class="username">opensrf</systemitem> 
                                        user, stop OpenSRF as follows:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        osrf_ctl.sh -l -a stop_all</userinput>
-</screen>
+                                       </screen>
                                </step>
                        </procedure>
                </section>
                                        the directory <filename class="directory">/home/opensrf</filename> then download
                                        and extract Evergreen. The new subdirectory
                                        <filename class="directory">/home/opensrf/Evergreen-ILS-1.6.1.6</filename> will be created:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        cd /home/opensrf
        wget http://evergreen-ils.org/downloads/Evergreen-ILS-1.6.1.6.tar.gz
        tar zxf Evergreen-ILS-1.6.1.6.tar.gz</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step xml:id="serversideinstallation-installprereq">
                                        <title>Install Prerequisites to Build Evergreen</title>
                                        For example, to install the prerequisites for Ubuntu version 9.10 (Karmic Koala) you would
                                        enter this command: <command>make -f Open-ILS/src/extras/Makefile.install
                                        ubuntu-karmic</command>.</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        cd /home/opensrf/Evergreen-ILS-1.6.1.6
        make -f Open-ILS/src/extras/Makefile.install [DISTRIBUTION]</userinput>
-</screen>
+                                       </screen>
                                        <table xml:id="serversideinstallation-keywords-evergreen">
                                                <?dbfo keep-together="always" ?>
                                                <title>Keyword Targets for Evergreen <application>"make"</application> Command</title>
                                        <para>You will need to install several Perl modules on the other system. As the
                                        <systemitem class="username">root</systemitem> user install the following Perl
                                        modules:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        # first, ensure the gcc compiler is installed:
        apt-get install gcc
 
        # then install the Perl modules:
        perl -MCPAN -e shell</userinput>
-       <computeroutput>
+                                               <computeroutput>
        cpan> <userinput>install JSON::XS</userinput>
        cpan> <userinput>install MARC::Record</userinput>
        cpan> <userinput>install MARC::File::XML</userinput></computeroutput>
-</screen>
+                                       </screen>
                                        <para>For more information on installing Perl Modules vist the official
                                        <link xl:href="http://www.cpan.org/">CPAN</link> site.</para>
                                        <indexterm>
                                        do this by creating the new file <filename>/etc/ld.so.conf.d/osrf.conf</filename>
                                        containing a new library path, then run the command <command>ldconfig</command> to
                                        automatically read the file and modify the system dynamic library path:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        echo "/usr/local/lib"     >> /etc/ld.so.conf.d/osrf.conf
        echo "/usr/local/lib/dbd" >> /etc/ld.so.conf.d/osrf.conf
        ldconfig</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step performance="optional">
                                        <title>Restart the PostgreSQL Server</title>
                                        execute the following command (remember to replace
                                        <emphasis>PGSQL_VERSION</emphasis> with your installed PostgreSQL version,
                                        for example <literal>8.3</literal>):</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        /etc/init.d/postgresql-PGSQL_VERSION restart</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step xml:id="serversideinstallation-configure">
                                        <title>Configure Evergreen</title>
                                        and linked later in <xref linkend="serversideinstallation-compile"/>.</para>
                                        <para>As the <systemitem class="username">opensrf</systemitem> user, return to
                                        the Evergreen build directory and execute these commands:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        cd /home/opensrf/Evergreen-ILS-1.6.1.6
        ./configure --prefix=/openils --sysconfdir=/openils/conf
        make</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step xml:id="serversideinstallation-compile">
                                        <title>Compile, Link and Install Evergreen</title>
                                        default Evergreen Staff Client.</para>
                                        <para>As the <systemitem class="username">root</systemitem> user, return to the
                                        Evergreen build directory and use the <command>make</command> utility as shown below:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        cd /home/opensrf/Evergreen-ILS-1.6.1.6
        make STAFF_CLIENT_BUILD_ID=rel_1_6_1_6 install</userinput>
-</screen>
+                                       </screen>
                                        <para>The Staff Client will also be automatically built, but you must remember
                                        to set the variable <envar>STAFF_CLIENT_BUILD_ID</envar> to match the version of the 
                                        Staff Client you will use to connect to the Evergreen server.</para>
                                        directory <filename class="directory">/openils/var/web/xul</filename> that points to the
                                        subdirectory <filename class="directory">/server</filename> of the new Staff Client
                                        build:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        cd /openils/var/web/xul
        ln -sf rel_1_6_1_6/server server</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <title>Copy the OpenSRF Configuration Files</title>
                                        to <systemitem class="username">opensrf</systemitem>.
                                        As the <systemitem class="username">root</systemitem> user, execute the following
                                        commands:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        cd /openils/conf
        cp opensrf.xml        opensrf.xml.BAK
        cp opensrf_core.xml.example opensrf_core.xml
        cp oils_web.xml.example     oils_web.xml
        chown -R opensrf:opensrf /openils/</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <title>Create and Configure PostgreSQL Database</title>
                                                        <para>As the <systemitem class="username">postgres</systemitem>
                                                        user on the PostgreSQL system create the PostgreSQL database,
                                                        then set some internal paths:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the postgres user:
        createdb evergreen -E UTF8 -T template0
        createlang plperl   evergreen
        createlang plperlu  evergreen
        createlang plpgsql  evergreen</userinput>
-</screen>
+                                                       </screen>
                                                        <para>Continue as the <systemitem class="username">postgres</systemitem> user
                                                        and execute the SQL scripts as shown below (remember to adjust the paths as needed,
                                                        where <emphasis>PGSQL_VERSION</emphasis> is your installed PostgreSQL
                                                        version, for example <literal>8.3</literal>).</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the postgres user:
        psql -f /usr/share/postgresql/PGSQL_VERSION/contrib/tablefunc.sql evergreen
        psql -f /usr/share/postgresql/PGSQL_VERSION/contrib/tsearch2.sql  evergreen
        psql -f /usr/share/postgresql/PGSQL_VERSION/contrib/pgxml.sql     evergreen</userinput>
-</screen>
+                                                       </screen>
                                                </step>
                                                <step xml:id="serversideinstallation-postgresqlcreateuser">
                                                        <title>Create <systemitem class="username">evergreen</systemitem> PostgreSQL user</title>
                                                        named <systemitem class="username">evergreen</systemitem> and
                                                        assign a password (remember to replace <emphasis>NEWPASSWORD</emphasis>
                                                        with an appropriate new password):</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the postgres user:
        createuser -P -s evergreen</userinput>
-       <computeroutput>
+                                                               <computeroutput>
        Enter password for new role: <userinput>NEWPASSWORD</userinput>
        Enter it again: <userinput>NEWPASSWORD</userinput></computeroutput>
-</screen>
+                                                       </screen>
                                                </step>
                                                <step>
                                                        <title>Create database schema</title>
                                                        the following commands and replace <emphasis>HOSTNAME, PORT,
                                                        PASSWORD</emphasis> and <emphasis>DATABASENAME</emphasis> with appropriate
                                                        values:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        cd /home/opensrf/Evergreen-ILS-1.6.1.6
        perl Open-ILS/src/support-scripts/eg_db_config.pl --update-config \
          --service all --create-schema --create-bootstrap --create-offline \
          --hostname HOSTNAME --port PORT \
          --user evergreen --password PASSWORD --database DATABASENAME</userinput>
-</screen>
+                                                       </screen>
                                                        <para>On most systems, <emphasis>HOSTNAME</emphasis> will be
                                                        <emphasis role="bold">localhost</emphasis> and
                                                        <emphasis>PORT</emphasis> will be <emphasis role="bold">5432</emphasis>.
                                                        <indexterm>
                                                                <primary>Apache modules</primary>
                                                        </indexterm>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        a2enmod ssl     # enable mod_ssl
        a2enmod rewrite # enable mod_rewrite
        a2enmod expires # enable mod_expires</userinput>
-</screen>
+                                                       </screen>
                                                        <para>As the commands execute, you may see warnings similar to:
                                                        <literal>Module SOMEMODULE already enabled</literal> but you can
                                                        safely ignore them.</para>
                                                        Evergreen installation directory to the Apache directory. As the
                                                        <systemitem class="username">root</systemitem> user, perform the
                                                        following commands:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        cd /home/opensrf/Evergreen-ILS-1.6.1.6
        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/startup.pl     /etc/apache2/</userinput>
-</screen>
+                                                       </screen>
                                                </step>
                                                <step xml:id="serversideinstallation-createsslcertificate">
                                                        <title>Create a Security Certificate</title>
                                                        accept the warnings in the Staff Client and browser during testing and
                                                        development. As the <systemitem class="username">root</systemitem> user,
                                                        perform the following commands:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        mkdir /etc/apache2/ssl
        cd /etc/apache2/ssl
        openssl req -new -x509 -days 365 -nodes -out server.crt -keyout server.key</userinput>
-</screen>
+                                                       </screen>
                                                        <para>You will be prompted for several items of information; enter
                                                        the appropriate information for each item. The new files
                                                        <filename>server.crt</filename> and <filename>server.key</filename> will
                                                                        <para>In the section
                                                                        <literal>&lt;Directory "/openils/var/cgi-bin"></literal>
                                                                        replace the line:</para>
-                                                                       <literal>Allow from 10.0.0.0/8</literal> 
+                                                                       <literal>Allow from 10.0.0.0/8</literal>
                                                                        <para>with the line:</para>
                                                                        <literal>Allow from all</literal>
                                                                        <warning>This change allows access to your configuration
                                                                        <systemitem class="osname">Debian Lenny</systemitem>, as
                                                                        the <systemitem class="username">root</systemitem> user,
                                                                        edit the Apache configuration file and change the lines:</para>
-<screen>
-       <userinput>
+                                                                       <screen>
+                                                                               <userinput>
        export APACHE_RUN_USER=www-data
        export APACHE_RUN_GROUP=www-data</userinput>
-</screen>
+                                                                       </screen>
                                                                        <para>to instead read:</para>
-<screen>
-       <userinput>
+                                                                       <screen>
+                                                                               <userinput>
        export APACHE_RUN_USER=opensrf
        export APACHE_RUN_GROUP=opensrf</userinput>
-</screen>
+                                                                       </screen>
                                                                </listitem>
                                                                <listitem>
                                                                        <para>As the 
                                                                        modify the value for <literal>KeepAliveTimeout</literal>
                                                                        and <literal>MaxKeepAliveRequests</literal> to match
                                                                        the following:</para>
-<screen>
-       <userinput>
+                                                                       <screen>
+                                                                               <userinput>
        KeepAliveTimeout       1
        MaxKeepAliveRequests 100</userinput>
-</screen>
+                                                                       </screen>
                                                                </listitem>
                                                                <listitem>
                                                                        <para>Further configuration changes to Apache may be
                                                                        and modify the section related to <emphasis>prefork
                                                                        configuration</emphasis> to suit the load on your
                                                                        system:</para>
-<programlisting language="xml"><![CDATA[
+                                                                       <programlisting language="xml"><![CDATA[
 <IfModule mpm_prefork_module>
    StartServers           20
    MinSpareServers      5
                                                        following Apache configuration commands to disable the default
                                                        <emphasis>It Works</emphasis> web page and enable the Evergreen
                                                        web site, and then restart the Apache server:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        # disable/enable web sites
        a2dissite default
        a2ensite eg.conf
        # restart the server
        /etc/init.d/apache2 reload</userinput>
-</screen>
+                                                       </screen>
                                                </step>
                                        </substeps>
                                </step>
                                                        <para>Modify the permissions in the directory 
                                                        <filename class="directory">/openils/var/cgi-bin</filename> 
                                                        to make the files executable:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the opensrf user:
        chmod 755 /openils/var/cgi-bin/*.cgi</userinput>
-</screen>
+                                                       </screen>
                                                </listitem>
                                                <listitem>
                                                        <para>As the <systemitem class="username">opensrf</systemitem> user,
                                                        <emphasis>before</emphasis> the line <literal>[ -z "$PS1" ] &amp;&amp;
                                                        return </literal>. This will allow headless (scripted) logins to load the
                                                        correct environment.</note>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the opensrf user:
        echo "export PERL5LIB=/openils/lib/perl5:\$PERL5LIB" >> ~/.bashrc
        . ~/.bashrc</userinput>
-</screen>
+                                                       </screen>
                                                </listitem>
                                        </itemizedlist>
                                </step>
                                        <para>As the <systemitem class="username">root</systemitem>
                                        user, start the <systemitem class="service">ejabberd</systemitem> and 
                                        <systemitem class="service">memcached</systemitem> services as follows:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        /etc/init.d/ejabberd start
        /etc/init.d/memcached start</userinput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <para>As the <systemitem class="username">opensrf</systemitem> user,
                                        start Evergreen as follows:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        osrf_ctl.sh -l -a start_all</userinput>
-</screen>
+                                       </screen>
                                        <para>The flag <option>-l</option> forces Evergreen to use 
                                        <systemitem class="domainname">localhost</systemitem> (your current system) 
                                        as the hostname. The flag <option>-a start_all</option>  starts the other 
                                        changes to the library hierarchy.</para>
                                        <para>As the <systemitem class="username">opensrf</systemitem> user, execute the
                                        following command and review the results:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the opensrf user:
        cd /openils/bin
        ./autogen.sh -c /openils/conf/opensrf_core.xml -u</userinput>
-       <computeroutput>
+                                               <computeroutput>
        Updating Evergreen organization tree and IDL using '/openils/conf/opensrf_core.xml'
        Updating fieldmapper
        Updating web_fieldmapper
        Refreshing proximity of org units
        Successfully updated the organization proximity
        Done</computeroutput>
-</screen>
+                                       </screen>
                                </step>
                                <step>
                                        <para>As the <systemitem class="username">root</systemitem> user, restart the
                                        Apache Web server:</para>
-<screen>
-       <userinput>
+                                       <screen>
+                                               <userinput>
        # as the root user:
        /etc/init.d/apache2 restart</userinput>
-</screen>
+                                       </screen>
                                        <note>If the Apache Web server was running when you started the OpenSRF
                                        services, you might not be able to successfully log into the OPAC or Staff
                                        Client until the Apache Web server has been restarted.</note>
                                <command>srfsh</command> commands, type <userinput>help</userinput> at the prompt.
                                As the <systemitem class="username">opensrf</systemitem> user,
                                execute the following commands to test your Evergreen connection:</para>
-<screen>
-       <userinput>
+                               <screen>
+                                       <userinput>
        # as the opensrf user:
        /openils/bin/srfsh</userinput>
-       <computeroutput>
+                                       <computeroutput>
        srfsh% <userinput>login admin open-ils</userinput>
        Received Data: "250bf1518c7527a03249858687714376"
        ------------------------------------
        Request Completed Successfully
        Request Time in seconds: 1.336568
        ------------------------------------</computeroutput>
-</screen>
+                               </screen>
                                <para>If this does not work, try the following:</para>
                                <itemizedlist>
                                        <listitem>
                                                <para>As the <systemitem class="username">opensrf</systemitem> user, run the
                                                <filename>settings-tester.pl</filename> utility to review your Evergreen
                                                installation for any system configuration problems:</para>
-<screen>
-       <userinput>
+                                               <screen>
+                                                       <userinput>
        # as the opensrf user:
        cd /home/opensrf
        ./Evergreen-ILS-1.6.1.6/Open-ILS/src/support-scripts/settings-tester.pl</userinput>
-</screen>
+                                               </screen>
                                                <para>If the output of <command>settings-tester.pl</command> does not help you
                                                find the problem, please do not make any significant changes to your
                                                configuration.</para>
                                version 3.0 and later on Ubuntu and Debian distributions).</para>
                                <para>As the <systemitem class="username">root</systemitem> user, start the Staff Client
                                as shown:</para>
-<screen>
-       <userinput>
+                               <screen>
+                                       <userinput>
        # as the root user:
        xulrunner /home/opensrf/Evergreen-ILS-1.6.1.6/Open-ILS/xul/staff_client/build/application.ini</userinput>
-</screen>
+                               </screen>
                                <para>A login screen for the Staff Client similar to this should appear:</para>
                                <mediaobject>
                                        <alt>Logging into the Staff Client</alt>
                                commands. Note the use of <emphasis>restart</emphasis> to force the new Evergreen
                                modules to be reloaded even if the Apache server is already running. Any problems found
                                with your configuration files should be displayed:</para>
-<screen>
-       <userinput>
+                               <screen>
+                                       <userinput>
        # as the root user:
        apache2ctl configtest &amp;&amp; /etc/init.d/apache2 restart</userinput>
-</screen>
+                               </screen>
                        </simplesect>
                        <simplesect xml:id="serversideinstallation-stopping">
                                <title>Stopping Evergreen</title>
                                Evergreen services.</para>
                                <para>As the <systemitem class="username">opensrf</systemitem> user, stop all Evergreen
                                services by using the following command:</para>
-<screen>
-       <userinput>
+                               <screen>
+                                       <userinput>
        # as the opensrf user
        #   stop the server; use "-l" to force hostname to be "localhost"
        osrf_ctl.sh -l -a stop_all</userinput>
-</screen>
+                               </screen>
                                <note>You can also stop Evergreen services <emphasis role="bold">without</emphasis> the
                                <option>-l</option> flag, but the <command>osrf_ctl.sh</command> utility must know the
                                fully qualified domain name for the system on which it will execute. That hostname may
                                </warning>
                        </section>
                        <section>
+                               <title>(OPTIONAL) IP-Redirection</title>
+                               <para>By default, Evergreen is configured so searching the OPAC always starts in the
+                               top-level (regional) library rather than in a second-level (branch) library. Instead,
+                               you can use "IP-Redirection" to change the default OPAC search location to use the IP
+                               address range assigned to the second-level library where the seach originates. You must
+                               configure these IP ranges by creating the configuration file
+                               <filename>/openils/conf/lib_ips.txt</filename> and modifying the Apache startup script
+                               <filename>/etc/apache2/startup.pl</filename>.</para>
+                               <para>First, copy the sample file
+                               <filename>/home/opensrf/Evergreen-ILS-1.6.1.2/Open-ILS/examples/lib_ips.txt.example</filename>
+                               to <filename>/openils/conf/lib_ips.txt</filename>. The example file contains the single
+                               line: <literal>"MY-LIB 127.0.0.1 127.0.0.254"</literal>. You must modify the file to use
+                               the IP address ranges for your library system. Add new lines to represent the IP address
+                               range for each branch library. Replace the values for <literal>MY-LIB</literal> with the
+                               values for each branch library found in the table
+                               <literal>actor.org_unit</literal>.</para>
+                               <para>Finally, modify the Apache startup script
+                               <filename>/etc/apache2/startup.pl</filename> by uncommenting two lines as shown, then
+                               restarting the Apache server:</para>
+                               <programlisting language="xml"><![CDATA[
+# - Uncomment the following 2 lines to make use of the IP redirection code
+# - The IP file should contain a map with the following format:
+# - actor.org_unit.shortname <start_ip> <end_ip>
+# - e.g.  LIB123 10.0.0.1 10.0.0.254
+use OpenILS::WWW::Redirect qw(/openils/conf/opensrf_core.xml);
+OpenILS::WWW::Redirect->parse_ips_file('/openils/conf/lib_ips.txt');
+]]></programlisting>
+                       </section>
+                       <section>
                                <title>(OPTIONAL) Set Up Support For Reports</title>
                                <para>Evergreen reports are extremely powerful but require some simple configuration.
                                See <xref linkend="report_starting_reporter_service"/> for information on starting and
                                                                <row>
                                                                        <entry>Debian "Lenny" (5.0)</entry>
                                                                        <entry>1.6.1.4</entry>
-                                                                       <entry><ulink url="http://www.open-ils.org/~denials/Evergreen_1_6_1_4_Lenny.zip">
-                                                                       download</ulink></entry>
+                                                                       <entry>
+                                                                               <ulink url="http://www.open-ils.org/~denials/Evergreen_1_6_1_4_Lenny.zip">
+                                                                       download</ulink>
+                                                                       </entry>
                                                                        <entry>VirtualBox image (no preloaded data)</entry>
                                                                </row>
                                                                <row>
                                                                        <entry>Debian "Lenny" (5.0)</entry>
                                                                        <entry>1.6.0.1</entry>
-                                                                       <entry><ulink url="http://www.open-ils.org/~denials/Evergreen1601_DebianLenny.zip">
-                                                                       download</ulink></entry>
+                                                                       <entry>
+                                                                               <ulink url="http://www.open-ils.org/~denials/Evergreen1601_DebianLenny.zip">
+                                                                       download</ulink>
+                                                                       </entry>
                                                                        <entry>VirtualBox image (no preloaded data)</entry>
                                                                </row>
                                                                <row>
                                                                        <entry>Ubuntu "Karmic Koala" (9.10)</entry>
                                                                        <entry>1.6.0.0</entry>
-                                                                       <entry><ulink url="http://www.open-ils.org/~denials/Evergreen-1600-Karmic.zip">
-                                                                       download</ulink></entry>
+                                                                       <entry>
+                                                                               <ulink url="http://www.open-ils.org/~denials/Evergreen-1600-Karmic.zip">
+                                                                       download</ulink>
+                                                                       </entry>
                                                                        <entry>VirtualBox image (no preloaded data)</entry>
                                                                </row>
                                                                <row>
                                                                        <entry>Ubuntu "Hardy Heron" (8.04)</entry>
                                                                        <entry>1.2.3.1</entry>
-                                                                       <entry><ulink url="http://open-ils.org/~denials/Ubuntu804.zip">
-                                                                       download</ulink></entry>
+                                                                       <entry>
+                                                                               <ulink url="http://open-ils.org/~denials/Ubuntu804.zip">
+                                                                       download</ulink>
+                                                                       </entry>
                                                                        <entry>VirtualBox image (no preloaded data)</entry>
                                                                </row>
                                                                <row>
                                                                        <entry>Debian Etch (4.0)</entry>
                                                                        <entry>1.2.2.3</entry>
-                                                                       <entry><ulink url="http://evergreen-ils.org/~denials/Evergreen_Debian_1.2.2.3.zip">
-                                                                       download</ulink></entry>
+                                                                       <entry>
+                                                                               <ulink url="http://evergreen-ils.org/~denials/Evergreen_Debian_1.2.2.3.zip">
+                                                                       download</ulink>
+                                                                       </entry>
                                                                        <entry>VMware image (preloaded with 13,000 Gutenberg records)</entry>
                                                                </row>
                                                                <row>
                                                                        <entry>Ubuntu "Gutsy Gibbon" (7.10)</entry>
                                                                        <entry>1.2.1.4</entry>
-                                                                       <entry><ulink url="http://www.open-ils.org/downloads/vmware/Evergreen_1.2.1.4_on_Ubuntu_7.10.zip">
-                                                                       download</ulink></entry>
+                                                                       <entry>
+                                                                               <ulink url="http://www.open-ils.org/downloads/vmware/Evergreen_1.2.1.4_on_Ubuntu_7.10.zip">
+                                                                       download</ulink>
+                                                                       </entry>
                                                                        <entry>VMware image, contributed by
                                                                        <ulink url="http://library.calvin.edu/">
                                                                        the Hekman Library, Calvin College</ulink></entry>
                                                        <para>You must configure VirtualBox to recognized the new disk
                                                        image before you can create a new virtual machine to use it.
                                                        Start VirtualBox and select
-                                                       <menuchoice>
-                                                               <guimenu>File</guimenu>
-                                                               <guimenuitem>VirtualBox Media Manager</guimenuitem>
-                                                               <guimenuitem>Add</guimenuitem>
-                                                       </menuchoice>,
+                                                       <menuchoice><guimenu>File</guimenu><guimenuitem>VirtualBox Media Manager</guimenuitem><guimenuitem>Add</guimenuitem></menuchoice>,
                                                        then choose the disk image <literal>Lenny_1614_disk1.vmdk</literal>
                                                        that you just extracted to the temporary directory. Review
                                                        <xref linkend="serversideinstallation-virtual-vm-install-2"/>,
                                                        as the root user (see 
                                                        <xref linkend="serversideinstallation-starting"/> for more
                                                        information):</para>
-<screen>
-       <userinput>
-       su -                        # become the root user - enter "evergreen" for the password
-       su - opensrf                # as the opensrf user
+                                                       <screen>
+                                                               <userinput>
+       su -                    # become the root user - enter "evergreen" for the password
+       su - opensrf            # as the opensrf user
        osrf_ctl.sh -l -a start_all # start all Evergreen services
-       exit                        # become the root user again
+       exit                    # become the root user again
        /etc/init.d/apache2 restart # restart the Apache server</userinput>
-</screen>
+                                                       </screen>
                                                        <para>The following table lists the default accounts already set
                                                        up in the virtual machine:</para>
                                                        <table xml:id="serversideinstall-virtual-accounts">
                                                        <systemitem class="osname">Linux</systemitem> / Evergreen system. If
                                                        you need to modify the Evergreen configuration in any way, review
                                                        <xref linkend="serversideinstallation-ubuntudebian"/>
-                                                       in the standard Evergreen installation instructions.</para> 
+                                                       in the standard Evergreen installation instructions.</para>
                                                </step>
                                                <step>
                                                        <title>Start staff client</title>
                                                        start the desktop and Evergreen, you can connect to Evergreen
                                                        using the built-in staff client with the following
                                                        commands:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the opensrf user
        cd /home/opensrf/Evergreen-ILS-1.6.1.4/Open-ILS
        xulrunner-1.9 xul/staff_client/build/application.ini</userinput>
-</screen>
+                                                       </screen>
                                                        <para>Connect to 
                                                        <emphasis role="bold">localhost</emphasis> using the
                                                        username and password 
                                                        tend to map virtual devices to real MAC addresses on their host,
                                                        you might need to clear that mapping before making a connection.
                                                        As root, run:</para>
-<screen>
-       <userinput>
+                                                       <screen>
+                                                               <userinput>
        # as the root user:
        rm /etc/udev/rules.d/70-persistent-net.rules
        reboot</userinput>
-</screen>
+                                                       </screen>
                                                        <para>To create a network connection, as root run:
                                                        <emphasis role="bold">dhclient eth0</emphasis> to set up a NAT
                                                        connection.</para>
                                                        of device <literal>eth1</literal> using the
                                                        <command>ifconfig</command> command: 
                                                        <emphasis role="bold">/sbin/ifconfig eth1</emphasis>. The IP address 
-                                                       will be listed in the inet_addr stanza as something like: <emphasis
-                                                       role="bold">inet addr: 192.168.56.101</emphasis>.</para>
+                                                       will be listed in the inet_addr stanza as something like: <emphasis role="bold">inet addr: 192.168.56.101</emphasis>.</para>
                                                </step>
                                                <step>
                                                        <title>Network connections for external staff clients</title>