/hackabot

The big pile of code behind the big cuddly sea cow.

Primary LanguagePython

Hackabot README
===============

    A crazy, hackable, and hacked up IRC bot.
    Licensed under the GNU GPL v2 or later.

INTRODUCTION
------------

This bot was mainly written by Michael Marineau and includes
contributions from other people including various staff of the OSU Open
Source Lab. See docs/credits.txt for individual contributors. This bot
is more widely known by it's original incarnation as 'manatee' on
Freenode.

The current implementation (it has been rewritten several times) by now
features a core bot is written in Python using the Twisted framework.
Commands and other event handlers can be implemented as plugins for the
core bot or as individual scripts in commands/ or hooks/<type>/ which
are called on demand. Most of the time writing features as external
scripts is the way to go as plugins must always us non-blocking IO and
play nice with Twisted.

INSTALL
-------

The bot should be run directly from its source tree (don't copy
anything to /usr/bin). The code depends on the current directory layout
to find all of its various pieces. Since the bot has a lot of random
commands that you may not even want I've split the dependency list
between the core requirements and the various noodly bits.

Core Requirements
~~~~~~~~~~~~~~~~~

Python >= 2.4
Twisted Core >= 2.5
Twisted Words >= 2.5
MySQLdb (optional, see below)
lxml or elementtree if using Python 2.4

Hackabot can be run without a database but many commands and hooks
depend on it so you probably want it unless you are simply using
Hackabot as a framework for your own stuff.

Disclaimer: Although I think hackabot is compatible with Python 2.4 and
Twisted 2.5 it has been a while since it was tested with these versions.

Misc Requirements
~~~~~~~~~~~~~~~~~

Most external commands/hooks will be happy with the following:

Bash
Perl
DBI
DBD::mysql
XML::Simple
URI::Escape
Time::Piece
lynx
wget

Of course if you are running without db support DBI/DBD is optional but be
sure to disable those external commands as it won't happen automatically.

And some lesser things:

URI::Find::Rule         (TinyURL hook)
WWW::Shorten::TinyURL   (TinyURL hook)
SOAP::Lite              (Urban Dictionary command)
figlet                  (figlet command)
cowsay                  (cowsay command)
and other stuff I forget...

To attempt to get catch missing dependencies before starting run the
check-deps script in the bin directory. It is far from perfect and is
known to miss a few things, but it should catch most things.

CONFIGURATION
-------------

An example config file showing and explaining all the options is
etc/hackabot.example.xml and a more minimal one is hackabot.simple.xml.
The basics should be pretty clear from those examples.

To set up access to various commands create an ACL config file and point
to it using an acl tag in the main config file. The example and
documentation is in etc/acl.example.xml. ACL files can be defined
globally or per network.

RUNNING
-------

Once the config files are in place start hackabot with the config file
as the argument:
./bin/hackabot etc/hackabot.xml

If you want the bot to background the bot try this:
./bin/hackabot -l var/hackabot.log -p var/hackabot.pid etc/hackabot.xml


Further documentation can be found in the docs directory. Enjoy!

-- Michael Marineau <mike@marineau.org>