Jabber::mod_perl

-- mod_perl for jabberd --

Copyright (c) 2002, Piers Harding. All Rights Reserved.
This module is free software. It may be used, redistributed
and/or modified under the same terms as Perl itself.



Jabber::mod_perl is an embedded interpreter in the session manager of jabberd2 (sm daemon).
This allows the user to insert arbitrary perl code (in the form of loaded modules) in to the
processing chain of the session manager, in a similar fashion to mod_perl for Apache.

First of all you need to get hold of the jabberd2 source code, as this needs to 
be patched to include mod_perl.c in the build.

Also check that you have:
 - Cyrus SASL 2
     ftp://ftp.andrew.cmu.edu/pub/cyrus-mail/
 - OpenSSL (0.9.6e or higher)
     http://www.openssl.org/news/
 - Berkeley DB 4.1
     http://www.sleepycat.com/download.html
 - autoconf 2.50+
     http://www.gnu.org/software/autoconf/autoconf.html
 - automake 1.4+
     http://www.gnu.org/software/automake/automake.html
 - libtool 1.4+
     http://www.gnu.org/software/automake/automake.html

Get a source code release candidate for the jabberd2 from:
  http://www.jabberstudio.org/projects/jabberd2/project/view.php
and unpack it - something like this: tar -xzvf Jabber-mod_perl-0.03.tar.gz

OR: 

You can get the latest jabberd2 source code by checking it out of cvs on jabberstudio.org like this:

cvs -d :pserver:anonymous@jabberstudio.org:/home/cvs co jabberd2

( remember to login to cvs first like this: cvs -d :pserver:anonymous@jabberstudio.org:/home/cvs login )

this will give you a directory jabberd2 in the directory that you are currently sitting in.
After this you should unpack this distribution next to it giving you two adjacent directories -
./jabberd-2.x.x-ax ( or ./jabberd2 from cvs ) and ./Jabber-mod_perl-x.xx


Change into the Jabber-mod_perl-x.xx directory and then do the -

perl Makefile.PL
make 
make test
make install <- do not do this if you want to test things first - see below

Dance.

perl Makefile.pl will prompt you for the location of jabberd2 (if the above went according to plan
then the default should suffice ), and then you will be asked for configuration parameters to be
passed to ./configure for the build of jabberd2.

NOTE:
perl Makefile.PL will do the the entire configure and build for jabberd2 so don't forget to run make
for Jabber::mod_perl.

Once you have built Jabber::mod_perl - this should have compiled jabberd2 for you successfully.  You still
need to change to the jabberd2 directory (cd ../jabberd2 ), and make install here to install the server.
When the server is installed change to the server config directory (cd $PREFIX/etc/jabberd) and amend the 
sm.xml config file to activate mod_perl - eg:

 ......
    <!-- pkt-sm receives packets from the router that are addressed directly to the sm host (no user) -->
    <chain id='pkt-sm'>
      <module>iq-last</module>      <!-- return the server uptime -->
      <module>iq-time</module>      <!-- return the current server time -->
      <module>iq-version</module>   <!-- return the server name and version -->
      <module>echo</module>         <!-- echo messages sent to /echo -->
      <module>mod_perl</module>     <!-- mod_perl handler activated here -->
    </chain>
.....
  </modules>

<!-- directives for mod_perl to load handler modules -->
  <mod_perl>
    <handler>Some::Handler1</handler>
    <handler>MyEcho</handler>
  </mod_perl>
.....


Testing/Making it all run
=========================

The above handler modules are located in the examples directory of this distribution.
When running the session manager - you must make sure the Perl can find any module
that it is attempting to load.  I typically do this by setting the PERL5LIB 
environment variable to include the appropriate paths - eg:

export PERL5LIB=path/to/mod_perl/examples
/home/jabber/jabberd/bin/sm -D > /home/jabber/jabberd/sm.log 2>&1 &

Or something similar.

look at the two scripts in the tools/ directory (start and stop) as an example
of how to control this with a little less pain :-).

Make sure that you watch the sm.log file, as this will alert you to any problems regarding loading 
modules etc.

for more details:

perldoc Jabber::mod_perl

Piers Harding - piers@cpan.org